C++11奇怪的语法
1. istream_iterator
简而言之,istream_iterator像操作容器一样操作istream。例如下面代码,从std::cin构造std::istream_iteream<int>类型迭代器,可以用于从cin顺序读取int数值。该迭代器又被用于初始化int型vector。
#include <iostream>
#include <iterator>
#include <vector>
#include <algorithm>
int main()
{
std::istream_iterator<int> in_iter(std::cin);
std::istream_iterator<int> eof; std::vector<int> vec(in_iter, eof); for_each(vec.cbegin(),
vec.cend(),
[] (const int i) {
std::cout << i << std::endl;
}); return ;
}
编译并运行这个例子:
$ g++ --std=c++ -Wall -o test test.cpp
$ ./test ^D
2. 元素个数为0的数组
// mingw32 G++4.9.2 with --std=c++11
#include <iostream>
int main()
{
int q[]; // std::cout << q[0] << std::endl;
for (auto b: q) {
std::cout << b << std::endl;
}
return ;
}
在C++11中,不能通过std::begin(q), std::end(q)获得元素为0数组的iterator:
#include <iostream> int main()
{
int p[]; auto b = std::begin(p); // error
return ;
}
3. new[0]
C++的new语法用来在运行时动态申请内存,
char *p = new char;
而new[]语法则用来动态申请一片连续的内存区域:
int n = ;
char *pa = new char[n];
上例中,当n等于0时,会发生什么呢?
#include <iostream>
int main()
{
int n = ;
int *p = new int[n]; // std::cout << *p << std::endl; // undefined for (int *q = p; q != p + n; ++q) {
std::cout << q << std::endl;
}
return ;
}
上例是完全可以执行的,也就是p = new [0]返回了一个合法的指针,该指针可以向其他指针一样做比较,但却不可以解引用,如上例中注释掉那一行,毕竟数组是空的。
4. 没有返回类型的Conversion Operator
Converion Operator是一种特殊的类成员函数,其语法如下:
operator type() {}
其中type是转换的目标类型。
虽然没有返回类型,函数体中又必须返回type类型value:
#include <iostream>
class SmallInt {
public:
SmallInt(int i) : _i(i){}
operator int() {return _i;} // Convertion Operator
private:
int _i;
};
int main()
{
SmallInt si();
int ret = si + ;
std::cout << ret << std::endl;
return ;
}
5. Reference Collapsing Rule
通过typedef等语法创建引用的引用,适用引用折叠原则:
T & & =>T&
T&& & => T&
T& && => T&
T&& && => T&&
也就是,除去右值引用的右值引用一种情况,全部折叠成普通引用;而右值引用的右值引用则折叠成右值引用
C++11奇怪的语法的更多相关文章
- [转]Markdown 11种基本语法
Markdown 11种基本语法 现在是我在学习Markdown时做的笔记.学完这些Markdown的基本使用已经不成问题. 1. 标题设置(让字体变大,和word的标题意思一样) 在Markdown ...
- Markdown 11 种基础语法
现在是我在学习Markdown时做的笔记.学完这些Markdown的基本使用已经不成问题. 1. 标题设置(让字体变大,和word的标题意思一样)在Markdown当中设置标题,有两种方式: 第一种: ...
- Markdown 11种基本语法
markdown真的很方便! 我根据自己在github上维护的项目编写的readme文件总结一些最基本的使用方法 ,学完这些Markdown的基本使用已经不成问题. 1. 标题设置(让字体变大,和wo ...
- -1-1 java 基础语法 java关键字 java 注释 常量 语句 运算符 函数 数组定义
Java语言基础组成 关键字 标识符 注释 常量和变量 运算符 语句 函数 数组 关键字 定义:被Java语言赋予了特殊含义的单词 特点:关键字中所有字母都为小写 用于定义数据类型的关键字 class ...
- Markdown 11种基本语法【转】
[转自:http://www.cnblogs.com/hnrainll/p/3514637.html] 1. 标题设置(让字体变大,和word的标题意思一样)在Markdown当中设置标题,有两种方式 ...
- 11 - Vue模板语法
Vue.js 使用了基于 HTML 的模板语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据. 所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML ...
- systemverilog中奇怪的语法
1.->运算符 expression_a->expression_b其实等效于(!expression_a || expression_b),systemverilog中利用 || 运算的 ...
- C++11模板友元语法
第 1 类: 普通类A的 普通类B 友元(一对一友好关系): 无需前置声明class B,当class B第一次出现在friend声明中时,该名字被隐式地认为可见. class A { friend ...
- 【作业】 iterator,set_union 一些奇怪的语法
关于set_union系列函数(需要有序)的第五个参数,output iterator. 网上都是用inserter(c,c.begin()) 但vs会编译报错 所以改成了back_inserter, ...
随机推荐
- python 判断列表字符串元素首尾字符是否相同
def match_words(words): ctr = for word in words: and word[] == word[-]: ctr += return ctr print(matc ...
- 【hive】数据仓库层次设计
转载 https://www.jianshu.com/p/849db358ec61
- ENUMSTXT.H中的指针数组
/************************************************************************ ...
- 用Ant手动打包android程序,android分包机制解决65536方法过多异常
Android利用ant手动打包 首先我们要给自己的IDE eclispe配置ant,默认的eclipse是集成了ant构建工具的,但是google提供的Android集成开发工具ADT,里面封装了E ...
- 是用TOP关键字对COUNT性能优化
在对大数据量进行检索或者分页的时候需要计算命中记录数大小,一般情况下我们可以直接COUNT得到结果,但是当结果集很大的时候(比如1万以上)具体结果值已经不重要了.没有人真的翻阅1万条记录,比如百度,你 ...
- web 开发 css 默认值列表
css默认值列表 HTML标签CSS属性默认值汇总 这个东西,在你需要还原默认值的时候,比较有用. 开始的时候 *{margin:0;padding:0;},当需要使用边距的时候,就需要还原HTML默 ...
- nginx配置文件的性能优化
1.nginx进程数,建议按照cpu数目来指定,一般跟cpu核数相同或为它的倍数.worker_processes 8; 2.为每个进程分配cpu,上例中将8个进程分配到8个cpu,当然可以写多个,或 ...
- swift 分页视图
var data:NSArray! var scrollView: UIScrollView! var pageCtrl: UIPageControl! override func viewDidLo ...
- windows下 两个版本的JDK环境变量进行切换 MARK
我们平时在window上做开发的时候,可能需要同时开发两个甚至多个项目,有时不同的项目对JDK的版本要求有区别,为了简化操作,我们可以通过批处理文件来完成环境变量切换的任务.使用方法:阅读代码我们就会 ...
- BZOJ3211: 花神游历各国(线段树)
3211: 花神游历各国 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 5692 Solved: 2114[Submit][Status][Discu ...