C++11特性-其他特性
创始人
2024-03-20 21:44:56
0

1.字符串的原始字面量

        表达式:R"xxx(原始字符串)xxx"或者R"(原始字符串)",xxx要写的话,必须一样

	//两种申明形式string a = "aaa";//没有转义的时候就是原始字面量string b = R"aaa(bbb)aaa";//申明为R"xxx()xxx"string c = R"(ccc)";//申明为R"()"string d = R"aaaa(ddd)aaaa";//申明为R"xxx()xxx"cout << a<

        意义:避免字符串中有转义字符时出现转义的问题,解决字符串过长(字符串写在多行中)而不想使用连接字符(\)的问题

    //避免转义string str = "hello\word\ttt";string strR = R"(hello\word\ttt)";cout << str << endl<< strR << endl;string  str2 = "hello\\word\\ttt";cout << str2 << endl;
    //解决字符串过长(字符串写在多行中)而不想使用连接字符(\)的问题string str = "dsfhk\dsfklhj\dsklfhjsd\\sdfkgjyhk\dsfg\dfsgf\dsrfgdrf";string strR = R"(dsfhkdsfklhjdsklfhjsdsdfkgjyhkdsfgdfsgfdsrfgdrf)";cout << str << endl << strR << endl;

2.指针空值类型-nullptr

        在C程序中,NULL表示(void*)0;在C++程序中,NULL表示0

void func(int a) {cout << "func(int a)" << endl;
}void func(char* a) {cout << "func(char* a)" << endl;
}//调用
func(10);
func(NULL);
func(nullptr);

          C++中void*不能隐式转换成其他类型的指针

    void* a = NULL;//NULL为0或者void *int* b = NULL;//NULL为0或者void *double* c = NULL;//NULL为0或者void *char* d = NULL;//NULL为0或者void *

         nullptr不能匹配类型;可以隐式的匹配指针类型,不能匹配类型。

	void* ptr = nullptr;//nullptr隐式转成void*int* test2 = nullptr;//nullptr隐式转成int*double* test3 = nullptr;//nullptr隐式转成double*char* test4 = nullptr;//nullptr隐式转成char*

3.常量-constexpr

        c11之前的const有两个意思,修饰常量与变量只读

        constexpr修饰常量表达式

        常量变达式:多个常量(值不变)组成,且在编译过程中得到计算结果的表达式,达到提高程序执行效率的结果

        定义常量const与constexpr是等价的,们都在编译过程得到结果

    //定义常量时,const与constexpr是等价的const int c = 33;//常量达表式const int d = c + 1;//常量达表式constexpr int h = 45;//常量达表式constexpr int k = h + 3453;//常量达表式

        对于C++内置数据类型可以使用constexpr修饰,使用class与struct自定义的数据类型不能使用constexpr修饰

        常量表达式函数:constexpr修饰函数返回值的函数(普通函数、类成员\构造函数、模板函数)

        常量表达式函数要求:

                1.函数必须有返回值且返回值必须是常量表达式

                2.函数使用前必须有对应的定义语句

                3.整个函数体,不能出现常量表达式之外的语句(return除外)不能出现如using、typedef、static_assert断言、循环等

//常量表达式函数
constexpr int funConstexpr3() {constexpr int a = 9;//a为常量return a;
}//constexpr修饰模板函数,会根据传入参数类型确定是否为常量表达式函数
template 
constexpr TT display(TT t) {return t;
}//constexpr修饰构造函数,函数体必须为空.初始化必须为成员初始化列表
class MyClass3
{
public:constexpr MyClass3():h(67) {}int h;
};

        在C++中建议把const与constexpr区分(即表示“只读”使用const,"常量"使用constexpr)

4.final

        final可以修饰函数与类,放在函数或者累后面。

        final修饰函数时,只能修饰虚函数(阻止子类重写父类的这个函数)

        final修饰类时,防止类被继承(派生子类)

        virtual不能与final同时出现

5.override

        保证派生类中申明的重写函数与基类中的虚函数有相同的函数名,同时明确会重写基类的虚函数,保证重写虚函数的正确性。

6.模板的优化        

        1.模板的右尖括号>>

                C11模板的多个右尖括号需要一个空格符fun >,之前连在一起是右移操作符

                C11特性优化了这个fun>

        2.模板的默认参数

                函数模板能添加模板参数         template

         模板参数的优先级(从高到低):

                1.显示指定参数类型

                2.使用推导的参数类型

                3.默认的模板参数类型

                4.没有默认也不能推导除参数类型,则会报错

7.using与typedef

        using与typedef定义类型的别名,不会创建新的类型

        定义基础类型一样

typedef int int111;//typedef 旧的类型名 新的类型名(别名)
using int222 = int;//using 新的类型名(别名)= 旧的类型名 

        定义函数指针时,using更直观

typedef int(*funcc)(int, string);
using funccc = int(*)(int, string);//可读性

        定义模板时,using能直接使用,typedef需要在定义外套一个类或者结构体

template 
//typedef ds  Ds;
//使用typedef时,需要使用class或者struct外包一层
struct MyStruct1
{typedef map  Ds;
};template 
using Um = map;

8.基于范围的for循环

        基于范围的for循环只访问一次后面的对象,多次遍历

        使用迭代器模式的for循环多次判断边界,可以动态操作便利的对象

//vt:表达式、数组、容器、初始化列表//&可以提高效率,修改原容器的值
for (auto& it : vt) {cout << it++ << " ";
}
//只读
for (const auto& it : vt) {cout << it << " ";
}

相关内容

热门资讯

不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
报告实验.pdfbase.tt... 这个错误通常是由于找不到字体文件或者文件路径不正确导致的。以下是一些解决方法:确认字体文件是否存在:...
APK正在安装,但应用程序列表... 这个问题可能是由于以下原因导致的:应用程序安装的APK文件可能存在问题。设备上已经存在同名的应用程序...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...