首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

每个C++开发者都应该学习和使用的C++11特性

本节目录 unsetunset1、autounsetunset 在C++中,auto是一个关键字,用于进行类型推导。它的引入是为了简化代码并提高可读性。...NULL 和 0 都可以隐式地转换为整数类型,可能引入一些不符合预期的行为。 为了解决这些问题,C++11 引入了 nullptr,它是一个明确的空指针常量,不具有整数类型,可以显式地表示空指针。...安全性:在重载函数或者模板中,使用 nullptr 可以避免因为整数类型的隐式转换导致的调用错误的重载版本的问题。 语法清晰:使用 nullptr 可以让代码更加清晰明了,表达程序员的意图。...1. override 关键字 override 关键字用于显式地标记派生类中的成员函数,以指明该函数是对基类中的虚函数的重写。...移动语义的实现: 为了支持移动语义,需要在类中定义移动构造函数和移动赋值运算符,并在这些函数中执行资源的转移操作。同时,也需要标记需要移动的对象为右值引用。

7810

《C++Primer》第十九章

,如果找到了用户自定义的版本,则使用该版本执行new或者delete表达式 没找到的话,则使用标准库定义的版本 我们可以使用作用域运算符使得new表达式或delete表达式忽略定义在类中的函数,直接执行全局作用域的版本...显式的析构函数调用 就像定位new与使用allocate类似一样,对析构函数的显式调用也与使用destroy很类似。...假设我们无法使用虚函数,那么可以使用一个RTTI运算符。另一方面,与虚成员函数相比,使用RTTI运算符蕴涵着更多潜在的风险:程序员必须清楚地知道转换的目标类型并且必须检查类型转换是否被成功执行。...,那么我们必须显式地声明函数类型以明确指出来我们想要使用的是哪个函数 // 例如我们可以声明一个指针, 令其指向含有两个形参的get: char (Screen::*pmf2)(Screen::pos,...使用union类型 和其他内置类型一样,默认情况下union是未初始化的,我们可以像显式地初始化聚合类一样用一对花括号内的初始值显式地初始化一个union: Token first_token = {'

1.4K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    什么?CC++面试过不了?因为你还没看过这个!

    它指向调用该成员函数的那个对象。 当对一个对象调用成员函数时,编译程序先将对象的地址赋给 this 指针,然后调用成员函数,每次成员函数存取数据成员时,都隐式使用 this 指针。...在以下场景中,经常需要显式引用 this 指针: 为实现对象的链式引用; 为避免对同一对象进行赋值操作; 在实现一些数据结构时,如 list。...内联函数相比宏函数来说,在代码展开时,会做安全检查或自动类型转换(同普通函数),而宏定义则不会。 在类中声明同时定义的成员函数,自动转化为内联函数,因此内联函数可以访问类的成员变量,宏定义则不能。...引用折叠 X& &、X& &&、X&& & 可折叠成 X& X&& && 可折叠成 X&& 宏 宏定义可以实现类似于函数的功能,但是它终归不是函数,而宏定义中括弧中的“参数”也不是真的参数,在宏展开的时候对...virtual int A() = 0; 虚函数、纯虚函数 类里如果声明了虚函数,这个函数是实现的,哪怕是空实现,它的作用就是为了能让这个函数在它的子类里面可以被覆盖(override),这样的话,编译器就可以使用后期绑定来达到多态了

    3.7K50

    C语言与C++面试知识总结

    它指向调用该成员函数的那个对象。 当对一个对象调用成员函数时,编译程序先将对象的地址赋给 this 指针,然后调用成员函数,每次成员函数存取数据成员时,都隐式使用 this 指针。...在以下场景中,经常需要显式引用 this 指针: 为实现对象的链式引用; 为避免对同一对象进行赋值操作; 在实现一些数据结构时,如 list。...内联函数相比宏函数来说,在代码展开时,会做安全检查或自动类型转换(同普通函数),而宏定义则不会。 在类中声明同时定义的成员函数,自动转化为内联函数,因此内联函数可以访问类的成员变量,宏定义则不能。...引用折叠 X& &、X& &&、X&& & 可折叠成 X& X&& && 可折叠成 X&& 宏 宏定义可以实现类似于函数的功能,但是它终归不是函数,而宏定义中括弧中的“参数”也不是真的参数,在宏展开的时候对...virtual int A() = 0; 虚函数、纯虚函数 类里如果声明了虚函数,这个函数是实现的,哪怕是空实现,它的作用就是为了能让这个函数在它的子类里面可以被覆盖(override),这样的话,编译器就可以使用后期绑定来达到多态了

    5K41

    Modern c++快速浅析

    用于Lambda表达式时,同样代表遵循模板类型推导的原则,例如C++11中可以将其用于匿名函数参数的推导 // 使用auto接住匿名函数,匿名函数使用auto进行参数推导,匿名函数的返回值使用auto推导...C++中都得到了提高 在C++11中,constexpr可以用来修饰对象(包括内置类型和自定义类型),以及可以用来修饰函数(构造函数,成员函数,普通函数等等),如果以constexpr修饰构造函数,那么代表构造出来的对象可以是一个编译期常量...以修饰函数为例,函数是否的返回值是否满足constexpr取决于两个方面 •传入的参数是否是编译期常量•函数体内的计算是否是编译期能够处理的 当两者条件都能满足时,它的结果就是constexpr的,否则它的运作方式和普通函数无异...,并且不给出它们的实现,如果在用户代码中仍然去访问此没有实现的成员函数,那么会在链接阶段得到错误。...template void processPointer(char*) = delete; = default只能用在特定的成员函数中,显式要求编译器生成对应版本的函数 override

    20410

    第 14 章 重载运算与类型转换

    成员运算符函数的(显式)参数数量比运算对象的数量少一个。...一个类中往往会同时定义这两种运算符,通常情况下,箭头运算符可以不执行任何操作,而是调用解引用运算符并返回解引用结果元素的地址。 重载的箭头运算符必须返回类的指针或者自定义了箭头运算符的某个类的对象。...一般情况下,比较两个无关指针将产生未定义行为,然而如果希望比较指针的内存地址来 sort指针的 vector,可以使用一个标准库函数对象来实现该目的。...,但是隐式的用户定义的类型转换可以置于一个标准(内置)类型转换之前或之后,并与其一起使用。...显式转换必须通过显式的强制类型转换才可以使用,不过当用作条件判断时,编译器还是会自动执行显式的类型转换。

    89860

    【c++11】列表初始化与声明

    它常用于用户自定义的类或函数,使其可以接受固定数量的初始化元素。 1. 定义与特点 std::initializer_list 的定义位于头文件 中。....声明 c++11提供了多种简化声明的方式,尤其是在使用模板时 2.1 auto 在C++98中auto是一个存储类型的说明符,表明变量是局部自动存储类型,但是局部域中定义局部的变量默认就是自动存储类型...它的能力远超 auto,可以精确地获取表达式的类型,尤其适合处理复杂类型和左值/右值差异的场景。 1. 定义与作用 decltype 的功能是检查一个表达式的类型,并返回该类型。...使用场景与示例 (1)推导变量类型 decltype 可以用来推导变量的类型,而无需显式声明。...std::cout << w << std::endl; // 输出 5.5 return 0; } (3)用在函数返回类型 在函数返回类型中,可以使用 decltype 推导返回值的类型

    13710

    lambda表达式的介绍

    第二行代码调用了这个 lambda 表达式,并输出其返回值 42。lambda 表达式是 C++11 引入的一种新特性,可以用于定义一个匿名函数对象。...第二段代码定义了一个带有两个参数的 lambda 表达式,它返回第一个参数字符串的长度是否小于第二个参数字符串的长度。...该 lambda 表达式中使用了一个函数对象调用运算符,用于在调用时执行 lambda 表达式的函数体,并返回计算结果。捕获规则lambda表达式的捕获列表有值捕获和引用捕获!...我们希望对一部分变量采用值捕获,对其他变量采用引用捕获,可以混合使用隐式捕获和显式捕获:当混合使用隐式捕获和显式捕获时,捕获列表中的第一个元素必须是一个&或=(必须隐式)当混合使用隐式捕获和显式捕获时,...但是通过值捕获时,在lambda生成的类中需要为值捕获的变量生成数据成员,创建构造函数:auto w=find\_if(vec.begin(),vec.end(),sz{return a.size()>

    15000

    《C++Primer》第十三章 拷贝控制

    第十三章 拷贝控制 简介 当定义一个类时,我们显式或者隐式地指定此类型对象拷贝、移动、赋值和销毁时做什么。...在一个析构函数中,不存在类似构造函数中初始化列表的东西来控制成员如何销毁,析构部分是隐式的。成员销毁时发生什么完全依赖于成员的类型。销毁类类型的成员需要执行成员自己的析构函数。...内置类型无析构函数,因此销毁内置类型成员什么也不做。 隐式销毁一个内置指针类型的成员不会delete它指向的对象。但是智能指针是类类型,所以具有析构函数,因此指向的对象在析构阶段会被销毁。...使用=default 我们可以通过将拷贝控制成员定义为=default来显式地要求编译器生成合成的版本。 6....当我们希望在vector重新分配内存这类情况下对我们自定义类型的对象进行移动而不是拷贝,就必须显式地告诉标准库我们的移动构造函数不会发生异常,可以安全使用。

    1.6K40

    C++相关基础知识总结笔记

    对于自定义类型,如果 ++ 操作符重载涉及复杂的逻辑或多个成员变量的修改,你需要显式地使用同步机制来确保线程安全。...Lambda 表达式允许你在代码中定义并使用一次性函数,而不必显式地定义一个函数。...如果基类没有默认构造函数,或者需要传递参数给基类构造函数,可以在派生类的构造函数初始化列表中显式调用基类的构造函数。 构造函数的规则 如果类中定义了任何构造函数,编译器就不会自动生成默认构造函数。...这意味着不能有多个具有不同参数列表的析构函数。 不能带参数:析构函数不能带有任何参数。 析构函数的类型 默认析构函数:如果类中没有显式定义析构函数,编译器会自动生成一个默认析构函数。...默认析构函数:如果类中没有显式定义析构函数,编译器会自动生成一个默认析构函数。如果类中有成员需要显式清理,则应显式定义析构函数。

    21330

    Effective Modern C++翻译(7)-条款6:当auto推导出意外的类型时,使用显式的类型初始化语义

    条款6:当auto推导出意外的类型时,使用显式的类型初始化语义 条款5解释了使用auto来声明变量比使用精确的类型声明多了了很多的技术优势,但有的时候,当你想要zag的时候,auto可能会推导出了zig...就像注释指出的那样,对processWidget的调用行为现在是未定义的了,但是为什么呢,答案可能会十分令人惊讶,在使用auto的代码中,highPriority的类型不再是bool,尽管std::vector...bool&都够使用的地方同样适用,在features中,std::vector::reference实现这个工作是通过一个到bool的隐式转换(不是bool&到bool,为了完整的解释std...,我把这个叫做显式的类型初始化语义(explicitly typed initializer idiom) 显式的类型初始化语义包括用auto声明一个变量,但是加上一个你想要auto推导出的初始化类型,...,而使用显式的类型初始化语义可以: auto ep = static_cast(calcEpsilon()); 如果你拥有一个float类型的表达式,但是你把它储存为一个整型的变量,也可以使用这个方法

    1.2K100

    《C++Primer》第十四章 重载运算与类型转换

    第十四章 重载运算与类型转换 基本概念 当一个重载符是成员函数时,this绑定到左侧运算对象,成员运算符的(显式)参数数量比运算对象的数量少一个 运算符函数必须要么是类的成员,要么最少含有一个类类型的参数...相等运算符 如果有一个类含有判断两个对象是否相等的操作,那么它应该把函数定义成operator==而非一个普通的命名函数,这样用户无须再费时费力去学习并记忆一个全新的函数名字 如果类定义了operator...下标运算符 表示容器的类可以通过元素在容器中的位置访问元素,这些类一般会定义下标运算符operator[]。 下标运算符必须是成员函数。...3.1 标准库function类型 我们可以使用一个名为function的新的标准库类型解决上述问题,function定义在functional头文件中,functionn定义的操作: function...int() const { return val; } // ...其他成员 } 和显式的构造函数一样,编译器通常也不会将一个显式的类型转换运算符用于隐式类型转换: SmallInt si =

    92910

    C++初阶

    空类中真的什么都没有吗?并不是,任何类在什么都不写时,编译器会自动生成以下6个默认成员函数。 默认成员函数:用户没有显式实现,编译器会生成的成员函数称为默认成员函数。...// 调用带参的构造函数 如果类中没有显式定义构造函数,则C++编译器会自动生成一个无参的默认构造函数,一旦 用户显式定义编译器将不再生成。...内置类型和自定义类型在析构中 关于编译器自动生成的析构函数,是否会完成一些事情呢?下面的程序我们会看到,编译器生成的默认析构函数,对自定类型成员调用它的析构函数。...”必须是非静态成员 内置类型和自定义类型在赋值运算符重载 用户没有显式实现时,编译器会生成一个默认赋值运算符重载,以值的方式逐字节拷贝。...将声明和定义放到一个文件 "xxx.hpp" 里面或者xxx.h其实也是可以的。推荐使用这种。 2. 模板定义的位置显式实例化。这种方法不实用,不推荐使用。 模板总结 优点 1.

    10210

    C++初阶大全

    空类中真的什么都没有吗?并不是,任何类在什么都不写时,编译器会自动生成以下6个默认成员函数。 默认成员函数:用户没有显式实现,编译器会生成的成员函数称为默认成员函数。...// 调用带参的构造函数 如果类中没有显式定义构造函数,则C++编译器会自动生成一个无参的默认构造函数,一旦 用户显式定义编译器将不再生成。...内置类型和自定义类型在析构中 关于编译器自动生成的析构函数,是否会完成一些事情呢?下面的程序我们会看到,编译器生成的默认析构函数,对自定类型成员调用它的析构函数。...”必须是非静态成员 内置类型和自定义类型在赋值运算符重载 用户没有显式实现时,编译器会生成一个默认赋值运算符重载,以值的方式逐字节拷贝。...将声明和定义放到一个文件 "xxx.hpp" 里面或者xxx.h其实也是可以的。推荐使用这种。 2. 模板定义的位置显式实例化。这种方法不实用,不推荐使用。 模板总结 优点 1.

    5810

    C++ lambda表达式

    使用lambda表达式时,编译器会产生未命名类的未命名对象,且有一个调用运算符成员函数,实际使用时会调用该调用运算符成员函数。...该未命名类不包含默认构造函数、赋值运算符、默认析构函数,而是否包含默认的拷贝、移动构造函数与捕获数据成员类型有关。...可使用隐式的值、引用传递,其捕获的数据可通过编译器在函数体的推导得出:auto Lambda = [=,&intVal](){cout 使用隐式传递则要求=、&要在捕获列表的首位置,同时之后的显式捕获不可为隐式捕获的传递方式。     ...注:如果是在类内使用并调用类内数据,则可以使用[=]、[&]、[this]方式隐式或显式捕获this并使用类内成员,如果是类静态成员可以直接使用而不用捕获。

    32840

    【笔记】《深入理解C++11》(上)

    regex, 库尽量以头文件实现, 但也有并行库这种必须深入编译器的库 用通用而非特殊的手段来实现特性: 显式类型转换 让特性对专家和新手都适用: 统一初始化表达式 增强类型安全: enum class...初始化列表的效果总是慢于就地初始化, 但也快过在构造函数中进行赋值 注意: 非常量的静态变量依然要在头文件外定义从而保证在程序中只存在一个 sizeof()可以对类成员表达式使用了 类模板也可以声明友元了...语法扩展 函数前面加上explict可以防止参数发生隐式类型转换, 用于构造函数和operator中 不要将explict与delete共用, 因为这相当于删去了显式转换版本的函数, 可能会留下默认的隐式转换的实现...没有继承关系) 类中的第一个非静态成员类型要与基类不同(为了类指针能直接指向第一个成员) 没有虚函数和虚基类 所有非静态成员都满足POD布局(递归定义) 之所以C++11引入POD的概念是为了保证我们可以安全地用...} 这个特性在C++20中被concept以更好的语法取代 4 新手易学, 老兵易用 auto auto是静态类型推导, 必须被初始化 auto本质上是一个类型占位符, 在编译的时候推导出类型然后以类似字面替换的方式进行使用

    2K20

    机器人CPP编程基础-02变量Variables

    C++有许多内置类型,包括整数、浮点数、字符、布尔等。此外,还可以使用自定义类型,如结构体、类等。 变量的声明:在C++中,必须在程序中使用变量之前声明它们。...变量的作用域:变量的作用域是指变量在程序中的可见性和生命周期。C++中有两种类型的作用域:局部和全局。局部作用域限制了变量的可见性和生命周期,只能在定义它的代码块中使用。...全局作用域使得变量在整个程序中都可见。 常量:常量是变量的特殊类型,表示一个不可变的值。在C++中,使用关键字const来声明常量。 变量的类型转换:在C++中,可以进行隐式类型转换和显式类型转换。...显式类型转换使用类型转换运算符(如static_cast、dynamic_cast等)来显式地将一个类型的值转换为另一个类型。...使用auto关键字可以简化变量的类型声明,特别是在使用复杂表达式或嵌套容器时。

    18930

    包装器 : function 与 bind 的原理及使用

    ++中,普通成员函数的调用与静态成员函数或普通的非成员函数不同,因为它隐含了一个 this 指针参数。...这个签名表示该成员函数属于特定的类,因此它并不完全等同于普通函数。每个普通成员函数的调用实际上是通过一个特定的对象调用的,而对象的地址(this 指针)在函数调用时必须传入。...在普通成员函数的调用中: this 指针作为隐式参数,指向调用函数的对象实例。...是非静态成员函数,需要显式传入一个 Plus 实例(对象)或该实例的指针作为 this。...函数作为容器的元素 在需要存储不同类型的可调用对象的容器中,使用 std::function 是一个最佳选择。

    20010
    领券