背景
C++11是C++语言的一个重大更新,引入了许多新个性,包含主动类型推导、lambda表达式、右值援用、智能指针等等。这些新个性使得C++更加现代化、高效、易用。也是面试容很容易被问到一个问题,上面我将简要介绍一些C++11的新个性:
主动类型推导
C++11引入了auto关键字,能够让编译器主动推导变量的类型。这样能够缩小代码中的反复代码,进步代码的可读性和可维护性。例如:
auto i = 42; // 推导为int类型auto d = 3.14; // 推导为double类型auto s = "hello"; // 推导为const char*类型
lambda表达式
C++11引入了lambda表达式,能够不便地定义匿名函数。这样能够缩小代码中的反复代码,进步代码的可读性和可维护性。例如:
auto f = [](int x, int y) { return x + y; };int z = f(1, 2); // z的值为3
右值援用
C++11引入了右值援用,能够不便地实现挪动语义和完满转发。这样能够进步代码的性能和效率。例如:
class MyString {public: MyString() : data_(nullptr), size_(0) {} MyString(const char* str) : data_(new char[strlen(str) + 1]), size_(strlen(str)) { strcpy(data_, str); } MyString(MyString&& other) : data_(other.data_), size_(other.size_) { other.data_ = nullptr; other.size_ = 0; } ~MyString() { delete[] data_; }private: char* data_; size_t size_;};
更多对于右值援用的内容,感兴趣的小伙伴能够翻看我之前的帖子,有专门的介绍。
智能指针
C++11引入了智能指针,能够不便地治理动态分配的内存,防止内存透露和悬空指针的问题。C++11中有两种智能指针:std::unique_ptr和std::shared_ptr。
std::unique_ptr是一种独占式智能指针,它领有对动态分配的对象的惟一所有权。当std::unique_ptr被销毁时,它所领有的对象也会被销毁。例如:
std::unique_ptr<int> p(new int(42));std::cout << *p << std::endl; // 输入42
std::shared_ptr是一种共享式智能指针,它能够被多个指针共享拥有权。当最初一个std::shared_ptr被销毁时,它所领有的对象也会被销毁。例如:
std::shared_ptr<int> p1(new int(42));std::shared_ptr<int> p2 = p1;std::cout << *p1 << " " << *p2 << std::endl; // 输入42 42
C++11的智能指针使得动态内存治理更加不便和平安。
range-based for循环
C++11引入了range-based for循环,能够不便地遍历容器中的元素。这样能够缩小代码中的反复代码,进步代码的可读性和可维护性。例如:
std::vector<int> v = {1, 2, 3, 4, 5};for (auto x : v) { std::cout << x << std::endl;}
nullptr
C++11引入了nullptr关键字,能够代替NULL宏定义。这样能够防止一些潜在的谬误。例如:
void f(int* p) {}f(nullptr); // 能够编译通过
constexpr
C++11引入了constexpr关键字,能够在编译期间计算表达式的值。这样能够进步代码的性能和效率。例如:
constexpr int factorial(int n) { return n == 0 ? 1 : n * factorial(n - 1);}int x = factorial(5); // x的值为120
更多对于constexpr的内容,感兴趣的小伙伴能够翻看我之前的帖子,有专门的介绍。
static_assert
C++11引入了static_assert关键字,能够在编译期间查看表达式的值是否为真。这样能够防止一些潜在的谬误。例如:
static_assert(sizeof(int) == 4, "int must be 4 bytes"); // 如果sizeof(int)不等于4,编译会失败
变长参数模板
C++11引入了变长参数模板,能够不便地解决可变数量的参数。这样能够进步代码的灵活性和可维护性。例如:
template<typename... Args>void f(Args... args) { std::cout << sizeof...(args) << std::endl; // 打印参数的数量}f(1, 2, 3); // 打印3f("hello", 3.14); // 打印2
线程反对库
C++11引入了线程反对库,能够不便地创立和治理线程。这样能够进步代码的并发性和可维护性。例如:
#include <iostream>#include <thread>void f() { std::cout << "hello, world" << std::endl;}int main() { std::thread t(f); // 创立一个新线程 t.join(); // 期待线程完结 return 0;}
结尾
以上是C++11的一些新个性,它们使得C++更加现代化、高效、易用。