上一篇:《深入理解C++11》笔记–简介
本篇介绍第二章的前面一部分内容。
就像上一篇文章说到,第一个C++标准是C++98,也就是在1998年推出,而2003年只是对一些缺陷进行了修复。而上一个最新的C标准C99是在1999年推出,因此C++11之前是不支持C99标准的,在C++11中加入了对C99的支持,包括以下内容:
- C99的预定义宏
- 预定义标识符号
__func__ - _Pragma操作符
- 不定参数宏定义以及
__VA_ARGS__ - 宽窄字符串连接
C99的预定义宏

int main()
{
std::cout << __STDC_HOSTED__ << std::endl; // 1
std::cout << __STDC__ << std::endl; // 1
std::cout << __STDC_VERSION_ << std::endl; // 未定义
std::cout << __STDC_ISO_10646__ << std::endl; // 未定义
return 0;
}
这些宏在不同的编译器或软件中支持的不同,用XCode测试后面两个宏未定义,用VS2015只定义了第一个。
预定义标识符号__func__
__func__的作用就是返回所在函数的名称,在C++11中也支持输出类的成员函数名称。
void test_function()
{
std::cout << __func__ << std::endl;
}
class Test{
public:
Test() { std::cout << __func__ << std::endl; }
void fun() { std::cout << __func__ << std::endl; }
};
int main()
{
test_function(); // test_function
Test test; // Test
test.fun(); // fun
return 0;
}
_Pragma操作符
_Pragma有点类似#pragma。后者是一条预处理指令,它的作用是设定编译器的状态或者是指示编译器完成一些特定的动作,不同的编译器可能会有不同的处理。常用的有#pragma once以及#pragma comment等。
_Pragma要实现#pragma once的效果,只需要使用_Pragma("once");。和#pragma不同,_Pragma是一个操作符比起#pragma更加灵活,也更加统一。
不定参数宏定义以及__VA_ARGS__
__VA_ARGS__能够指代宏定义参数中的最后一个参数...,来看代码:
#define MYPRINT(...) printf(__VA_ARGS__)
int main()
{
MYPRINT("test : %d", 1); // test : 1
return 0;
}
宽窄字符串连接
在之前的C++标准中,将窄字符串(char)转换成宽字符串(wchar_t)是未定义的行为。而在C++11标准中,在将窄字符串和宽字符串进行连接时,支持C++11标准的编译器会将窄字符串转换成宽字符串,然后再与宽字符串进行连接。
以上为原文内容,由于没有举例说明,我不是很明白这里所说的自动转换成宽字节是什么意思,有待后续研究。
下一篇:《深入理解C++11》笔记–扩展

本文详细介绍了C++11标准中引入的新特性,包括对C99标准的支持、预定义宏、预定义标识符号__func__、_Pragma操作符、不定参数宏定义以及宽窄字符串连接等功能。

1444

被折叠的 条评论
为什么被折叠?



