前言

  • 发现好多情况下都会用到c++11的新特性啊。
  • 所以稍稍总结一下,只会粗略的说,不会详细的讲……
  • upd.csp-s可能不是c++11标准,请慎用。(博主考试CE后的善意提醒)

1.auto&decltype

  • c++11新增关键字,类型推导。
  • 迭代器在之前必须写得很长,比如:
set<int>s;
set<int>::iterator it=s.begin();
  • 而c++11只需写成:
auto it=s.begin();
  • 但auto只能对变量而不能对表达式进行类型推导,所以又引入了decltype关键字。
  • decltype只会推导表达式的类型而不会算出数值。
auto a=233,b=666;
decltype (a+b) c;

2.constexpr

  • 常量表达式的修饰符。
  • 可修饰常量和函数。
  • 注意赋给常量的值必须是系统能够识别的,而不能是自定义的变量。
#include<bits/stdc++.h>
constexpr long long qwq(long long x){
return x*x;
}
int main(){
constexpr int a=;
return ;
}

3.nullptr

  • 空指针值,为了区分0和NULL。
  • 因为NULL的本质是0,所以就算把NULL赋给int也不会报错,但nullptr就不行,因为它只代表空指针。

4.tuple

  • 元组。
  • 相当于高级的pair,成员可为任意个。
  • 相关操作参考下面的代码。
#include<iostream>
#include<tuple>
using namespace std;
tuple<int,int,int>s=make_tuple(,,);//make_tuple:制造元组
int main(){
cout<<get<>(s)<<" "<<get<>(s)<<" "<<get<>(s)<<endl;//get:得到元组中的某位元素
int x,y,z;
tie(x,y,z)=s;//tie:拆元组
cout<<x<<" "<<y<<" "<<z<<endl;
tuple<int,long long>w=make_tuple(,4ll);
auto ws=tuple_cat(w,s);//tuple_cat:合并元组
cout<<get<>(ws)<<" "<<get<>(ws)<<" "<<get<>(ws)<<" "<<get<>(ws)<<" "<<get<>(ws)<<endl;
return ;
}

5.哈希容器

  • c++11新增了一些基于Hash的容器:
  • unorder_map,unorder_set,unorder_mulitmap,unorder_mulitset。
  • 性能比set,map等更优。

6.容器&数组遍历

  • 只能说非常方便,甚至可以遍历map……
#include<bits/stdc++.h>
using namespace std;
vector<int>s;
int a[];
int main(){
a[]=,a[]=,a[]=;
s.push_back(),s.push_back(1e9+),s.push_back();
for(auto &x:s)cout<<x<<" ";
puts("");
for(int &x:a)cout<<x<<" ";
puts("");
return ;
}

7.容器初始化

  • 可以像数组一样对容器进行初始化,包括map(为什么又拿map开刀……)。
map<int,int>mp{{233,1},{521,2}};

8.Lambda

  • 匿名函数。
  • 可以在使用时再定义函数,而不用费力起函数名。
  • 如sort:
#include<bits/stdc++.h>
using namespace std;
int a[];
int main(){
srand(time());
int n=;
for(register int i=;i<=n;++i)a[i]=rand();
sort(a+,a+n+,[](int skyh,int yxs){
return skyh>yxs;
});
for(register int i=;i<=n;++i)printf("%d ",a[i]);
return ;
}
  • 用法很灵活,非常好的特性。然而我对它理解不是非常透彻

9.mt19937

  • C++11引入,基于Mersenne twister算法实现的高质量随机数。
  • 得到的随机数在int范围内。
  • 据说比rand()函数快,不过实测时mt19937比rand还要慢一些……
  • 还是rand更快。
#include<random>
#include<cstdio>
using namespace std;
int main(){
//freopen("1.in","w",stdout);
mt19937 rd(time(NULL));
int n=rd()%+,m=rd()%+;
printf("%d %d\n",n,m);
return ;
}
  • upd.听从miemeng神的意见,顺便提一下random标准库吧。
  • 这是c++11新增的一个库,分为生成器和分布两大部分。
  • 其中有三种随机数生成引擎。
  • 第一种是线性同余生成引擎,第二种是Mersenne_twister算法(梅森旋转法)生成引擎,第三种是滞后Fibonacci算法生成引擎。
  • 线性同余最快,梅森旋转法效果最好。
  • 想更详细了解的话可以参照这篇博客:
  • https://blog.csdn.net/u010487568/article/details/51526337

10.尖括号

  • 可能你在打代码的时候没有注意,但这也是c++11的特性。
  • >>不再只被认为是流。
vector<pair<int,int>>s;//是合法的

c++11相关特性的更多相关文章

  1. C++ 11学习和掌握 ——《深入理解C++ 11:C++11新特性解析和应用》读书笔记(一)

    因为偶然的机会,在图书馆看到<深入理解C++ 11:C++11新特性解析和应用>这本书,大致扫下,受益匪浅,就果断借出来,对于其中的部分内容进行详读并亲自编程测试相关代码,也就有了整理写出 ...

  2. [转载] C++11新特性

    C++11标准发布已有一段时间了, 维基百科上有对C++11新标准的变化和C++11新特性介绍的文章. 我是一名C++程序员,非常想了解一下C++11. 英文版的维基百科看起来非常费劲,而中文版维基百 ...

  3. C#中的自定义控件中的属性、事件及一些相关特性的总结(转)

      摘要: C#中的自定义控件中的属性(Property).事件(Event)及一些相关特性(Attribute)的总结 今天学习了下C#用户控件开发添加自定义属性的事件,主要参考了MSDN,总结并实 ...

  4. 不能支持C++11的特性~,升级到4.8.2

    一.简易安装 操作环境 CentOS6.5 64bit,原版本4.4.7,不能支持C++11的特性~,希望升级到4.8.2 不能通过yum的方法升级,需要自己手动下载安装包并编译 1.1 获取安装包并 ...

  5. c++学习书籍推荐《深入理解C++11 C++11新特性解析与应用》下载

    百度云及其他网盘下载地址:点我 编辑推荐 <深入理解C++11:C++11新特性解析与应用>编辑推荐:C++标准委员会成员和IBM XL编译器中国开发团队共同撰写,权威性毋庸置疑.系统.深 ...

  6. C++11 新特性之智能指针(shared_ptr, unique_ptr, weak_ptr)

    这是C++11新特性介绍的第五部分,涉及到智能指针的相关内容(shared_ptr, unique_ptr, weak_ptr). shared_ptr shared_ptr 基本用法 shared_ ...

  7. Java SE 11 新增特性

    Java SE 11 新增特性 作者:Grey 原文地址:Java SE 11 新增特性 源码 源仓库: Github:java_new_features 镜像仓库: GitCode:java_new ...

  8. C++11新特性总结 (二)

    1. 范围for语句 C++11 引入了一种更为简单的for语句,这种for语句可以很方便的遍历容器或其他序列的所有元素 vector<int> vec = {1,2,3,4,5,6}; ...

  9. C++11新特性总结 (一)

    1. 概述 最近在看C++ Primer5 刚好看到一半,总结一下C++11里面确实加了很多新东西,如果没有任何了解,别说自己写了,看别人写的代码估计都会有些吃力.C++ Primer5是学习C++1 ...

随机推荐

  1. CSS3新特性(阴影、动画、渐变)

    一.阴影 1.1文字阴影: text-shadow<length>①: 第1个长度值用来设置对象的阴影水平偏移值.可以为负值 <length>②: 第2个长度值用来设置对象的阴 ...

  2. 小记-----如何把本地jar包加载到maven库中

    1.从maven中央库下载下jar包

  3. React同构起步

    React同构从0到1 前言 如果你想快速做react同构的新项目建议你去了解next.js等成熟框架,本教程仅限于想了解如何从0开始实现一个同构环境过程的同学,对于想改造现有spa项目的同学也很有帮 ...

  4. Flask-wtf导入Regexp规则库验证手机号码合法性(测试通过)

    手机号码在项目有着很重要的地位,保证用户输入的号码准确无误就显得很关键. 废话不多说,现在页面中引入Regexp规则库: from wtforms.validators import Regexp 验 ...

  5. Berland Army CodeForces - 883B (贪心,拓扑排序)

    大意: n个点, 点$i$的等级为$r_i$, 只给出部分点的$r$值, $r_i$的范围为[1,k], 且[1,k]都至少有一个. 给定m条有向边, (x,y)表示$r[x]>r[y]$, 求 ...

  6. leetcode 980. Unique Paths III

    On a 2-dimensional grid, there are 4 types of squares: 1 represents the starting square.  There is e ...

  7. 76. Minimum Window Substring (JAVA)

    Given a string S and a string T, find the minimum window in S which will contain all the characters ...

  8. AIX 6.1创建逻辑卷并挂载【smitty】

    1.创建卷组 #mkvg  -y   datavg     hdisk2   hdisk3   #smitty   vg

  9. windows server :远程桌面服务当前正忙,因此无法完成您尝试执行的任务

    原因是:Csrss.exe 进程和某些应用程序 (例如,Microsoft Excel 或 Microsoft Visio) 之间发生的死锁情况下会出现此问题. 解决:下载一个修复补丁,安装后重启服务 ...

  10. linux编译安装mysql5.7

    一.下载源码包 -src cd /usr/local/src/mysql--src wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5 ...