C++ Coroutine簡(jiǎn)單學(xué)習(xí)教程
在C++里,一個(gè)函數(shù)如果其函數(shù)體實(shí)現(xiàn)中包含co_await、co_yield、co_return中任何一個(gè)關(guān)鍵字,那么這個(gè)函數(shù)就是一個(gè)coroutine。其中:
co_await:掛起當(dāng)前的coroutine
co_return:從當(dāng)前coroutine返回一個(gè)結(jié)果
co_yield:返回一個(gè)結(jié)果并且掛起當(dāng)前的coroutine
一個(gè)coroutine要能被編譯期識(shí)別并通過(guò)編譯,在某些情況下要自己去特化coroutine_traits。下面就一個(gè)簡(jiǎn)單的coroutine來(lái)說(shuō)一說(shuō)C++編譯器是如何修改這個(gè)coroutine的。
// 我們假定這個(gè)模板函數(shù)是一個(gè)coroutine template <typename TRet, typename … TArgs> TRet func(TArgs args…) { body; // body里至少包含了co_await、co_yield、co_return三者之一。 }
那么這個(gè)函數(shù)會(huì)被編譯器改成如下形式:
// 它會(huì)被編譯期展開(kāi)成如下形式 template <typename TRet, typename ... TArgs> TRet func(TArgs args...) { using promise_t = typename coroutine_traits<TRet, TArgs...>::promise_type; promise_t promise; auto __return__ = promise.get_return_object(); // 這個(gè)__return__會(huì)被編譯器特殊處理 co_await promise.initial_suspend(); try { // co_return expr; => promise.return_value(expr); goto final_suspend; body; // co_return; => promise.return_void(); goto final_suspend; } // co_yield expr; => co_await promise.yield_value(expr); catch (...) { promise.set_exception(std::current_exception()); } final_suspend: co_await promise.final_suspend(); }
以上是一個(gè)coroutine的基本形式。事實(shí)上看完之后會(huì)發(fā)現(xiàn),一個(gè)coroutine的關(guān)鍵主要還是和其關(guān)聯(lián)的promise。
和coroutine promise關(guān)聯(lián)的另外一個(gè)概念,叫awaitable。Awaitable可以稱(chēng)為一個(gè)可等待對(duì)象。一個(gè)awaitable對(duì)象需要實(shí)現(xiàn)3個(gè)相關(guān)函數(shù):
1、await_ready:awaitable實(shí)例是否已經(jīng)ready
2、await_suspend:掛起awaitable。該函數(shù)會(huì)傳入一個(gè)coroutine_handle類(lèi)型的參數(shù)。這是一個(gè)由編譯器生成的變量。suspend過(guò)程可以指定該coroutine何時(shí)何地以何種方式被resume。比方說(shuō)實(shí)現(xiàn)suspend函數(shù)時(shí),將coroutine_handle放到threadpool中。那么當(dāng)前的coroutine接下來(lái)就運(yùn)行在線程池指派的后臺(tái)線程中運(yùn)行了。
3、await_resume:當(dāng)coroutine重新運(yùn)行時(shí),會(huì)調(diào)用該函數(shù)。
所以要讓一個(gè)類(lèi)型能夠awaitable,有三種手段:
1、該類(lèi)型相關(guān)代碼無(wú)法修改時(shí),需要實(shí)現(xiàn):
bool await_ready(T &);
void await_suspend(T &, coroutine_handle<promise_type>);
auto await_resume(T &); auto視具體情況而定
2、該類(lèi)型相關(guān)代碼可以修改時(shí),需要增加3個(gè)成員函數(shù):
bool await_ready();
void await_suspend(coroutine_handle<promise_type> ch);
auto await_resume();
3、實(shí)現(xiàn)operator co_await操作符,返回一個(gè)可等待的代理類(lèi)型,并且實(shí)現(xiàn)了上述三個(gè)函數(shù)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
上一篇:C++ 中String 替換指定字符串的實(shí)例詳解
欄 目:C語(yǔ)言
下一篇:C++ STL入門(mén)教程(1) vector向量容器使用方法
本文標(biāo)題:C++ Coroutine簡(jiǎn)單學(xué)習(xí)教程
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1227.html
您可能感興趣的文章
- 04-02c語(yǔ)言沒(méi)有round函數(shù) round c語(yǔ)言
- 01-10深入理解C++中常見(jiàn)的關(guān)鍵字含義
- 01-10使用C++實(shí)現(xiàn)全排列算法的方法詳解
- 01-10c++中inline的用法分析
- 01-10用C++實(shí)現(xiàn)DBSCAN聚類(lèi)算法
- 01-10全排列算法的非遞歸實(shí)現(xiàn)與遞歸實(shí)現(xiàn)的方法(C++)
- 01-10C++大數(shù)模板(推薦)
- 01-10淺談C/C++中的static與extern關(guān)鍵字的使用詳解
- 01-10深入C/C++浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)方式詳解
- 01-10深入理解C/C++混合編程


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02c語(yǔ)言函數(shù)調(diào)用后清空內(nèi)存 c語(yǔ)言調(diào)用
- 04-02func函數(shù)+在C語(yǔ)言 func函數(shù)在c語(yǔ)言中
- 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)
- 04-02c語(yǔ)言用函數(shù)寫(xiě)分段 用c語(yǔ)言表示分段
- 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)
- 04-02c語(yǔ)言編寫(xiě)函數(shù)冒泡排序 c語(yǔ)言冒泡排
- 04-02c語(yǔ)言沒(méi)有round函數(shù) round c語(yǔ)言
- 04-02c語(yǔ)言分段函數(shù)怎么求 用c語(yǔ)言求分段
- 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎
- 04-02c語(yǔ)言調(diào)用函數(shù)求fibo C語(yǔ)言調(diào)用函數(shù)求
隨機(jī)閱讀
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 04-02jquery與jsp,用jquery
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 01-10delphi制作wav文件的方法
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改