从reddit/hackernews/lobsters/meetingcpp/purecpp/知乎/等等摘抄一些c++动态
周刊项目地址|在线地址 |知乎专栏 | 腾讯云+社区 |
欢迎投稿,推荐或自荐文章/软件/资源等
可以贴在下一期草稿里 草稿链接
2022 1002
大家国庆快乐
标准委员会动态/ide/编译器信息放在这里
编译器信息最新动态推荐关注hellogcc公众号 本周更新 2022-09-28 第169期
除了贵和积热之外没啥缺点。zen4太贵了。本来打算双十一拼一台。看样子只能考虑明年618再拼了。
今年可以双十一攒个5950x,加b550不到四千。内存也便宜
struct s {
static constexpr auto operator()() { return 1; }
};
auto l = [] static { return 2; };
static_assert(3 == s{}() + l());
static_assert(3 == s::operator()() +
decltype(l)::operator()());
没啥说的。补全一下
有了ssize支持,可以不考虑符号了,
for (int i = 0; i < ssize(vec); ++i)
std::cout << i << ": " << vec[i] << '\n';
range遍历 + 索引
int main() {
std::vector vec { 1, 2, 3, 4, 5};
for (int i = 0; const auto& elem : vec)
std::cout << i++ << ": " << elem << '\n';
}
说实话有点别扭,没有go那种 i, v = range
那种感觉好, 聊胜于无吧
组合view
#include <iostream>
#include <vector>
#include <ranges>
int main() {
std::vector vec { 1, 2, 3, 4, 5};
for (int i = 0; const auto& elem : vec | std::views::reverse)
std::cout << i++ << ": " << elem << '\n';
}
使用range view算法
void printReverse(auto cont) {
std::ranges::for_each(cont | std::views::reverse,
[i=0](const auto& elem) mutable {
std::cout << i++ << ' ' << elem << '\n';
}
);
}
看不懂
科普一下
还是科普
这个其实就是之前那个英语博客的转述
草药老师关于他cppfront语法的一些需求的实现。没细看
介绍format以及llvm的支持程度。基本都支持除了chrono
内联场景的前缀字符串前缀数组可能会被编译器优化掉,减少二进制大小
比如
const char * str1 = "dear friend";
const char * str2 = "dear friend";
return str1 == str2;
void oops(std::vector<std::string>& v)
{
set_name(v.front.c_str());
// ^^^^^ error: A pointer to a bound function
// may only be used to call the function
}
忘记加括号了
有些功能比如move迭代器之类的存在用不好的场景。导致莫名其妙的影响性能。
类型擦除的方法。之前也讲过. 就是藏函数指针
class animal_view {
public:
template <typename Speakable>
explicit animal_view(const Speakable &speakable)
: object{&speakable},
speak_impl{// create a lambda that knows how to unpack the stored object
[](const void *obj) {
return static_cast<const Speakable *>(obj)->speak();
}} {}
void speak() const { speak_impl(object); }
private:
// void * to object of unknown type
const void *object;
// function pointer that knows how to use unknown type
void (*speak_impl)(const void *);
};
void do_animal_things(animal_view animal) { animal.speak(); }
int main() {
struct Cow {
void speak() const { fmt::print("Mooo\n"); }
};
struct Sheep {
void speak() const { fmt::print("Baaa\n"); }
};
do_animal_things(animal_view{Cow{}});
do_animal_things(animal_view{Sheep{}});
}