c++builder XE7 C++11 C++0x 新语法
Non-static data member initializers
非静态成员变量初始化变得简单,这个XE7 64位编译成功,32位还是不支持
As a simple example,
struct TPerson
 {
  String aname = "张三";
 };
    class A {
    public:
        int a = 7;
        String aName = "MyName";
    };
would be equivalent to
    class A {
    public:
        A() : a(7) {}
    };
http://www.open-std.org/JTC1/SC22/WG21/docs/papers/2008/n2756.htm
http://docwiki.embarcadero.com/RADStudio/XE7/en/Main_Page
C++11 Features Supported by RAD Studio Clang-based C++ Compilers
http://docwiki.embarcadero.com/RADStudio/XE7/en/C%2B%2B11_Features_Supported_by_RAD_Studio_Clang-based_C%2B%2B_Compilers
XE764对11支持的全面,32很少。
http://docwiki.embarcadero.com/RADStudio/XE7/en/C%2B%2B11_Language_Features_Compliance_Status
11新特性
http://clang.llvm.org/cxx_status.html
http://cpprocks.com/9-reasons-to-start-using-c11/
Multi-declarator auto
The C++11 standard includes the multi-variable form of auto declarations, such as:
int* func(){}
 
int _tmain(int argc, _TCHAR* argv[])
{
        auto x = 3, * y = func(), z = 4;
        return 0;
}
32位支持这样初始化
class TNoteJSON
{
public:
struct TNames
{
static String Title;
static String Content;
static String Id;
}
} String TNoteJSON::TNames::Title = "title";
String TNoteJSON::TNames::Content = "content";
String TNoteJSON::TNames::Id = "id"; Caption = TNoteJSON::TNames::Title;
TNoteJSON tc;
Caption = tc.at.Title;
Caption = tc.at.Content; C++0x Features Index
http://docwiki.embarcadero.com/RADStudio/XE7/en/C%2B%2B0x_Features_Index
Topics
alignof Operator (C++0x)
- C++0x Attributes
 - Explicit Conversion Operators (C++0x)
 - extern Templates (C++0x)
 - Forward Declaration of Enums (C++0x)
 - rvalue References (C++0x)
 - Static Assertions (C++0x)
 - Strongly Typed Enums (C++0x)
 - Type Specifier decltype (C++0x)
 - Type Trait Functions (C++0x)
 - Unicode Character Types and Literals (C++0x)
 - Workaround for C++0x Attributes (Clang-based C++ Compilers)
 
其中__is_member_function_pointer、__is_enum、__is_base_of很有用
http://docwiki.embarcadero.com/RADStudio/XE7/en/Strongly_Typed_Enums_(C%2B%2B0x)
http://docwiki.embarcadero.com/RADStudio/XE7/en/Type_Trait_Functions_(C%2B%2B0x)_Index
std::vector<int> numbers;
for(auto i : numbers)
   ListBox2->Items->Add(i);
http://towriting.com/blog/2013/08/01/what-is-cpp11/
http://developer.51cto.com/art/201312/422379.htm
http://www.cnblogs.com/hujian/archive/2012/12/10/2810813.html
http://cpprocks.com/c11-compiler-support-shootout-visual-studio-gcc-clang-intel/
什么是C++11
C++11是曾经被叫做C++0x,是对目前C++语言的扩展和修正,C++11不仅包含核心语言的新机能,而且扩展了C++的标准程序库(STL),并入了大部分的C++ Technical Report 1(TR1)程序库(数学的特殊函数除外)。
C++11包括大量的新特性:包括lambda表达式,类型推导关键字auto、decltype,和模板的大量改进。
本文将对C++11的以上新特性进行简单的讲解,以便大家能够快速了解到C++11对C++的易用性方面祈祷的巨大作用。
新的关键字
auto
C++11中引入auto第一种作用是为了自动类型推导
auto的自动类型推导,用于从初始化表达式中推断出变量的数据类型。通过auto的自动类型推导,可以大大简化我们的编程工作
auto实际上实在编译时对变量进行了类型推导,所以不会对程序的运行效率造成不良影响
另外,似乎auto并不会影响编译速度,因为编译时本来也要右侧推导然后判断与左侧是否匹配。
- auto a; // 错误,auto是通过初始化表达式进行类型推导,如果没有初始化表达式,就无法确定a的类型
 - auto i = 1;
 - auto d = 1.0;
 - auto str = "Hello World";
 - auto ch = 'A';
 - auto func = less<int>();
 - vector<int> iv;
 - auto ite = iv.begin();
 - auto p = new foo() // 对自定义类型进行类型推导
 
auto不光有以上的应用,它在模板中也是大显身手,比如下例这个加工产品的例子中,如果不使用auto就必须声明Product这一模板参数:
- template <typename Product, typename Creator>
 - void processProduct(const Creator& creator) {
 - Product* val = creator.makeObject();
 - // do somthing with val
 - }
 - .
 
如果使用auto,则可以这样写:
- template <typename Creator>
 - void processProduct(const Creator& creator) {
 - auto val = creator.makeObject();
 - // do somthing with val
 - }
 
抛弃了麻烦的模板参数,整个代码变得更加正解了。
智能指针
std::auto_ptr<TStringList>sl(new TStringList());
decltype
decltype实际上有点像auto的反函数,auto可以让你声明一个变量,而decltype则可以从一个变量或表达式中得到类型,有实例如下:
- int x = 3;
 - decltype(x) y = x;
 
有人会问,decltype的实用之处在哪里呢,我们接着上边的例子继续说下去,如果上文中的加工产品的例子中我们想把产品作为返回值该怎么办呢?我们可以这样写:
- template <typename Creator>
 - auto processProduct(const Creator& creator) -> decltype(creator.makeObject()) {
 - auto val = creator.makeObject();
 - // do somthing with val
 - }
 
nullptr
nullptr是为了解决原来C++中NULL的二义性问题而引进的一种新的类型,因为NULL实际上代表的是0,
- void F(int a){
 - cout<<a<<endl;
 - }
 - void F(int *p){
 - assert(p != NULL);
 - cout<< p <<endl;
 - }
 - int main(){
 - int *p = nullptr;
 - int *q = NULL;
 - bool equal = ( p == q ); // equal的值为true,说明p和q都是空指针
 - int a = nullptr; // 编译失败,nullptr不能转型为int
 - F(0); // 在C++98中编译失败,有二义性;在C++11中调用F(int)
 - F(nullptr);
 - return 0;
 - }
 
序列for循环
在C++中for循环可以使用类似java的简化的for循环,可以用于遍历数组,容器,string以及由begin和end函数定义的序列(即有Iterator),示例代码如下:
- map<string, int> m{{"a", 1}, {"b", 2}, {"c", 3}};
 - for (auto p : m){
 - cout<<p.first<<" : "<<p.second<<endl;
 - }
 
Lambda表达式
lambda表达式类似Javascript中的闭包,它可以用于创建并定义匿名的函数对象,以简化编程工作。Lambda的语法如下:
[函数对象参数](操作符重载函数参数)->返回值类型{函数体}
- vector<int> iv{5, 4, 3, 2, 1};
 - int a = 2, b = 1;
 - for_each(iv.begin(), iv.end(), [b](int &x){cout<<(x + b)<<endl;}); // (1)
 - for_each(iv.begin(), iv.end(), [=](int &x){x *= (a + b);}); // (2)
 - for_each(iv.begin(), iv.end(), [=](int &x)->int{return x * (a + b);});// (3)
 
- []内的参数指的是Lambda表达式可以取得的全局变量。(1)函数中的b就是指函数可以得到在Lambda表达式外的全局变量,如果在[]中传入=的话,即是可以取得所有的外部变量,如(2)和(3)Lambda表达式
 - ()内的参数是每次调用函数时传入的参数。
 - ->后加上的是Lambda表达式返回值的类型,如(3)中返回了一个int类型的变量
 
变长参数的模板
我们在C++中都用过pair,pair可以使用make_pair构造,构造一个包含两种不同类型的数据的容器。比如,如下代码:
- auto p = make_pair(1, "C++ 11");
 
由于在C++11中引入了变长参数模板,所以发明了新的数据类型:tuple,tuple是一个N元组,可以传入1个, 2个甚至多个不同类型的数据
- auto t1 = make_tuple(1, 2.0, "C++ 11");
 - auto t2 = make_tuple(1, 2.0, "C++ 11", {1, 0, 2});
 
这样就避免了从前的pair中嵌套pair的丑陋做法,使得代码更加整洁
另一个经常见到的例子是Print函数,在C语言中printf可以传入多个参数,在C++11中,我们可以用变长参数模板实现更简洁的Print
- template<typename head, typename... tail>
 - void Print(Head head, typename... tail) {
 - cout<< head <<endl;
 - Print(tail...);
 - }
 
Print中可以传入多个不同种类的参数,如下:
- Print(1, 1.0, "C++11");
 
更加优雅的初始化方法
在引入C++11之前,只有数组能使用初始化列表,其他容器想要使用初始化列表,只能用以下方法:
- int arr[3] = {1, 2, 3}
 - vector<int> v(arr, arr + 3);
 
在C++11中,我们可以使用以下语法来进行替换:
- int arr[3]{1, 2, 3};
 - vector<int> iv{1, 2, 3};
 - map<int, string>{{1, "a"}, {2, "b"}};
 - string str{"Hello World"};
 
然后呢…
如果你想了解更多C++11令人兴奋的新特性,我会向你推荐这两个博客:
原文链接:http://my.oschina.net/wangxuanyihaha/blog/183151
http://docwiki.embarcadero.com/RADStudio/XE7/en/Unicode_Character_Types_and_Literals_%28C%2B%2B0x%29
Character Types char16_t and char32_t
Character Literals u'character' and U'character'
String Literals u"UTF-16_string" and U"UTF-32_string"
u"UTF-16_string"is a string literal containing characters of the char16_t type, for exampleu"string_containing_UTF-16_encoding_characters".
U"UTF-32_string"is a string literal containing characters of the char32_t type, for exampleU"string_containing_UTF-32_encoding_characters".Range-based for example
char array[] = {'c', '+', '+', '1', '1'};
(static_cast<int>(_width/2)+1)DynamicArray<int> aint;
aint.set_length(10);
aint.Low;
aint.High;
aint[0];
DynamicArray<TBytes> blist; //二维数组
byte a[10][8];//二维数组
Note: The StaticArray class is designed for Delphi functions that return static arrays.
StaticArray<int, 5>a; a[0] = 100; include\windows\rtl\sysdyn.h
#if defined(GENERIC_ARRAY_NAMES)
typedef DynamicArray<int> ArrayOfint;
typedef DynamicArray<AnsiString> ArrayOfstring;
typedef DynamicArray<WideString> ArrayOfwidestring;
typedef DynamicArray<Byte> ArrayOfbyte;
typedef DynamicArray<short> ArrayOfshort;
typedef DynamicArray<long> ArrayOflong;
typedef DynamicArray<bool> ArrayOfboolean;
typedef DynamicArray<double> ArrayOfdouble;
#endif typedef DynamicArray<Integer> TIntegerDynArray;
typedef DynamicArray<Cardinal> TCardinalDynArray;
typedef DynamicArray<Word> TWordDynArray;
typedef DynamicArray<Smallint> TSmallIntDynArray;
typedef DynamicArray<Byte> TByteDynArray;
typedef DynamicArray<Int8> TInt8DynArray;
typedef DynamicArray<Int8> TShortIntDynArray _DEPRECATED_ATTRIBUTE0;
typedef DynamicArray<__int64> TInt64DynArray;
// NOTE: The following is not quite correct given that
// LongWord is defined as 'unsigned long' in SYSMAC.H
// However, 'DynamicArray<unsigned>' is what the Pascal
// compiler is emitting in .HPPs for TLongWordDynArray
// Please update this if the .HPPs change.
typedef DynamicArray<unsigned> TLongWordDynArray;
typedef DynamicArray<Single> TSingleDynArray;
typedef DynamicArray<Double> TDoubleDynArray;
typedef DynamicArray<Boolean> TBooleanDynArray;
typedef DynamicArray<String> TStringDynArray;
typedef DynamicArray<WideString> TWideStringDynArray;
include\windows\rtl\System.SysUtils.hpp
typedef System::DynamicArray<System::Byte> TBytes;
typedef System::DynamicArray<System::WideChar> TCharArray;
InheritsFrom 继承关系
this->ActiveControl->InheritsFrom(__classid(TCustomEdit))
c++builder XE7 C++11 C++0x 新语法的更多相关文章
- 一起学习c++11——c++11中的新语法
		
c++11新语法1: auto关键字 c++11 添加的最有用的一个特性应该就是auto关键字. 不知道大家有没有写过这样的代码: std::map<std::string, std::vect ...
 - 微信小程序0.11.122100版本新功能解析
		
微信小程序0.11.122100版本新功能解析 新版本就不再吐槽了,整的自己跟个愤青似的.人老了,喷不动了,把机会留给年轻人吧.下午随着新版本开放,微信居然破天荒的开放了开发者论坛.我很是担心官方 ...
 - Mysql8.0.11简介,新特性
		
MySQL 8.0 正式版 8.0.11 已发布,官方表示 MySQL 8 要比 MySQL 5.7 快 2 倍,还带来了大量的改进和更快的性能! 注意:从 MySQL 5.7 升级到 MySQL 8 ...
 - (数据科学学习手札139)geopandas 0.11版本重要新特性一览
		
本文示例代码已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 大家好我是费老师,就在几天前,geopandas ...
 - 2019.11.18【每天学点SAP小知识】Day4 - ABAP 7.40新语法 FOR
		
"今天学习一下FOR的语法,常用的2个语法. FOR wa|<fs> IN itab [INDEX INTO idx] [cond] "FOR i = … [THEN ...
 - 2019.11.10【每天学点SAP小知识】Day3 - ABAP 7.40新语法 值转化和值赋值
		
1.语法为 CONV dTYPE|#(...)\ # 代表任意类型 "7.40之前表达式 . DATA helper TYPE string. DATA xstr TYPE xstring. ...
 - 2019.11.07【每天学点SAP小知识】Day2 - ABAP 7.40新语法 - 内表
		
今天学习一下内表的表达式在ABAP 7.4之后的语法: SELECT * FROM mara INTO TABLE @DATA(gt_mara)UP TO 10 ROWS. DATA gt_mara_ ...
 - 2019.11.06 【每天学点SAP小知识】Day1 - ABAP 7.40新语法
		
最近看同事使用ABAP新语法贼溜,省了好多的功夫,还在使用老语法的我眼红了. 所以就自己补一补7.40之后语法,能够让自己写代码更顺畅吧. 今天学习内联申明 inline 意思是:当编译器发现某段代码 ...
 - C++11带来的优雅语法
		
C++11带来的优雅语法 自动类型推导 auto auto的自动类型推导,用于从初始化表达式中推断出变量的数据类型.通过auto的自动类型推导,可以简化我们的编程工作; auto是在编译时对变量进行了 ...
 
随机推荐
- day02 大型互联网架构演变历程笔记  和nigix和keepalived
			
PS:1.单个进程内,有多个线程,可以共享进程的内存空间2. 进程和进程之间通信比较麻烦, 会涉及 序列化和反序列化 PS :以一个交易网站看网站是如何变大的,网站的发展!!!! PS:随着请求的增加 ...
 - CentOS升级Python2.6到Python2.7并安装pip
			
原文:http://ruter.sundaystart.net/2015/12/03/Update-python/ 貌似CentOS 6.X系统默认安装的Python都是2.6版本的?平时使用以及很多 ...
 - #define WIN32_LEAN_AND_MEAN 的作用
			
今天看了用mysql的库+vc连接数据库,结果我用mfc application向导建立一个project,然后加入#include "mysql.h"(已经设置好了环境),编译出 ...
 - 命令行net time同步时间(内网)
			
首先还是推荐大家使用Internet时间来同步自己计算机的时间,这样做主要是方便,就是设置一个ntp服务器,我推荐下面的三个ntp服务器地址. time.asia.apple.com //亲测有效 a ...
 - spring 概念之:IoC(控制反转)
			
IoC(控制反转,Inverse of Control) IoC 的字面意思是控制反转,它包括两方面的内容: 控制 反转 那到底是什么东西的"控制"被"反转"了 ...
 - 大快DKH大数据智能分析平台监控参数说明
			
2018年国内大数据公司50强榜单排名已经公布了出来,大快以黑马之姿闯入50强,并摘得多项桂冠.Hanlp自然语言处理技术也荣膺了“2018中国数据星技术”奖.对这份榜单感兴趣的可以找一下看看.本篇承 ...
 - Hbuilder mui 相册拍照图片上传
			
http://www.bcty365.com/content-146-3648-1.html 使用流程 弹出actionSheet /*点击头像触发*/ document.getElementById ...
 - VS2005常用快捷键
			
Visual C++ 2005有很多种快捷键的映射方案,有适合 Emacs 用户的,有适合 Visual C++ 6.0 用户的,也有 Visual Studio 2005的,下面的快捷键符合IDE默 ...
 - 压缩归档tar命令
			
归档有两个命令,一个是tar命令,一个是cpio 归档不删除原文件 tar命令语法: tar cvf aa.tar file1 file2 file3 file4 file5 # tar cvf bb ...
 - innerHTML与jquery里的html()区别介绍
			
我原本一直以为innerHTML和jquery里的html其实是完全一样的,jquery是多此一举了,直到我遇到一次问题 看个示例: 复制代码 代码如下: var tbody=document.c ...