C++11模板的别名】的更多相关文章

c++11 模板的别名 #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <string> #include <vector> #include <map> using uint = unsigned int; typedef unsigned int UINT; using sint = int; void mytest() { //std::is_same 判断类型是否一致 //这个…
[C++模板的别名] 参考:http://zh.wikipedia.org/wiki/C++0x#.E6.A8.A1.E6.9D.BF.E7.9A.84.E5.88.A5.E5.90.8D…
c++11改进了编译器的解析规则,尽可能的将多个右尖括号(>)解析为模板参数结束符,方便编写模板相关的代码. 1. 模板的右尖括号 之前的c++标准中,模板套模板中右尖括号不能连在一块,否则会和右移操作符混淆,如 vector< map< int, int> > //右边的两个>要分开. 而在c++11中,这种限制取消了,编译器能够判断出">>"是右移操作符还是模板参数的结束标记. 2. 模板的别名 之前的c++使用 typedef 来为…
1.推荐使用std::shared_ptr<TaskT>代替指针TaskT*使用,shared_ptr是一种智能指针,能自主销毁释放内存,在c++11中被引入,在多线程编程中有很大的用处,它可以统计有多少指针指向同一个对象.该类被包含在<memory>中. 2.在模板类中要使用某一容器的iterator类型,需要在该iterator类型前加上typename,才能进行编译,原因不明. 3.容器中的iterator类型只要不被删除,iterator所指向的内容是恒定的,利用这一点可以…
创建模板(模板名和索引名一样都不能有大写) PUT http://222.108.x.x:9200/_template/templateds { "template": "dsideal*", "order": 0, "settings": { "number_of_shards": 5 }, "aliases": { "dsideal-query": {} #起个别…
第 1 类: 普通类A的 普通类B 友元(一对一友好关系): 无需前置声明class B,当class B第一次出现在friend声明中时,该名字被隐式地认为可见. class A { friend class B; public: void f() { cout << "class A"; } private: int a; }; class B { public: void f() { cout << "class B"; } void…
C++11 1.long long新类型 2.列表初始化 int t=0; int t={0}; int t(0); int t{0}; 注意:如果我们使用列表初始化有丢失信息的风险,则编译器报错 long double ld=3.1415926536; int a{ld},b={ld};//错误 int c(ld),d=ld;//正确,会丢失数据 3.空指针nullptr int *p1=nullptr; int *p2=0; int *p3=NULL;//尽量避免 4.constexpr类型…
最近阅读google chromium base container stack_container代码,深刻感觉到基础知识不扎实. // Casts the buffer in its right type.T* stack_buffer() { return stack_buffer_.template data_as<T>(); }const T* stack_buffer() const {  return stack_buffer_.template data_as<T>…
C++ Primer中文版(第5版)(顶级畅销书重磅升级全面采用最新 C++ 11标准) [美]Stanley B. Lippman( 斯坦利李普曼)  Josee Lajoie(约瑟拉乔伊 )  Barbara E. Moo (芭芭拉默)  著 王刚  杨巨峰译 ISBN 978-7-121-15535-2 2013年9月出版 定价:128.00元 864页 16开 编辑推荐 C++领域权威 潘爱民|孟岩作序,代表技术圈鼎力推荐 一线C++工程师腾讯Milo.微软刘未鹏|陈梓瀚.阿里李云|侯凤…
__func__宏 __func__返回当前的函数名,也可以返回class和struct名. /*返回函数名hello*/ const char* hello() { return __func__; } /*返回结构体名foo*/ struct foo { foo():name(__func){} const char* name; } __VA_ARGS__宏 可变参数宏 #define INFO(...) printf(__VA_ARGS) noexcept noexcept操作会阻止异常…