C++ 中文周刊 常见问题 解答

周刊项目地址

公众号

qq群 点击进入 满了加这俩 729240657 866408334

RSS

经常在群里交流,发现有很多共性的问题,以及迷茫的点,大家重复交流很无聊,需要一些共识,这也是群聊的目的

大部分c++群聊聊天的内容都会包括本帖中讨论的各种争执,反复讨论很无聊,以后有重复的讨论就会把这个链接丢出来

之前通过发问卷收集了一些反馈 问卷地址 https://docs.qq.com/sheet/DYkllcE9scmtUUWlu?tab=ss_epaxm9&viewId=fv1&u=556ff788fee74403a1ab2ecd9e607b89

本文长期更新,按照更新顺序排列,目前更新时间为 2024-10-28

本文感谢赞助的朋友


c++就业前景/什么时候能找到好工作/当前c++能做的业务场景

这个我做了一个表格,https://docs.qq.com/sheet/DYm1nV1ZUdGVNWnNh?tab=BB08J2

大家感兴趣也可以补充,我把表格内容列出来

排名主要取决于成就感/薪资/发展 但实际上c++工作都很苦逼

对于应届生来说,主要是活下去,不一定强求非得干这个

已经入行的,大多有互相转的趋势,比如做基础架构的平台哥去做AI infra

或者做游戏的受不了了出来干平台

但做嵌入式肯定是苦的,如果你已经苦了,切换岗位代价高,那就去苦且有钱的地方,比如车行业

我该用哪个序列化库/哪个序列化库好?

选取库主要是取决于需求,要根据已有的场景做抉择,比如已经沾上grpc的屎, protobuf就躲不开

既然用protobuf,想换grpc也就只能去brpc

目前通用型屎protobuf较多的,甚至有基于protobuf的存储/算子引擎(扣字段)/内存分配器

通用性第二就是thrift

其次是flatbuffer 性能较好

c++如果不涉及跨语言边界,内部可以搞二进制自解析,比如struct_pack cista 还有redpanda/seastar都实现了自己的序列化

这些原理都是magic_ger(boost.pfr)就不展开了

一定还是要围绕需求的。前期开发可以用pb,后面慢慢切接口

现在学c++还有前途吗

学c++可以说是自找苦吃,计算机行业基本都需要终身学习

但c++不仅要终身学习,终身学习的途中你还会发现自己知道的越来越少

从沉没成本角度分析,前途不好,投入大于收益

但我觉的爱学的肯定你想换成别的语言也简单。毕竟你连c++都能忍

从已有的存量代码角度分析,c++肯定能活很久,所有语言所有范式,你翻一番就能在c++代码屎山里找到,吃屎饿不死

但受不了的人可能就用别的语言写一坨新的屎了

并且在cpu无明显进化的场景下,比如这几年intel磨洋工,这种场景下c++程序员是比较值钱的

从资方角度考虑,省CPU还是省人力,当人力不值钱,c++就不火

雇佣c++程序员如果能扣出来机器的钱,那就不愁找工作。目前来看还有一段距离

cpp当前主要能做的业务,以及在某些业务中的竞争对手语言

业务上面说了 主要竞争对手其实是后端语言都竞争

和go 抢普通业务CURD开发,基本被抢光了

和java抢大数据infra开发, java基本抢光。c++活在底层组件里

和rust抢底层infra组件,rust靠一手安全抢了一些业务,这种主要看公司老板推动,不推就是c++的天下

和python抢算法,现在作为python后端活着

协程哪个好,无栈协程好还是有栈协程好

其实这个问题也是需求问题,我们讨论协程通常是忽略了调度器分配器的,这里正交一下场景非常多

当前无栈协程不算稳定,可以先有有栈协程,观望先

目前已有的结论是无栈协程IO处理更好,有栈协程计算更稳,但这只是通用结论,具体场景还得自己来测

除标准库外,常用的一些三方库(网络,序列化,ui…)总结

这种其实github搜关键字就好了

网络 asio/libuv/libevent/brpc等等

序列化 protobuf/thrift/flatbuffers/ 自定义序列化

ui qt ?不太了解

json github搜星最多的那个,如果不是性能要求,不要用rapid-json,他既不rapid,也不好用,接口难用的一

这个后面慢慢补充吧 标记个TODO

有什么主要讲cpp工程而不是语法的书籍

工程只能从项目里找,一般可能就看看cppcon演讲了

或者最近有一本大规模c++程序设计可以看一下。我也下单了,有空写book review

这里也标记一个TODO

做算法C++要掌握到什么程度

能看懂基础语法,能把算法翻译成c++就行

我们把c++分成两类语法,业务级别/库级别

你需要掌握的就是业务级别,库级别特性比如enableif之类的你完全可以不看

重点在算法相关,比如浮点数可能有问题,标准库处理了太多异常你算法可以不考虑,可以优化

当然如果你做算法的库,可能还是得懂一点库级别特性

模板要学到什么程度

这个和上一个差不多,主要是模版有很多是库级别特性,但开发库的人千里挑一,业务哥用就完了

看你对自己的定位,你是平台哥要开发脚手架给别人用,你就得研究透模版偏特化/萃取之类的手段,给业务哥用

设计模式怎么学?我自己是做客户端,UI也好,业务逻辑也好,框架也好,自己写出来的总差点意思。没章法,不好维护

这种就是代码写得少抄的少了,你的场景什么应用也会有?github找到该项目,直接抄他的组织模式

指针和数组有什么区别?

这个是经典吵架问题,有啥区别,完全不一样,数组名能退化(decay)成指针,就这一个关联

array和数组谁性能好/vector和我自己写的动态数组谁快

这种模糊问题不好回答,比较什么接口?比如array的[]和vector::emplace_back比,前者可能存在向量化

自己约束场景做压测最好,问是问不出来的

c++多个版本,从哪个版本学习更容易开始工作

c++17 编译器是什么版本你就学什么版本,编译器目前默认17

为什么库都很难装,很难用。一个库一堆重复的宏

c++ 没有包管理器的问题

如果你是cmake,用cpm, 如果没有选择,可以尝试xmake,公司一般来说会用bazel/blade 后面三个原理类似

什么是右值,右值引用变量为什么不是右值/类型和值类别/右值引用 所有权

你要理解纯值类型 pure value,其他名次基本上就是为了延长生命周期做的代价

这个新人可以跳过。这一般不是重点

模板递归怎么写/concept怎么写/iterator怎么写

没有需求没法教会你,模版递归很容易栈溢出

concept你可以照着抄std::same_as

iterator可以随便抄一个容器的,重点是tag dispatch

c++11的移动是个什么东西

移动语义可以写一本书,打个比方value左值是一个盒子,我可以通过move告诉编译器把盒子里的东西搬走

有时间的话可以看一下这篇:C++的右值引用、移动和值类别系统,你所需要的一切

各种编译失败/库的链接问题(为什么链接失败

这种只能搜索引擎搜,我也总结了个常见报错整理 https://wanghenshui.github.io/2019/11/01/compile.html

没有好的解决办法

有无对标python ply yacc的现代化的语法解析器?

boost::spirit 这个是最经典的也是比较难懂的,foothan他有个lexy

这种需求说实话有点小众

单独的一条if或者while语句要不要加花括号/左花括号{要不要换行

格式问题一律clang-format修复,自己的规则自己维护,因为格式吵架过于无聊

字符串是否应该可变?

字符串需求非常多,99%都是小的不可变的,因此cow也有存在价值,SSO默认都做

fbstring也有长短串优化, 甚至还有umbrastring这种prefix优化字符串

回到问题,看需求,c++是灵活的,面对不同需求解法多花样多,就是图这个花样我才学c++

struct vs tuple?

永远优先struct,tuple只适合转发,没有名字信息是致命的

如何调试模版错误?

只能复制编译报错拿出来二分,搜代码文件名字,瞪眼法,没有好的办法。如果ICE就放弃吧

ICE/NTTP/….是什么

关于这些缩写名次 https://quuxplusone.github.io/blog/2019/08/02/the-tough-guide-to-cpp-acronyms/

这里有个总结。其实看一遍大概就明白了

有没有c++推荐书单/怎么学c++

书单 Stackoverflow上有个经典书单 https://stackoverflow.com/questions/388242/the-definitive-c-book-guide-and-list

说实话,你不太可能挨个看完,这里列一下

还有一些老书什么深入理解对象模型stl源码剖析之类的 ,我只能说开卷有益,但没事你别开这几卷

至于怎么学c++,永远是围绕着需求来的,你要先有一个目标,需求,做什么,然后围绕这个目标努力,然后围绕这个目标迭代你的代码

光看不写是不行的,纸上得来终觉浅

这里有一篇详细的介绍,不是我写的,但是很不错,给新人参考 https://zclll.com/index.php/cpp/get_started_cpp.html

编译器之争?哪个编译器好

需求需要用什么编译器就用什么,gcc/clang也可以自由选择使用libcxx还是libstdc++

你也可以全平台都用

举例 clickhouse就选择使用libcxx和llvm compilerrt来作为项目一部份

xx算法/xx设计比标准库stl快,为什么没有进标准库,有没有可能进标准库

introsort不如pdqsort,pdqsort有机会,但目前演进很慢

还有fmtlib的浮点数要比标准库的快

还有令人诟病的regex问题。cxx标准库为了ABI稳定做了太多妥协,当然他们也懒得一笔

能用第三方库就用,c++生态问题一直非常令人诟病,而其他快的库/算法/设计可能由于信息差的问题看不到

关注c++中文周刊,谢谢

有没有初学者入门推荐的视频

教学视频通常信息量过低,我个人不太推荐,如果非要看可以B站随便搜入门视频

另外CPPCON建议学一些之后再看。

对于初学者,开卷有益,随便找一本书看起来再说

另外很多人买网课,属于一种健身房办卡的行为,靠花钱激发负罪感都花钱了得学得练

这种心态也能理解

当然你也可以给我打钱

int8为什么std::cout无法打印

有一些字符是不可见字符,std::cout不会按照int打印

这种场景选择用fmt

感觉clang-tidy/告警报错很有挫败感,感觉自己老也写不对

不要陷入教条主义,告警尽量修

clang-tidy很多是最佳实践,做不到,能控制住影响,也可以忽略掉 NOLINT

专家还建议每天八杯水呢。尽力而为,控制影响,要有自己的判断

optional<T*> 是好的设计吗

非常不好

看到这里或许你有建议或者疑问或者指出错误,请留言评论! 多谢! 你的评论非常重要!也可以帮忙点赞收藏转发!多谢支持! 觉得写的不错那就给点吧, 在线乞讨 微信转账