一 多线程编程的基础类
1 std::bind C++11中的std::bind 简单易懂_云飞扬_Dylan的博客-CSDN博客_std::bin
2 future: C++11之std::future对象使用说明_Jimmy1224的博客-CSDN博客_std::futrue
3 promise:https://www.jianshu.com/p/7945428c220e
4 std::function function/bind的救赎(上)_myan的博客-CSDN博客_function/bind的救赎 C++11新特性之std::function_一苇渡江694的博客-CSDN博客
5 forward完美转发。C++11新特性之 std::forward(完美转发)_一苇渡江694的博客-CSDN博客_c++11 forward
6 move c++ 之 std::move 原理实现与用法总结_ppipp1109的博客-CSDN博客_std::move
7 move&forward c++ 之 std::move 原理实现与用法总结_ppipp1109的博客-CSDN博客_std::move
8 左值引用和右值引用c++ 之 std::move 原理实现与用法总结_ppipp1109的博客-CSDN博客_std::move
9 lambda表达式和函数对象包装器 《现代C++教程》chapter 3&chapter 4_带你去网吧里偷耳机的博客-CSDN博客. C++ 11 Lambda表达式 - 滴水瓦 - 博客园
右值引用有两个很有用的性质。第一,右值引用扩展了原初始化值的生命周期到右值引用的生命周期(指向常对象的左值引用也可以做到)。
第二,非常量引用允许你修改右值。 15.2 右值引用 - LearnCPP 中文教程
如果我们构造一个对象或者进行一次赋值时,当参数是一个左值,我们唯一能做的就是拷贝这个左值。我们不能假设修改它是安全的,因为它可能在之后的程序中被使用。就好像如果有一个表达式 a = b,我们无论如何不会期待b被改变 。然而,如果我们构造一个对象或者做一次赋值时,参数是一个右值,我们知道右值仅仅是一个某个类型的临时值。相比拷贝他(花费更多资源),我们可以简单的移动它的资源(花费非常少)给我们正在创建或者赋值的资源。这是实现起来是安全的,因为临时值将会被销毁在表达式的结尾,因此我们知道它将永远不会再被再次使用!
先学习移动语义(移动构造和移动赋值),再学习move。
15.3 移动构造和移动赋值 - LearnCPP 中文教程
在 C++11 中 std::move 是一个标准库函数,该函数只有一个目的,把参数转化为右值。我们可以传一个左值给 std::move,然后它就会返回一个右值引用。
15.4 std::move - LearnCPP 中文教程
std::move() 提供了一个提示给编译器,程序员不再需要这个对象了(至少,不需要它当前的状态)。因此,你应该不要使用 std::move() 在任何持续使用,不想被修改的对象,并且你应该不要期望任何经过 std::move() 的对象在经过移动后相同!
std::forward就可以保存参数的左值或右值特性。
1 模版的引用折叠原则
C++11 完美转发 - kaizenly - 博客园
2 为什么要引入完美转发
C++11 完美转发 - kaizenly - 博客园
无论左值引用类型的变量还是右值引用类型的变量,都是左值,因为它们有名字。
先看懂移动语义
再学习move操作
再学习模版引用折叠
再学习完美转发(1 为什么要引入完美转发,2 完美转发做了什么,怎么实操)
二 基础算法
1 nth_element() C++ nth_element()用法详解
2 atomic类型 c++ atomic函数_C++11 - atomic类型和内存模型 - CodeAntenna (原子语句线程间天然互斥操作,memory_order是为了说线程内部各原子操作的先后顺序)
3 emplace关键字 C++11容器中新增加的emplace相关函数的使用_fengbingchun的博客-CSDN博客_emplace函数
4 swap操作。关于C++ 容器的swap操作_imkelt的博客-CSDN博客 c++中std::swap使用方法_四叶草姚的博客-CSDN博客_std swap
5 raii封装。C++11实现模板化(通用化)RAII机制_10km的博客-CSDN博客
6 C++友元函数和友元类。C++友元函数和友元类(C++ friend)详解
7 Std::unique https://www.jianshu.com/p/b8987c8d80b8
8 std::set_difference C++集合操作之集合差集:std::set_difference_CoderAndClimber的博客-CSDN博客_set_difference
9 inplace_merge C++ merge()和inplace_merge()函数用法(详解版)
10 lower_bound和upper_bound:关于lower_bound( )和upper_bound( )的常见用法_brandong的博客-CSDN博客_upper_bound
11 scoped_ptr: C++智能指针scoped_ptr的原理和使用_yishizuofei的博客-CSDN博客_scoped_ptr
12 智能指针官方文档: Boost.SmartPtr: The Smart Pointer Library - 1.80.0
13 C++ resize和reserve区别
如果先用resize,再push_back,那么前边的size个数据还在。
14 cpp so文件
什么是.so文件_老王不让用的博客-CSDN博客_.so文件
linux 中的.so和.a文件_YYDroid的博客-CSDN博客
15 C++ protobuf反射
https://www.jianshu.com/p/ddc1aaca3691
protobuf反射详解 - Ying's Blog (自己曾经做过)
ProtoBuf(Google Protocol Buffers)—— 反射原理以及反射具体流程介绍_JMW1407的博客-CSDN博客_protobuf反射
#define参数化
#define CASE_FIELD_TYPE(cpptype, method, valuetype)\
case google::protobuf::FieldDescriptor::CPPTYPE_##cpptype: {\
reflection->Set##method(\
message,\
field,\
*(reinterpret_cast<const valuetype*>(value.c_str())));\
std::cout << field->name() << "\t" << *(reinterpret_cast<const valuetype*>(value.c_str())) << std::endl;\
break;\
}
CASE_FIELD_TYPE(INT32, Int32, int);
CASE_FIELD_TYPE(UINT32, UInt32, uint32_t);
CASE_FIELD_TYPE(FLOAT, Float, float);
CASE_FIELD_TYPE(DOUBLE, Double, double);
CASE_FIELD_TYPE(BOOL, Bool, bool);
CASE_FIELD_TYPE(INT64, Int64, int64_t);
CASE_FIELD_TYPE(UINT64, UInt64, uint64_t);
#undef CASE_FIELD_TYPE
16 i++和++i