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是在编译时对变量进行了 ...
随机推荐
- WCF 采用net.tcp协议实践(转)
概述 与Socket相比,WCF真是爽得不得了,其基本指导思想为SOA——面向服务. 其基本配置在于ABC(Address,Binding,Contract),通常,只要这三个因素配置对了,那么,基本 ...
- java类库 java API jar包 C语言函数库
翁凯说:java的强大是因为类库的强大 C/C++强大是因为函数库 在程序中用到系统提供的标准函数库中的输入输出函数时 应在程序的开头写上一行:#include"stdio.h"或 ...
- android 工具类 数据库管理
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/xuduzhoud/article/details/27540301 数据库工具类,优雅的管理andr ...
- Web Js推断键盘出发事件
window.document.onkeydown = disableRefresh; function disableRefresh(evt){ evt = (evt) ? evt : wind ...
- pykd试用
啥是pykd? 一个windbg插件,能在windbg里面运行python指令 试用步骤 下载from https://pykd.codeplex.com/releases/view/615625 解 ...
- [转]Oracle中trace的几种
Oracle中trace的几种 标签: 杂谈 我们在Oracle中在做troubleshooting的时候,经常要去做跟踪来查错,那今天就介绍几种trace的方法. 在这之前,我先说说10046事 ...
- BaseDao的编写:实现 增,删,改,查,分页这些公共方法的编写
1.BaseDao接口 package com.learning.crm.base; import java.io.Serializable; import java.util.List; publi ...
- SQL Server Management Studio (SSMS) 清除登录记录
对于 SQL Server 2005 Management Studio,可以删除以下文件清空该列表: WinXP: C:\Documents and Settings\<user>\Ap ...
- SQL 将非标准日期格式转换成标准格式,进行条件判断
a.JLDate为非标准日期格式: 例: 2011-8-28 0:00:000011-8-28 0:00:000111-8-4 0:00:00 select CONVERT(varchar(50),C ...
- Zabbix监控windows的CPU利用率和其他资源
zabbix的WEB端--配置-模板--Template OS Windows--项目--创建项目 名称:UserPerfCountercpu 键值:UserPerfCountercpu 数据类型:数 ...