www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 單片機 > 程序喵大人
[導讀]前面程序喵介紹過C++11的新特性,這篇文章介紹下C++14的新特性。 「函數(shù)返回值類型推導」 C++14對函數(shù)返回類型推導規(guī)則做了優(yōu)化,先看一段代碼: #include using namespace std; auto func(int i) { return i;} int main() { cout << func(4) << e


前面程序喵介紹過C++11的新特性" tab="innerlink" data-linktype="2" rel="nofollow">C++11的新特性,這篇文章介紹下C++14的新特性。


「函數(shù)返回值類型推導」


C++14對函數(shù)返回類型推導規(guī)則做了優(yōu)化,先看一段代碼:

#include <iostream>
using namespace std;
auto func(int i) { return i;}
int main() { cout << func(4) << endl; return 0;}

使用C++11編譯:

~/test$ g++ test.cc -std=c++11test.cc:5:16: error: ‘func’ function uses ‘auto’ type specifier without trailing return typeauto func(int i) { ^test.cc:5:16: note: deduced return type only available with -std=c++14 or -std=gnu++14

上面的代碼使用C++11是不能通過編譯的,通過編譯器輸出的信息也可以看見這個特性需要到C++14才被支持。

返回值類型推導也可以用在模板中:

#include <iostream>using namespace std;
template<typename T> auto func(T t) { return t; }
int main() { cout << func(4) << endl; cout << func(3.4) << endl; return 0;}

注意

函數(shù)內(nèi)如果有多個return語句,它們必須返回相同的類型,否則編譯失敗

auto func(bool flag) { if (flag) return 1; else return 2.3; // error}// inconsistent deduction for auto return type: ‘int’ and then ‘double’

如果return語句返回初始化列表,返回值類型推導也會失敗

auto func() { return {1, 2, 3}; // error returning initializer list}

如果函數(shù)是虛函數(shù),不能使用返回值類型推導

struct A {// error: virtual function cannot have deduced return typevirtual auto func() { return 1; }}

返回類型推導可以用在前向聲明中,但是在使用它們之前,翻譯單元中必須能夠得到函數(shù)定義

auto f(); // declared, not yet definedauto f() { return 42; } // defined, return type is int
int main() {cout << f() << endl;}

返回類型推導可以用在遞歸函數(shù)中,但是遞歸調(diào)用必須以至少一個返回語句作為先導,以便編譯器推導出返回類型。

auto sum(int i) { if (i == 1) return i; // return int else return sum(i - 1) + i; // ok}


lambda參數(shù)auto



在C++11中,lambda表達式參數(shù)需要使用具體的類型聲明:

auto f = [] (int a) { return a; }

在C++14中,對此進行優(yōu)化,lambda表達式參數(shù)可以直接是auto:

auto f = [] (auto a) { return a; };cout << f(1) << endl;cout << f(2.3f) << endl;


變量模板



C++14支持變量模板:

template<class T>constexpr T pi = T(3.1415926535897932385L);
int main() { cout << pi<int> << endl; // 3 cout << pi<double> << endl; // 3.14159 return 0;}


別名模板



C++14也支持別名模板:

template<typename T, typename U>struct A { T t; U u;};
template<typename T>using B = A<T, int>;
int main() { B<double> b; b.t = 10; b.u = 20; cout << b.t << endl; cout << b.u << endl; return 0;}

constexpr的限制



C++14相較于C++11對constexpr減少了一些限制:

C++11中constexpr函數(shù)可以使用遞歸,在C++14中可以使用局部變量和循環(huán)

constexpr int factorial(int n) { // C++14 和 C++11均可 return n <= 1 ? 1 : (n * factorial(n - 1));}

在C++14中可以這樣做:

constexpr int factorial(int n) { // C++11中不可,C++14中可以 int ret = 0; for (int i = 0; i < n; ++i) { ret += i; } return ret;}

C++11中constexpr函數(shù)必須必須把所有東西都放在一個單獨的return語句中,而constexpr則無此限制

constexpr int func(bool flag) { // C++14 和 C++11均可 return 0;}

在C++14中可以這樣:

constexpr int func(bool flag) { // C++11中不可,C++14中可以 if (flag) return 1; else return 0;}

[[deprecated]]標記



C++14中增加了deprecated標記,修飾類、變、函數(shù)等,當程序中使用到了被其修飾的代碼時,編譯時被產(chǎn)生警告,用戶提示開發(fā)者該標記修飾的內(nèi)容將來可能會被丟棄,盡量不要使用。

struct [[deprecated]] A { };
int main() { A a; return 0;}

當編譯時,會出現(xiàn)如下警告:

~/test$ g++ test.cc -std=c++14test.cc: In function ‘int main()’:test.cc:11:7: warning: ‘A’ is deprecated [-Wdeprecated-declarations] A a; ^test.cc:6:23: note: declared here struct [[deprecated]] A {

二進制字面量與整形字面量分隔符



C++14引入了二進制字面量,也引入了分隔符,防止看起來眼花哈~

int a = 0b0001'0011'1010;double b = 3.14'1234'1234'1234;

std::make_unique






我們都知道C++11中有std::make_shared,卻沒有std::make_unique,在C++14已經(jīng)改善。

struct A {};std::unique_ptr<A> ptr = std::make_unique<A>();

std::shared_timed_mutex與std::shared_lock



C++14通過std::shared_timed_mutex和std::shared_lock來實現(xiàn)讀寫鎖,保證多個線程可以同時讀,但是寫線程必須獨立運行,寫操作不可以同時和讀操作一起進行。

實現(xiàn)方式如下:

struct ThreadSafe { mutable std::shared_timed_mutex mutex_; int value_;
ThreadSafe() { value_ = 0; }
int get() const { std::shared_lock<std::shared_timed_mutex> loc(mutex_); return value_; }
void increase() { std::unique_lock<std::shared_timed_mutex> lock(mutex_); value_ += 1; }};

為什么是timed的鎖呢,因為可以帶超時時間,具體可以自行查詢相關(guān)資料哈,網(wǎng)上有很多。

std::integer_sequence



template<typename T, T... ints>void print_sequence(std::integer_sequence<T, ints...> int_seq){ std::cout << "The sequence of size " << int_seq.size() << ": "; ((std::cout << ints << ' '), ...); std::cout << '\n';}
int main() { print_sequence(std::integer_sequence<int, 9, 2, 5, 1, 9, 1, 6>{}); return 0;}
輸出:7 9 2 5 1 9 1 6

std::integer_sequence和std::tuple的配合使用:

template <std::size_t... Is, typename F, typename T>auto map_filter_tuple(F f, T& t) { return std::make_tuple(f(std::get<Is>(t))...);}
template <std::size_t... Is, typename F, typename T>auto map_filter_tuple(std::index_sequence<Is...>, F f, T& t) { return std::make_tuple(f(std::get<Is>(t))...);}
template <typename S, typename F, typename T>auto map_filter_tuple(F&& f, T& t) { return map_filter_tuple(S{}, std::forward<F>(f), t);}

std::exchange



直接看代碼吧:

int main() { std::vector<int> v; std::exchange(v, {1,2,3,4}); cout << v.size() << endl; for (int a : v) { cout << a << " "; } return 0;}

看樣子貌似和std::swap作用相同,那它倆有什么區(qū)別呢?

可以看下exchange的實現(xiàn):

template<class T, class U = T>constexpr T exchange(T& obj, U&& new_value) { T old_value = std::move(obj); obj = std::forward<U>(new_value); return old_value;}

可以看見new_value的值給了obj,而沒有對new_value賦值,這里相信您已經(jīng)知道了它和swap的區(qū)別了吧!

std::quoted



C++14引入std::quoted用于給字符串添加雙引號,直接看代碼:

int main() { string str = "hello world"; cout << str << endl; cout << std::quoted(str) << endl; return 0;}

編譯&輸出:

~/test$ g++ test.cc -std=c++14~/test$ ./a.outhello world"hello world"

關(guān)于C++14,我們今天先說到這里。

下期預告:

C++17新特性

請持續(xù)關(guān)注哈!

歡迎大家點亮在看點贊轉(zhuǎn)發(fā)~

參考鏈接

https://en.cppreference.com/w/cpp/14
https://en.cppreference.com/w/cpp/language/function#Return_type_deduction_.28since_C.2B.2B14.29
https://en.cppreference.com/w/cpp/language/lambda
https://en.cppreference.com/w/cpp/language/constexpr
https://en.cppreference.com/w/cpp/io/manip/quoted



c++11新特性,所有知識點都在這了!

你的c++團隊還在禁用異常處理嗎?

JNI編程如何巧妙獲取JNIEnv

Linux 為什么要動態(tài)鏈接?與靜態(tài)鏈接的區(qū)別是什么?

內(nèi)存對齊之格式修訂版

c++11新特性之智能指針

gcc a.c 究竟經(jīng)歷了什么?

談談程序鏈接及分段那些事


「 在看的,麻煩點一下再走~ 」


免責聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉