公众号

欢迎投稿,推荐或自荐文章/软件/资源等
可以贴在下一期草稿里 草稿链接
标准委员会动态/ide/编译器信息放在这里
编译器信息最新动态推荐关注hellogcc公众号 本周更新 2022-01-05 第131期
boost 1.81 beta发布 https://boostorg.jfrog.io/artifactory/main/beta/1.81.0.beta1/source
有Boost.URL,也有boost.unordered_flat_map,尝鲜可以试试
手把手写反射,可以这里 https://godbolt.org/z/qsqe3aW6b 体验一下,还是很有意思的
各种bit strings比较(vector<bool>, bitset<N>,boostd::dynamic_bitset)  谁find更快,结论libc++(llvm)有优化,libstdcxx(gcc)没有
有意思
简单说,就是未定义行为都是代码屎山,所以可以根据屎的最初形态来找一些蛛丝马迹。。。
c语言过于底层,已经成为 协议/接口的一部分了 。后来的语言都要缝缝补补c
perf分析 。qt相关。不太懂
std::unreachable();一看就懂
std::to_underlying 是这玩意
template <typename Enum>
constexpr auto to_underlying(Enum e) noexcept
{
    return static_cast<std::underlying_type_t<Enum>>(e);
}
std::byteswap 看这个例子
template <std::integral T>
void print_hex(T v)
{
   for (std::size_t i = 0; i < sizeof(T); ++i, v >>= 8)
   {
      std::cout << std::format("{:02X} ", static_cast<unsigned>(T(0xFF) & v));
   }
   std::cout << '\n';
}
int main()
{
   unsigned char a = 0xBA;
   print_hex(a);                    // BA
   print_hex(std::byteswap(a));     // BA
   unsigned short b = 0xBAAD;
   print_hex(b);                    // AD BA
   print_hex(std::byteswap(b));     // BA AD
   int c = 0xBAADF00D;
   print_hex(c);                    // 0D F0 AD BA
   print_hex(std::byteswap(c));     // BA AD F0 0D
   long long d = 0xBAADF00DBAADC0FE;
   print_hex(d);                    // FE C0 AD BA 0D F0 AD BA
   print_hex(std::byteswap(d));     // BA AD F0 0D BA AD C0 FE
}
看不懂
简单来说,就是使用继承T,把T本身多余的信息吃掉。花哨。看个乐
template<auto...> struct long_type {};
//生成类型long_type<0,1,2,3...41>
using long_type_t = decltype(
    []<auto... Ns>(std::index_sequence<Ns...>) {
        return long_type<Ns...>{};
    }
    (std::make_index_sequence<42>{})
);
// typename erasure
// 通过继承直接吃掉long_type_t的类型
struct short_type_t : long_type_t{};
// generic typename erasure
// 泛型版本的继承,吃掉类型。这个T得有默认构造,不然编译不过
template<class T> using typename_erasure = decltype([] {
    struct s : T { using T::T; }; // generated in the compiler as `$0::s` or similar
    return s{};
}());
int main() {
    assert(std::string_view{typeid(long_type_t).name()}.size() > 100); // 长类型
    assert(std::string_view{typeid(short_type_t).name()}.size() < 15); // 短类型
    assert(std::string_view{typeid(typename_erasure<long_type_t>).name()}.size() < 25); // 短类型
}
茴香豆的茴有几种写法?
这个和c++没啥关系,但是非常有意思
没啥说的
美帝的公司也裁员啊。大环境真就都不好
是否被裁,就看这俩月!虽然我划水,但别裁俺
