从reddit/hackernews/lobsters/meetingcpp摘抄一些c++动态
周刊项目地址|在线地址 |知乎专栏 | 腾讯云+社区 |
欢迎投稿,推荐或自荐文章/软件/资源等,请提交 issue
2022 0808
标准委员会动态/ide/编译器信息放在这里
编译器信息最新动态推荐关注hellogcc公众号 本周更新 2022-08-03 第161期
c++的bind和网络库的bind符号冲突了。很搞笑。不过在linux环境下没有这个问题 我之前在windows平台遇到过log日志接口和cmath的log函数有符号冲突。msvc这个方面做的不是很好
/*
divide_by_32_no_assume(int):
lea eax, [rdi + 31]
test edi, edi
cmovns eax, edi
sar eax, 5
ret
*/
auto divide_by_32_no_assume(int x) {
return x / 32;
}
/*
divide_by_32_assume(int):
mov eax, edi
shr eax, 5
ret
*/
auto divide_by_32_assume(int x) {
__builtin_assume(x >= 0);
return x / 32;
}
这个之前提到过,有个经典的fast-math开关优化。那个力度比较大。这里你可以自主控制,力度更精细一些
同一个代码段 c和c++有很大区别。主要是逗号表达式,左值右值,位域,类型转换,类型大小,空类型,匿名结构体等等。感兴趣的可以看看。
介绍TSAN的原理
介绍内核内存分配策略
用c++实现structopt, 看个乐
没看明白
一个bug
template<class It>
bool is_palindrome(It first, It last) {
while (first != last) {
--last;
if (first == last) break;
if (*first != *last) {
return false;
}
++first;
}
return true;
}
很自然的,可以改写成
template<class It>
bool is_palindrome(It first, It last) {
return std::equal(
first, last,
std::reverse_iterator(last),
std::reverse_iterator(first)
);
}
这里没用make_reverse_iterator,用的CTAD自动推导。但是这个推导可能不是我们预想的那样
std::string s = "foo";
assert(!is_palindrome(s.begin(), s.end()));
assert(is_palindrome(s.begin()+1, s.end()));
assert(!is_palindrome(s.rbegin(), s.rend()));
assert(is_palindrome(s.rbegin(), s.rend()-1)); // Fails! Oof!
最后两个例子,已经是reverse的iterator, CTAD什么都不做,而不是推导成 reverse_iterator<iterator>
这种东西,所以报错了
尽量别用CTAD。降低入门门槛但是引入了背景,不熟就掉坑
有没有需要看大门的,要被毕业了