C++11新标准 特性 整理

Part1 :C++ 11 using

使用 using 代替 typedef 定义别名

1.typedef 定义别名

typedef经常使用的场景包括以下几种:

  1. 指定一个简单的别名,避免了书写过长的类型名称
  2. 实现一种定长的类型,在跨平台编程的时候尤其重要
  3. 使用一种方便阅读的单词来作为别名,方便阅读代码

1.1  结构体

typedef struct {
    char* name;
    int age;
    } Person;

Person xiaoming,xiaozhang;

 1.2 指针

typedef  long long LongLong;

1.3 定义数组

typedef int arrType[6]; 

1.4  定义函数指针

typedef int (*addFunc)(int, int);

定义了一个  的函数指针,这个函数返回值是int类型,包含两个参数(int,int)

在typdef可以定义更加复杂的类型,这种情况遇到的不是很多,有时候多层的嵌套会将代码演变的异常复杂,可读性变差;

2.  使用using定义别名

using 别名 = xxx(类型);

可以看出,using声明别名的顺序和typedef是正好相反:typedef首先是类型,接着是别名,而using使用别名作为左侧的参数,之后才是右侧的类型,例如上面的类型定义:

    typedef int INT;
    using INT= int;  

在定义诸如函数指针等类型时,使用using的方式更加自然和易读:

typedef void (*FP) (int, const std::string&);
using FP = void (*) (int, const std::string&); //等价的using别名

另外using可以在模板别名中使用,但是typedef不可以:

在C++11中,请使用using,而非typedef

PART2: 新标准之二:初始化列表

C++11引入了一个新的初始化方式,称为初始化列表(List Initialize)如下:

int a = {1};
int a{3};

初始化列表在使用的时候有如下一些要求:

1. 当初始化内置基本类型的时候,列表初始化不允许出现隐式类型的转换,例如:

long double ld = 3.1415926536;
int a{ld}, b = {ld}; //出错,不允许出现精度的丢失
int c(ld), d = ld; // 非列表初始化,但是会出现精度的丢失

2. 初始化列表可以用于初始化结构体类型,例如

#include <iostream>
 
struct Person
{
  std::string name;
  int age;
};
 
int main()
{
	Person p = {"Frank", 25};
	std::cout << p.name << " : " << p.age << std::endl;
}

3. 其他一些不方便初始化的地方使用,比如std<vector>的初始化,如果不使用这种方式,只能用构造函数来初始化,难以达到效果

	std::vector<int> ivec1(3, 5);
	std::vector<int> ivec2 = {5, 5, 5};
	std::vector<int> ivec3 = {1,2,3,4,5}; //不使用列表初始化用构造函数难以实现

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
C++11引入了许多特性,其中包括线程池的实现。在引用中的代码中,ZERO_ThreadPool类封装了线程池的功能。线程池的原理是通过维护一个线程队列和一个任务队列来实现的。 在初始化阶段,通过调用init函数来初始化线程池。该函数会创建指定数量的线程,并将其保存在threads_队列中。如果线程池已经被初始化过,则直接返回false。 在启动线程池后,调用start函数。该函数会循环创建指定数量的线程,并将它们放入threads_队列中。每个线程都会调用run函数来执行任务。 当调用exec函数时,会将任务添加到tasks_队列中。其中,std::bind用于绑定一个成员函数和其参数,以及占位符std::placeholders::_1表示传入的参数。 在waitForAllDone函数中,会判断atomic_是否为0且tasks_是否为空。如果是,则表示所有任务已经执行完毕,线程池可以退出。 线程池的stop函数用于停止线程池的运行。它会遍历threads_队列,并调用每个线程的join函数,等待线程执行完毕后再返回。 以上就是C++11特性线程池的基本原理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [基于C++11特性手写线程池实现](https://blog.csdn.net/m0_70418130/article/details/126805390)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

恋恋西风

up up up

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值