線路代號30的表示方法(C17in)
2023-08-22 18:40:57 2
線路代號30的表示方法?anon類模板參數推導,今天小編就來聊一聊關於線路代號30的表示方法?接下來我們就一起去研究一下吧!
線路代號30的表示方法
anon
類模板參數推導
std::pair p(2, 4.5); // std::pairstd::tuple t(4, 3, 2.5); // std::tuple
inline variable
// In a.hppinline SomeType singletonVar;
每個翻譯單元都要include a.hpp,最後只會保留一個
細化Evaluation order
a[i ] = i; // 等號右邊的現在規定會先計算完成/*a.ba->ba->*ba(b1, b2, b3)b @= aa[b]a <> b現在都會a, b, c, d順序計算*/
guaranteed copy elision
std::mutex a_mutex;std::lock_guard get_lock{ return std::lock_guard(a_mutex); // lock_guard沒有複製、移動構造函數。17之前這句不合法(儘管事實上都能編譯過)。17之後auto lock = get_lock;就合法了}
if statement with initilizer
if (auto it = m.find(10); it != m.end) // return *it
structured binding
std::map m;auto [iter, ok] = m.insert({1, 2}); // insert返回pair
string_view
std::string cppstr = "Foo";std::string_view cppstr_v(&cppstr[0], cppstr.size);cppstr[0] = 'A';std::cout << cppstr_v; // Aoo
嵌套namespace
namespace a::b{ // ...}
if constexpr
templatevoid f(Ts ... args){ if constexpr(sizeof... (args) > 0) f1(args..); else f1(default_arg);}
Fold 表達式
templateconstexpr int sum(Ts... args){ return ( 0 ... args ); // = ( (0 arg0) arg1 ) arg2 ...}static_assert(10 == sum(2, 3, 5)); // static_assert可以沒有信息了
模板非類型參數auto
templatestruct Size{ static const size_t size = sizeof(C);};static_assert(Size::size == sizeof(3));static_assert(Size::size == sizeof(void*));
lambda改進
struct Foo{ int val; void f { (*this) { val = 100; }; // 複製了整個對象進lambda }};Foo obj {42};obj.f;assert(obj.val == 42);auto getSize = (auto o) { return sizeof(o); } // 這是constexpr了static_assert(getSize(obj) == sizeof(Foo));
void_t,更方便的SFINAE
template< class, class = std::void_t >struct has_type_member : std::false_type { };templatestruct has_type_member<T, std::void_t> : std::true_type { };
{variant/optional/any}
optional get_foo{ if (...) return some_msg; else return {};}std::cout << get_foo.value_or("Not found!");
variant v, w;v = 12;int i = get(v);w = get(v);w = get(v); // 同上w = v; // 同上get(v); // ill formed
改進
std::sort(std::execution::par, std::begin(v), std::end(v)); // 並行版std::vector v2{ 1, 2, 4, 5, 0 };assert(12 == std::reduce(std::execution::par, std::begin(v2), std::end(v2))); // 亂序版accumulate
filesystem
std::filesystem::copy("/etc/resolv.conf", "./resolv.conf", std::filesystem::copy_options::overwrite_existing);for (auto it = std::filesystem::recursive_directory_iterator("/usr/bin"); it != std::filesystem::recursive_directory_iterator; it){ std::cout <path << std::endl;}
Aligned dynamic allocation
namespace std {enum class align_val_t: size_t;};void *operator new(std::size_t, std::align_val_t);// new overload 分配一段對齊的內存
在不同容器間移動結點
map src {{1,"one"}, {2,"two"}, {3,"buckle my shoe"}};map dst {{3,"three"}};dst.insert( src.extract( src.find(1) ) );dst.insert( src.extract(2) );
,