C++学习2022

一 多线程编程的基础类

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

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++ resizereserve区别

如果先用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

C++中的i++和++i的区别_Xu小亿的博客-CSDN博客_c++中++i和i++的区别

++i和i++是线程安全的吗?_舒泱的博客-CSDN博客_i++和++i线程安全

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值