c++标准库-c++11新特性

本文深入探讨了C++中的Range-Based for循环、Move语义、Rvalue引用、新式字符串字面常量、异常处理、constexpr关键字及main()定义式等高级特性,展示了如何优化代码并提高效率。

Range-Based for循环

  int x2[]{1, 2, 3, 4, 6};
  for (auto i:x2)
  {
    cout << i << endl;
  }
  {
    //等同上面for循环
    for (auto _pos = begin(x2), _end = end(x2); _pos!=_end; ++_pos)
    {
//      auto decl = *_pos;
      cout << *_pos << endl;
    }

    //class template std::initializer_lis<>提供了begin()和end()
    //所以可以如下for循环
    for (auto tmp: {1,2,3,4,5,7})
    {
      cout << tmp << endl;
    }
  }
//避免下面的元素调用了构造和析构函数,下面的for循环采用const reference
template<typename T>
void printElements(const T &coll)
{
  for (const auto &elem : coll)//const reference
  {
    std::cout << elem << std::endl;

  }
}

Move语义和Rvalue Reference

待补充,对实现理解的一知半解

新式字符串字面常量(String Literal)

Raw String Literal

语法:R"delim(....)delim"
其中delim是一个字符序列,最多16个基本字符,不可以包含反斜线、空格、小括号。
其允许我们定义字符序列(character sequence),从而避免书写很多的转移字符。

  std::string x3(R"(\\n)");
  std::string x4("\\\\n");//同上
  std::string rawStr = R"(\\n)";
  std::string rawStr = R"nc(a\
                            b\nc()"
                            )nc";
  cout << rawStr << endl;
  //完整语法书输出
  cout << "===========" << endl;
  /*
  a\
                            b\nc()"
                            
===========
*/

编码的String Literal

  • u8 以UTF-8编定的某个字符起头,字符类型为const char
  • u 定义一个string literal,带着类型为char16_t
  • U定义一个string literal,带着类型为char32_t
  • L定义一个wide string literal,带着类型为wchar_t的字符
  • Raw string开头的那个R的前面还可以放置一个编码前缀

关键字noexcept

用来指明某个函数无法——或不打算——抛出异常。例如:

void foo() noexcept;//如果foo()有异常未被处理或者抛出异常,则程序会被终止
//然后std::terminate()被调用并默认调用std::abort()

关键字constexpr

不是很了解用法,需要后续补充

//constexpr  用于让表达式在编译期通过检查
constexpr int square(int x)
{
  return x*x;
}
float a[square(9)];//constexpr用来在这里使得数组通过编译期运算

# main()定义式
c++标准中定义“正确且具有移植性”的main()如下所示,c++中隐式的定义了一个return 0;

int main()
{
}int main(int argc, char * argv[])
{
}

异常Execption

一下示范如何使用一个泛型函数来处理(这里只是打印)不同的异常

#include <exception>
#include <system_error>
#include <future>
#include <iostream>

template <typename T>
void processCodeException (const T& e)
{
    using namespace std;
    auto c = e.code();
    cerr << "- category:     " << c.category().name() << endl;
    cerr << "- value:        " << c.value() << endl;
    cerr << "- msg:          " << c.message() << endl;
    cerr << "- def category: "
         << c.default_error_condition().category().name() << endl;
    cerr << "- def value:    "
         << c.default_error_condition().value() << endl;
    cerr << "- def msg:      "
         << c.default_error_condition().message() << endl;
}

void processException()
{
    using namespace std;
    try {
        throw;  // rethrow exception to deal with it here
    }
    catch (const ios_base::failure& e) {
        cerr << "I/O EXCEPTION: " << e.what() << endl;
        processCodeException(e);
    }
    catch (const system_error& e) {
        cerr << "SYSTEM EXCEPTION: " << e.what() << endl;
        processCodeException(e);
    }
    catch (const future_error& e) {
        cerr << "FUTURE EXCEPTION: " << e.what() << endl;
        processCodeException(e);
    }
    catch (const bad_alloc& e) {
        cerr << "BAD ALLOC EXCEPTION: " << e.what() << endl;
    }
    catch (const exception& e) {
        cerr << "EXCEPTION: " << e.what() << endl;
    }
    catch (...) {
        cerr << "EXCEPTION (unknown)" << endl;
    }
}


//那么我们可以如下使用方式来处理异常
try{

}
catch(...)
{
    processException();
}
相比于 C++98 带来的面向对象的革命性,C++11 带来的 XIII  却并非“翻天覆地”式的改变。很多时候,程序员保持着“C++98 式”的观点来看待 C++11 代码也同样是合理的。因为在编程思想上,C++11 依然遵从了一贯的面向对象的思想,并深 入加强了泛型编程的支持。从我们的观察来看,C++11 更多的是对步入“成熟稳重”的中年 时期的 C++ 的一种改造。比如,像 auto 类型推导这样的新特性,展现出的是语言的亲和力 ; 而右值引用、移动语义的特性,则着重于改变一些使用 C++ 程序库时容易发生的性能不佳的 状况。当然,C++11 中也有局部的创新,比如 lambda 函数的引入,以及原子类型的设计等, 都体现了语言与时俱进的活力。语言的诸多方面都在 C++11 中再次被锤炼,从而变得更加合 理、更加条理清晰、更加易用。C++11C++ 语言改进的每一点,都呈现出了经过长时间技 术沉淀的编程语言的特色与风采。所以从这个角度上看,学习 C++11C++98 在思想上是 一脉相承的,程序员可以用较小的代价对 C++ 的知识进行更新换代。而在现实中,只要修改 少量已有代码(甚至不修改) ,就可以使用 C++11 编译器对旧有代码进行升级编译而获得新 标准带来的好处,这也非常具有实用性。因此,从很多方面来看,C++ 程序员都应该乐于升 级换代已有的知识,而学习及使用 C++11 也正是大势所趋。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值