1. Item 1: Understand template type deduction.
  2. Item 2: Understand auto type deduction.
  3. Item 3: Understand decltype.
  4. Item 4: Know how to view deduced types.
  5. Item 5: Prefer auto to explicit type declarations.
  6. Item 6: Use the explicitly typed initializer idiom when auto deduces undesired types.
  7. Item 7: Distinguish between () and {} when creating objects.
  8. Item 8: Prefer nullptr to 0 and NULL.
  9. Item 9: Prefer alias declarations to typedefs.
  10. Item 10: Prefer scoped enums to unscoped enums.
  11. Item 11: Prefer deleted functions to private undefined ones.
  12. Item 12: Declare overriding functions override.
  13. Item 13: Prefer const_iterators to iterators.
  14. Item 14: Declare functions noexcept if they won’t emit exceptions.
  15. Item 15: Use constexpr whenever possible.
  16. Item 16: Make const member functions thread safe.
  17. Item 17: Understand special member function generation.
  18. Item 18: Use std::unique_ptr for exclusive-ownership resource management.
  19. Item 19: Use std::shared_ptr for shared-ownership resource management.
  20. Item 20: Use std::weak_ptr for std::shared_ptr like pointers that can dangle.

  21. Item 21: Prefer std::make_unique and std::make_shared to direct use of new.
  22. Item 22: When using the Pimpl Idiom, define special member functions in the implementation file.
  23. Item 23: Understand std::move and std::forward.
  24. Item 24: Distinguish universal references from rvalue references.
  25. Item 25: Use std::move on rvalue references, std::forward on universal references.
  26. Item 26: Avoid overloading on universal references.
  27. Item 27: Familiarize yourself with alternatives to overloading on universal references.
  28. Item 28: Understand reference collapsing.
  29. Item 29: Assume that move operations are not present, not cheap, and not used.
  30. Item 30: Familiarize yourself with perfect forwarding failure cases.
  31. Item 31: Avoid default capture modes.
  32. Item 32: Use init capture to move objects into closures.
  33. Item 33: Use decltype on auto&& parameters to std::forward them.
  34. Item 34: Prefer lambdas to std::bind.
  35. Item 35: Prefer task-based programming to thread-based.
  36. Item 36: Specify std::launch::async if asynchronicity is essential.
  37. Item 37: Make std::threads unjoinable on all paths.
  38. Item 38: Be aware of varying thread handle destructor behavior.
  39. Item 39: Consider void futures for one-shot event communication.
  40. Item 40: Use std::atomic for concurrency, volatile for special memory.

  41. Item 41: Consider pass by value for copyable parameters that are cheap to move and always copied.
  42. Item 42: Consider emplacement instead of insertion.

Effective Modern C++ 42 Specific Ways to Improve Your Use of C++11 and C++14的更多相关文章

  1. 决定干点事儿--翻译一下《effective modern c++》

    写了非常多关于C++11的博客.总是认为不踏实,非常多东西都是东拼西凑.市场上也非常少有C++11的优秀书籍,但幸运的是Meyers老爷子并没有闲赋.为我们带来了<effective moder ...

  2. [C++11] Effective Modern C++ 读书笔记

    本文记录了我读Effective Modern C++时自己的一些理解和心得. item1:模板类型推导 1)reference属性不能通过传值参数传入模板函数.这就意味着如果模板函数需要一个refe ...

  3. Effective Modern C++翻译(1):序言

    /*********************************************************** 关于书: 书是我从网上找到的effective Modern C++的样章,内 ...

  4. 《Effective Modern C++》翻译--简单介绍

    北京时间2016年1月9日10:31:06.正式開始翻译.水平有限,各位看官若有觉得不妥之处,请批评指正. 之前已经有人翻译了前几个条目,有些借鉴出处:http://www.cnblogs.com/m ...

  5. Effective Modern C++:01类型推导

    C++的官方钦定版本,都是以ISO标准被接受的年份命名,分别是C++98,C++03,C++11,C++14,C++17,C++20等.C++11及其后续版本统称为Modern C++. C++11之 ...

  6. Effective Modern C++翻译(2)-条款1:明白模板类型推导

    第一章 类型推导 C++98有一套单一的类型推导的规则:用来推导函数模板,C++11轻微的修改了这些规则并且增加了两个,一个用于auto,一个用于decltype,接着C++14扩展了auto和dec ...

  7. 8 ways to improve ASP.NET Web API performance

    ASP.NET Web API is a great piece of technology. Writing Web API is so easy that many developers don’ ...

  8. 《Effective Modern C++》翻译--条款4:了解怎样查看推导出的类型

    条款4:了解怎样查看推导出的类型 那些想要了解编译器怎样推导出的类型的人通常分为两个阵营. 第一种阵营是实用主义者.他们的动力通常来自于编敲代码过程中(比如他们还在调试解决中),他们利用编译器进行寻找 ...

  9. Ten ways to improve the performance of large tables in MySQL--转载

    原文地址:http://www.tocker.ca/2013/10/24/improving-the-performance-of-large-tables-in-mysql.html Today I ...

随机推荐

  1. tornado 学习笔记15 _ServerRequestAdapter分析

         继承于HTTPMessageDeletegate,是HTTPMessageDeletegate的一种实现,用于处理请求消息. 15.1 构造函数 def __init__(self, ser ...

  2. BZOJ4597: [Shoi2016]随机序列

    Description 你的面前有N个数排成一行.分别为A1, A2, … , An.你打算在每相邻的两个 Ai和 Ai+1 间都插入一个加号或者 减号或者乘号.那么一共有 3^(n-1) 种可能的表 ...

  3. View的弹性滑动

    View的弹性滑动 实现弹性滑动的思想:将一次大的滑动分成若干次小的滑动并在一个时间段内完成,具体的实现方式有很多,如通过Scroller.Handler#postDelayed以及Thread#sl ...

  4. C,C++

    C与C++的Struct有何区别,Java有Struct吗,C++里Struct与Class区别: C++虚析构函数作用: static静态变量初始化: 深复制与浅复制区别: const * int ...

  5. Centos7强制卸载Mariadb

    之前安装过Mariadb 10.2.1版本,现在安装10.1.19版本,提示安装成功了,其实是失败的.MariaDB-server 提示已经安装,通过 rpm qa|grep MariaDB 查看 发 ...

  6. oracle导出一条二进制数据(二进制,long只能通过dmp导出)

    exp jxfoc/JXFOC@ORCL file=d:\dd.dmp tables=(jxfoc.FLIGHT_PLAN_MAKE_LOG,jxfoc.METAR_CONTENT_FOR_MAIL) ...

  7. 解决IE6/IE7/IE8不支持before,after问题

    对从事web开发的朋友来讲,低版本的IE永远是一个痛点,不支持最新技术(如css3,html5). 在现在web开发中使用图标字体已经很广泛,如Font Awesome,Bootstrap等,字体图片 ...

  8. 基于TCP协议的socket通信

    一.服务器端 1.创建serverSocket,即服务器端的socket,绑定指定的端口,并侦听此端口 ServerSocket server = new ServerSocket(8888); 2. ...

  9. SQL Server CONVERT() 截取日期

    SELECT CONVERT(varchar(100), GETDATE(), 0): 05 16 2006 10:57AMSELECT CONVERT(varchar(100), GETDATE() ...

  10. SQL Server 触发器

    触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程.触发器主要是通过事件进行触发被自动调用执行的.而存储过程可以通过存储过程的名称被调用. Ø 什么是触发器 触发器对表进行插入.更新.删 ...