背景

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++更加现代化、高效、易用。