auto
C++11标准引入的auto类型说明符,能让编译器通过初始值来推算变量的类型,显然,auto定义的变量必须有初始值。如:
auto i=47,*p=&i;//i是int变量,p是指向int的指针
需要注意的是,auto一般会忽略掉顶层const,而底层const则会保留。
(顶层const表示指针本身是个常量,底层const表示指针所指对象是个常量)
const int ci=47,&cr=ci;//ci是const限定的int变量,cr是ci的引用,ci与cr都是顶层const
auto a=ci;//此时a是int类型,ci的顶层const特性被忽略掉了。
//此时试图改变ci和a的值
ci=0;//错误,ci是整型常量
a=0;//正确,a是int类型
auto b=cr;//cr是ci的别名,同样是顶层const,同样会被忽略,此时的b为int类型。
cr=0;//错误
b=0;//正确
auto c=&ci;//c是指向整型常量的指针(对常量对象取地址是一种底层const)
decltype
decltype的作用是选择并返回操作数的数据类型,在此过程中,编译器分析表达式并得到它的类型,但并没有实际计算表达式的值。其格式为:
decltype(expression/variable) variable;
若括号内是个变量,就直接返回该变量的类型即可;若括号内是表达式,则返回表达式结果对应的类型。
注意,括号内诸如(*ptr)、(&r)是表达式,(ptr)®才是变量名。
int i=47,*p=&i,&r=i;
decltype(i) a;//a为int类型
decltype(r+5) b;//r+5,即47+5,结果是int类型,故b也是int类型
decltype(*p) c;//错误,c必须初始化
如果表达式是内容是解引用操作,则decltype将得到引用类型。
如上面代码块内的变量c,其类型为int&,而非int
还有一点需要注意,若括号内的变量多了一层括号,其结果永远是引用。如:
decltype((i)) d;//d的类型为int&
用途
对于一些未知其类型的对象,如string和vector的size_type,或者一些类型名称很长的,如迭代器vector::const_iterator,就可以使用auto或decltype来获取、替代。
使用迭代器遍历:
//假设存在一个vector容器v
for(auto it=v.begin();it!=v.end();it++)
cout << *it << endl;
获取size_type的类型:
对于所有存放string类的size函数返回值的变量,都应该是string::size_type类型的
string s("hello world");
decltype(s.size()) num;
使用范围for将字符串的字母转换为大写:
string s("hello world!");
for(auto &c:s)//注意c之前要加引用。相当于是auto &c=s[i]
c=toupper(c);//cctype头文件中的函数,若c为小写字母,输出其大写形式。这里将c转大写后再重新赋值给c
cout << s << endl;