首页
/
每日頭條
/
生活
/
線路代号30的表示方法
線路代号30的表示方法
更新时间:2025-07-04 11:20:08

線路代号30的表示方法?anon類模闆參數推導,今天小編就來聊一聊關于線路代号30的表示方法?接下來我們就一起去研究一下吧!

線路代号30的表示方法(C17in)1

線路代号30的表示方法

anon

類模闆參數推導

std::pair p(2, 4.5); // std::pair<int, double> std::tuple t(4, 3, 2.5); // std::tuple<int, int, double>

inline variable

// In a.hpp inline SomeType singletonVar;

每個翻譯單元都要include a.hpp,最後隻會保留一個

細化Evaluation order

a[i ] = i; // 等号右邊的現在規定會先計算完成 /* a.b a->b a->*b a(b1, b2, b3) b @= a a[b] a << b a >> b 現在都會a, b, c, d順序計算 */

guaranteed copy elision

std::mutex a_mutex; std::lock_guard<std::mutex> get_lock { return std::lock_guard<std::mutex>(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<int, int> m; auto [iter, ok] = m.insert({1, 2}); // insert返回pair<Iterator, bool>

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

template<typename ... Ts> void f(Ts ... args) { if constexpr(sizeof... (args) > 0) f1(args..); else f1(default_arg); }

Fold 表達式

template<typename ... Ts> constexpr int sum(Ts... args) { return ( 0 ... args ); // = ( (0 arg0) arg1 ) arg2 ... } static_assert(10 == sum(2, 3, 5)); // static_assert可以沒有信息了

模闆非類型參數auto

template<auto C> struct Size { static const size_t size = sizeof(C); }; static_assert(Size<3>::size == sizeof(3)); static_assert(Size<(void*)0>::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 { }; template< class T > struct has_type_member<T, std::void_t<typename T::type>> : std::true_type { };

{variant/optional/any}

optional<const char*> get_foo { if (...) return some_msg; else return {}; } std::cout << get_foo.value_or("Not found!");

variant<int, float> v, w; v = 12; int i = get<int>(v); w = get<int>(v); w = get<0>(v); // 同上 w = v; // 同上 get<double>(v); // ill formed

<algorithm>改進

std::sort(std::execution::par, std::begin(v), std::end(v)); // 并行版 std::vector<int> 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 << it->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<int, string> src {{1,"one"}, {2,"two"}, {3,"buckle my shoe"}}; map<int, string> dst {{3,"three"}}; dst.insert( src.extract( src.find(1) ) ); dst.insert( src.extract(2) );

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
原神肯德基聯動外網評價
原神肯德基聯動外網評價
原神和肯德基聯動的“異世相遇,盡享美味”活動今天早上正式開始,很多喜歡原神的玩家紛紛選擇下單肯德基的“原神異世尋味禮”,想要擁有活動限定的【飨宴之翼】風之翼裝扮,但是很多玩家對線下門店的其他活動都表達了自己的不滿。線上活動原神和明日方舟的線...
2025-07-04
老鷹主動襲擊鳥
老鷹主動襲擊鳥
在鳥類中,鷹科猛禽是一種兇猛的肉食性鳥類,一般鳥類屬于雜食類,老鷹是以鳥、鼠和其它小型動物為食,理論上是所有其它鳥類都不敢惹鷹科,但偏偏就有兩種鳥善于欺負老鷹,分布是烏鴉和喜鵲這兩種聰明鳥類。這次有攝影師拍攝到:一隻烏鴉踩在老鷹頭上作威作福...
2025-07-04
懷孕一個月可以吃闆栗炖雞嗎
懷孕一個月可以吃闆栗炖雞嗎
做法步驟1、水發銀耳,去除雜蒂,放入碗内加清水,上籠蒸透。2、将鹌鹑蛋放入冷水鍋内煮開,撈出,浸在冷水中,剝去外殼。3、将剝好的鹌鹑蛋放入銀耳碗内,加冰糖,煮開,撇去浮沫即成。小貼士适合懷胎第九月噢~心情故事主打營養素是膳食纖維,可防止便秘...
2025-07-04
jmp例子
jmp例子
jmp例子?JMP是什麼?它能夠做什麼?什麼是JMP?JMP是一個強的,視圖操作的數據統計分析軟件JMP有非常好制圖能力,以及其他數據處理和分析能力,比SAS和RS/1更容易學習和使用JMP視圖操作統計分析軟體系統,可使用Windows應用...
2025-07-04
excel怎麼快速合并每一行單元格
excel怎麼快速合并每一行單元格
【溫馨提示】親愛的朋友,閱讀之前請您點擊【關注】,您的支持将是我最大的動力!我們都知道,在Excel中合并單元格是個非常鬧心的事,合并單元格後進行數據篩選、求和之類操作計算時,往往會出現錯誤。但合并單元格後的表格層次分明、清晰易讀。算了,别...
2025-07-04
Copyright 2023-2025 - www.tftnews.com All Rights Reserved