自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

五分鐘看懂 C++20 協(xié)程:從"回調(diào)地獄"到"天堂之路"

開發(fā)
就在程序員們快要被"回調(diào)地獄"逼瘋的時候,C++20 像一位英雄般閃亮登場了!它帶來了一件神奇的法寶 - 協(xié)程。

在C++的江湖中,有一個讓程序員們又愛又恨的"大俠" - 那就是異步編程。想想看,在沒有協(xié)程的遠(yuǎn)古時代,寫個異步代碼簡直比登天還難!程序員們不得不和回調(diào)函數(shù)這個"老頑固"打交道,寫著寫著就迷失在了層層疊疊的括號迷宮中。這種代碼看起來就像是俄羅斯套娃 ??,拆開一層還有一層,拆著拆著連自己都不知道自己在寫什么了!

但是!就在程序員們快要被"回調(diào)地獄"逼瘋的時候,C++20 像一位英雄般閃亮登場了!它帶來了一件神奇的法寶 - 協(xié)程 。有了協(xié)程,異步代碼寫起來就像在寫同步代碼一樣優(yōu)雅,就像給代碼穿上了一件華麗的禮服,讓原本雜亂無章的代碼瞬間變得賞心悅目!這簡直就是程序員界的"灰姑娘故事" ,讓丑小鴨變成了白天鵝,讓噩夢變成了美夢。

讓我們一起來探索這個充滿魔法的協(xié)程世界吧,看看它是如何讓我們的代碼變得既優(yōu)雅又高效,就像一位優(yōu)秀的魔法師,不僅能變出漂亮的花朵,還能解決實(shí)際的問題!準(zhǔn)備好了嗎?讓我們開始這段奇妙的旅程吧!

回調(diào)地獄時代的困境

在遠(yuǎn)古時代 ? ,C++還沒有協(xié)程這個法寶,程序員們想要處理異步操作時,就只能用回調(diào)函數(shù)這個"大殺器" ???

想象一下,你是一位餐廳服務(wù)員 ???,客人點(diǎn)了一份需要多步驟的復(fù)雜料理。你需要先去倉庫取食材(異步操作1),然后交給廚師烹飪(異步操作2),等菜品出鍋后還要裝盤(異步操作3),最后送到客人桌前(異步操作4)。在沒有協(xié)程的時代,這就像是你要給每個步驟都留下一張"便利貼" ??,上面寫著"等這步完成后該做什么"。

這些便利貼就是回調(diào)函數(shù)啦!每完成一步,就要看下一張便利貼,知道接下來該做什么。便利貼越貼越多,最后整個流程就變成了一個套娃游戲 ??:便利貼里面套便利貼,貼著貼著自己都暈了 ????

更慘的是,如果中途出了什么意外(比如食材壞了 ??),你還得回溯之前的所有步驟,把每個便利貼都翻出來看看要怎么處理異常情況。這簡直就像是在玩一個"記憶力挑戰(zhàn)游戲" ??,稍不注意就會漏掉某個重要步驟!

而且啊,要是你想同時處理多個訂單,那場面就更熱鬧了 ??!想象一下,你左手拿著一沓便利貼在處理第一份訂單,右手又要記錄第二份訂單的進(jìn)度,腦袋上還要平衡第三份訂單的狀態(tài)...這簡直比雜技演員還要累 ??♀?

所以說,這種代碼寫起來真是讓人欲仙欲死 ??,調(diào)試起來更是讓人抓狂 ??。程序員們每天都在想:"要是能有一種方法,讓異步代碼寫起來像同步代碼一樣簡單就好了!"

為什么不能用同步方式?

哎呀,要是真能這么簡單就好了!想象一下,如果我們用同步的方式寫代碼,那就像是餐廳服務(wù)員站在原地死等 ??♂?:去取食材時,站在倉庫門口傻等(阻塞);送去廚房后,又站在廚房門口發(fā)呆(繼續(xù)阻塞);等菜品出鍋,又呆站在那里等裝盤(還是阻塞)...這位服務(wù)員除了等就是等,什么事都干不了!??

// 同步方式的代碼示例 - 這會導(dǎo)致程序卡??!??
string processOrder() {
    // 服務(wù)員傻等食材準(zhǔn)備好 (卡住 5 秒) ??
    auto ingredients = getIngredients();  // 阻塞等待
    
    // 服務(wù)員繼續(xù)傻等廚師炒菜 (卡住 10 秒) ??
    auto dish = cook(ingredients);        // 阻塞等待
    
    // 服務(wù)員還要傻等裝盤 (卡住 3 秒) ??
    auto platedDish = plate(dish);        // 阻塞等待
    
    // 這期間服務(wù)員什么都干不了!
    // - 不能接待新客人 ??
    // - 不能收拾餐桌 ??
    // - 不能處理其他訂單 ??
    
    return platedDish;
}

更要命的是,餐廳里可不止一位客人??!如果服務(wù)員A在等第一道菜時,客人B又來點(diǎn)餐了,那這位客人是不是得餓到天荒地老??? 要是再來個客人C,那餐廳可能就要被餓壞的客人們給"掀翻"啦!??

所以啊,同步代碼就像是一位"不懂變通"的服務(wù)員 ??:

  • 取個食材要等 10 分鐘?就傻站著等 10 分鐘!
  • 廚師炒菜要等 15 分鐘?繼續(xù)傻站著等 15 分鐘!
  • 裝盤要等 5 分鐘?沒錯,還是傻站著等 5 分鐘!

這樣的服務(wù)員,怕是要把老板給"愁禿"嘍!????

而異步編程就像是一位"機(jī)智"的服務(wù)員 ??♂?:取完食材不等,先去招呼其他客人;送完菜去廚房,順便收拾一下空桌子;等裝盤的時候,還能給別的客人倒倒水...這樣的服務(wù)員,才是餐廳老板的"心頭好"?。??

但是呢,要把這種"機(jī)智"用代碼寫出來,以前只能用回調(diào)函數(shù)。這就像是給服務(wù)員發(fā)一堆"便利貼",搞得服務(wù)員口袋里塞滿了各種"待辦事項(xiàng)",最后自己都理不清楚該干啥了!??

所以啊,這就是為什么我們需要協(xié)程 ?!它讓我們能用同步的方式,寫出異步的效果。就像是給服務(wù)員配了個智能小助手 ??,幫他完美地安排所有任務(wù),該等的時候去忙別的,該回來的時候準(zhǔn)時回來,整個餐廳運(yùn)轉(zhuǎn)得那叫一個順滑~ ??

直到有一天,C++20 的協(xié)程橫空出世 ??,終于讓程序員們從回調(diào)地獄中解脫出來,重見天日 ??。這簡直就像是給程序員們發(fā)了一張通往天堂的門票!?

第一章:遠(yuǎn)古時代的困境

讓我們乘坐時光機(jī)回到過去 ??。那是一個寫異步代碼令人抓狂的年代,每個C++程序員都像是在玩一個超難的俄羅斯套娃游戲 ??。

想象一下,你正在開發(fā)一個網(wǎng)絡(luò)應(yīng)用程序。用戶點(diǎn)擊一個按鈕,你需要先從數(shù)據(jù)庫獲取數(shù)據(jù),然后發(fā)送到服務(wù)器,最后還要處理服務(wù)器的響應(yīng)。聽起來很簡單對吧?但當(dāng)你開始寫代碼的時候...噢,天哪!??

// 這是一個典型的回調(diào)地獄示例
void processUserClick() {
    // 第一層回調(diào): 從數(shù)據(jù)庫獲取數(shù)據(jù)
    // 問題1: 這里的錯誤處理只能處理數(shù)據(jù)庫錯誤,無法處理后續(xù)步驟的錯誤
    fetchFromDatabase([](DbResult dbData) {           
        // 第二層回調(diào): 將數(shù)據(jù)上傳到服務(wù)器
        // 問題2: 這時如果想要訪問外層的變量很困難,作用域被分割了
        uploadToServer(dbData, [](ServerResponse resp) {   
            // 第三層回調(diào): 處理服務(wù)器響應(yīng)
            // 問題3: 如果這里想要提前返回,必須層層往外傳遞信號
            processResponse(resp, [](FinalResult fr) {         
                // 第四層回調(diào): 更新UI
                // 問題4: 代碼縮進(jìn)已經(jīng)嚴(yán)重影響可讀性
                updateUI(fr, [](UIState state) {                   
                    if (state.hasError) {
                        // 問題5: 錯誤處理變得極其困難
                        // - 無法統(tǒng)一處理錯誤
                        // - 資源清理容易遺漏
                        // - 異常傳播路徑不清晰
                    }
                });
            });
        });
    });
}

看到這段代碼,你的眼睛是不是已經(jīng)開始斜視了??? 這就是臭名昭著的"回調(diào)地獄" ??。每個操作都需要一個回調(diào)函數(shù),回調(diào)里面還有回調(diào),就像套娃一樣越套越深。不僅如此,錯誤處理更是噩夢 ??:

  • 想在最內(nèi)層處理最外層的錯誤?對不起,變量作用域不允許!??
  • 需要在中間某層提前返回?抱歉,這里只能一層一層回調(diào)下去!??
  • 準(zhǔn)備調(diào)試代碼?祝你好運(yùn)!斷點(diǎn)打到第三層的時候你可能已經(jīng)忘記自己是誰了!??

程序員們痛苦地抓著頭發(fā):"這代碼比我奶奶的俄羅斯套娃還要套娃!?? 寫著寫著就迷失在了括號的海洋里...到底哪個花括號對應(yīng)哪個?。?

更要命的是,如果你想并行處理多個異步操作,代碼會變得更加瘋狂。這簡直就像是在玩三維魔方,同時還要倒立跳舞!????

就在程序員們快要崩潰的時候...

第二章:希望的曙光 (2017年) 

在一個陽光明媚的早晨 ??,委員會成員們正在享用他們的第三杯咖啡 ?? 時,突然靈光乍現(xiàn) ??:"嘿,伙計們!要是我們能讓異步代碼看起來像寫同步代碼一樣優(yōu)雅,那該多美妙??!"

async Task doSomethingAsync() {
    auto result = co_await startOperation();        // 優(yōu)雅得像一首詩! ?
    auto nextResult = co_await processResult(result);    // 代碼如絲般順滑~ ??
    auto finalResult = co_await finalStep(nextResult);   // 完美!就是這樣! ??
}

但就在大家開心得想要擊掌慶祝時 ??,一位戴著厚厚眼鏡的程序員突然舉手發(fā)問:"等等,我們是不是忘記了一些重要的細(xì)節(jié)?" ??

這一提醒讓房間里瞬間安靜下來。是啊,協(xié)程的狀態(tài)要往哪里存呢??? 生命周期又該如何管理呢??? 還有那個神秘的 promise_type,它到底是個什么樣的存在呢??? 這些問題就像一個個調(diào)皮的小精靈 ??♂?,在程序員們的腦海中跳來跳去,等待著被解開謎題...

第三章:艱難的探索 (2018-2019年) 

啊,那是一段令人頭禿的日子 ????! 委員會成員們像是在探索一片未知的代碼荒原,每天都在與模板元編程這個"終極 Boss"搏斗 ??。他們要設(shè)計的不僅僅是普通的代碼結(jié)構(gòu),而是一個能讓協(xié)程優(yōu)雅運(yùn)行的"魔法陣" ?:


template<typename T>
struct Task {
    struct promise_type {  // 這個神秘的 promise_type 就像是協(xié)程的"靈魂" ??
        T result;         // 存儲協(xié)程的"寶藏" ??
        
        // 創(chuàng)建協(xié)程時的"開光儀式" ???
        auto get_return_object() { return Task{handle_type::from_promise(*this)}; }
        
        // 協(xié)程的"起床氣" ??
        auto initial_suspend() { return suspend_never{}; }
        
        // 協(xié)程的"睡前禱告" ??
        auto final_suspend() noexcept { return suspend_always{}; }
        
        // 收獲勝利果實(shí)的時刻 ??
        void return_value(T value) { result = value; }
        
        // 當(dāng)一切都出錯時的"緊急按鈕" ??
        void unhandled_exception() { throw; }
    };
    // 還有一大堆讓人眼花繚亂的實(shí)現(xiàn)細(xì)節(jié),像迷宮一樣復(fù)雜 ??
};

"天吶!這簡直比解魔方還要讓人頭大!" 程序員們抱著腦袋哀嚎道 ??。每寫一行代碼都像是在解一道高數(shù)題,每調(diào)試一個問題都仿佛在破解達(dá)芬奇密碼 ??。但是為了實(shí)現(xiàn)協(xié)程這個終極夢想,大家還是咬著牙堅持了下來 ??。畢竟,偉大的作品往往都是從痛苦中誕生的,不是嗎? ??

第四章:勝利在望 (2020年) 

啊哈!經(jīng)過程序員們?nèi)杖找挂沟膴^戰(zhàn) ??,熬過了無數(shù)個被bug折磨的不眠之夜 ??,終于在2020年這個特別的年份里,C++20像一位英雄般閃亮登場 ?,帶來了我們期待已久的協(xié)程支持!

瞧瞧這段代碼,簡直美得讓人想哭 ??:

Task<int> fibonacci(int n) {
    if (n <= 2) co_return 1;  // 優(yōu)雅地返回~ ??
    auto a = co_await fibonacci(n - 1);  // 等等我哦~ ??
    auto b = co_await fibonacci(n - 2);  // 馬上就好~ ??
    co_return a + b;  // 完美收工! ??
}

看到這段代碼,程序員們激動得熱淚盈眶 ??:"這簡直就像在寫詩一樣!" 有人甚至激動地站在椅子上手舞足蹈 ??。再也不用面對那可怕的回調(diào)地獄了,再也不用被無窮無盡的括號折磨了!這段代碼寫得多么清晰,多么自然,就像在講述一個優(yōu)美的故事 ??~

就連那些以前對異步編程聞風(fēng)喪膽的新手程序員們,現(xiàn)在也能輕松駕馭協(xié)程的魔法了 ??。"這也太簡單了吧!"他們驚喜地說道,"感覺自己一下子從碼農(nóng)變成了代碼藝術(shù)家!" ??

這一刻,整個C++社區(qū)都沸騰了!論壇上、社交媒體上到處都是程序員們興奮的歡呼聲 ??。這簡直就像是編程界的嘉年華,每個人臉上都洋溢著幸福的笑容 ??。終于,異步編程不再是一場噩夢,而是變成了一次充滿樂趣的冒險!??

第五章:協(xié)程的實(shí)戰(zhàn)應(yīng)用

1. 協(xié)程的基本組件

終于到了激動人心的實(shí)戰(zhàn)環(huán)節(jié)!讓我們來認(rèn)識一下協(xié)程的三位"超級英雄" ??♂?,他們各自都有著獨(dú)特的超能力,組合起來簡直就是無敵的存在!?

首先登場的是我們的三位主角 ??:

co_await  // 等待型英雄,擅長"時間暫停" ??
co_yield  // 生產(chǎn)型英雄,負(fù)責(zé)"物資運(yùn)輸" ??
co_return // 終結(jié)型英雄,專門"畫上句點(diǎn)" ??

想象一下,當(dāng)你在寫一個網(wǎng)絡(luò)請求時,co_await 就像是一個貼心的管家 ??,它會說:"主人,您先去休息,等數(shù)據(jù)準(zhǔn)備好了我再叫您~"

Task<string> fetchUserData() {
    // 管家:主人,我去幫您取數(shù)據(jù),您先喝杯茶吧 ??
    auto response = co_await http.get("/api/user");  
    // 管家:主人,數(shù)據(jù)已經(jīng)準(zhǔn)備好啦!??
    co_return response.body();
}

而 co_yield 呢,就像是一個勤勞的小蜜蜂 ??,每次都會給你帶來一點(diǎn)甜蜜的蜂蜜:

Generator<int> range(int start, int end) {
    for(int i = start; i < end; ++i) {
        co_yield i;  // 小蜜蜂:嗡嗡~這是第i份蜂蜜,我去采下一份啦~ ??
    }
}

最后是我們的完美收場專家 co_return,就像是故事的結(jié)局一樣,畫上一個完美的句點(diǎn) ?:

Task<double> calculateAverage(vector<int> numbers) {
    if(numbers.empty()) {
        co_return 0.0;  // 空數(shù)組?那就直接說再見啦~ ??
    }
    double sum = 0;
    for(auto n : numbers) {
        sum += n;  // 一個一個加起來... ??
    }
    co_return sum / numbers.size();  // 完美收工!??
}

這三位超級英雄齊心協(xié)力 ??,讓我們的異步代碼變得既優(yōu)雅又易讀,就像在講述一個精彩的故事一樣!讓人不禁感嘆:這才是寫代碼應(yīng)該有的樣子啊~ ??

2. 協(xié)程的限制條件

不是所有函數(shù)都能變成協(xié)程哦!就像不是所有的青蛙 ?? 都能變成王子一樣,協(xié)程也有它的限制:

// ? 這些都不能是協(xié)程:
consteval auto func1() { co_return 42; }     // 不能用于 consteval 函數(shù)
constexpr auto func2() { co_return 42; }     // 不能用于 constexpr 函數(shù)
auto main() { co_return 0; }                 // main 函數(shù)不能是協(xié)程
struct S { S() { co_return; } };             // 構(gòu)造函數(shù)不能是協(xié)程
struct S { ~S() { co_return; } };            // 析構(gòu)函數(shù)不能是協(xié)程

// ? 這些可以是協(xié)程:
Task<int> func3() { co_return 42; }          // 普通函數(shù)可以
auto lambda = []() -> Task<int> {            // lambda 表達(dá)式可以
    co_return 42;
};

3. 實(shí)用的協(xié)程模式

異步操作鏈?zhǔn)秸{(diào)用 - 讓代碼如絲般順滑

Task<User> getUserInfo() {
    // 就像是在跟老朋友聊天一樣自然~ ??
    auto token = co_await auth.login();         // 先敲門說聲"您好"~ ??
    auto profile = co_await user.getProfile(token);    // 聊聊近況如何啊~ ??
    auto settings = co_await user.getSettings(token);  // 順便問問有什么新變化~ ??
    
    co_return User{profile, settings};  // 愉快地道別,期待下次相見!??
}

瞧瞧這段代碼多么優(yōu)雅~就像是在寫一個溫馨的小故事 ??!每一步都那么自然,那么流暢,完全不用擔(dān)心什么回調(diào)地獄了 ??。co_await 就像是一位貼心的管家 ??,在每個異步操作時都會說:"主人,您先去休息,等結(jié)果出來我再通知您哦~" 而 co_return 則像是故事的完美結(jié)局 ??,把所有收集到的信息打包成一份精美的禮物 ??,送給調(diào)用者~ 這哪里是在寫代碼啊,簡直就是在創(chuàng)作藝術(shù)!?

(1) 生成器模式 - 數(shù)學(xué)界的魔術(shù)師 ???

Generator<int> fibonacci() {
    int a = 0, b = 1;
    while(true) {
        co_yield a;        // 像變魔術(shù)一樣,變出一個斐波那契數(shù) ??
        auto temp = a + b; // 施展數(shù)學(xué)魔法,計算下一個數(shù) ?
        a = b;            // 像跳舞一樣,優(yōu)雅地交換數(shù)字 ??
        b = temp;         // 為下一次表演做準(zhǔn)備~ ??
    }
}

// 讓我們欣賞這場數(shù)學(xué)表演吧!
void useFibonacci() {
    auto fib = fibonacci();  // 請出我們的魔術(shù)師 ??♂?
    for(int i = 0; i < 10; ++i) {
        cout << fib() << " ";  // 一個接一個,數(shù)字像魔法一樣冒出來 ?
    }                          // 瞧:0 1 1 2 3 5 8 13 21 34 ??
}

看看這個神奇的生成器吧!它就像是一位數(shù)學(xué)魔術(shù)師 ??,每次我們喊"請變出下一個數(shù)字"的時候,它就會用 co_yield 這根魔法棒 ?,優(yōu)雅地變出一個新的斐波那契數(shù)。而且最神奇的是,它不會一次性變出所有數(shù)字,而是像變魔術(shù)一樣,等我們說"請繼續(xù)"的時候才會表演下一個 ??。這樣既省內(nèi)存又吸引眼球,簡直是編程界的魔術(shù)表演??!??

這位魔術(shù)師不會因?yàn)橛^眾不看了就繼續(xù)表演,也不會因?yàn)闀簳r休息就忘記上一個數(shù)字,它會乖乖地在那里等待,隨時準(zhǔn)備繼續(xù)它的精彩演出 ??。這就是協(xié)程生成器的魅力所在 - 它讓復(fù)雜的數(shù)學(xué)運(yùn)算變成了一場優(yōu)雅的魔術(shù)表演!?

(2) 異步流處理 ??

AsyncStream<DataPacket> processDataStream() {
    while(true) {
        auto data = co_await streamSource.readNext();
        if(data.isEmpty()) break;
        
        // 處理數(shù)據(jù)
        auto processed = co_await processData(data);
        co_yield processed;
    }
}

瞧瞧這段代碼多么優(yōu)雅啊!就像一位數(shù)據(jù)流中的沖浪高手 ??♂?,在數(shù)據(jù)的海洋中優(yōu)雅地穿梭。每當(dāng)新的數(shù)據(jù)浪潮到來,我們的沖浪手就會耐心等待(co_await)、靈活處理,然后把處理好的"浪花"優(yōu)雅地傳遞出去(co_yield) ??。這哪里是在寫代碼啊,簡直就是在跟數(shù)據(jù)跳探戈! ??

最棒的是,我們的"沖浪手"從不會被大浪嚇到 - 它會優(yōu)雅地等待每一波數(shù)據(jù),就像在海浪中漂浮的水母一樣從容自如 ??。當(dāng)數(shù)據(jù)流結(jié)束時,它也會優(yōu)雅地收工,就像夕陽西下時劃著小船返航的漁夫 ??。這種寫法不僅讓代碼清晰易懂,還讓異步處理變得如此詩意! ?

4. 性能優(yōu)化技巧

想讓你的協(xié)程像火箭一樣快嗎 ???來,讓我告訴你一些神奇的咒語!

首先,我們要學(xué)會"懶惰"的藝術(shù) ?? - 沒錯,有時候"懶"也是一種美德!通過使用 suspend_always 來實(shí)現(xiàn)懶加載,我們可以像個睡美人一樣,等到真正需要的時候才優(yōu)雅地醒來:

// 像個優(yōu)雅的睡美人 ??
auto initial_suspend() { return std::suspend_always{}; }

// 像個永不停歇的陀螺 ?? (可能會消耗更多魔法值哦)
auto initial_suspend() { return std::suspend_never{}; }

接下來,讓我們變身成為內(nèi)存管理大師 ???!通過自定義 promise_type,我們可以像變魔術(shù)一樣完美控制內(nèi)存的分配和釋放:

struct Task {
    struct promise_type {
        // 施展內(nèi)存分配魔法 ??
        void* operator new(size_t size) {
            return customAllocator.allocate(size); // 變出一塊完美的內(nèi)存空間 ?
        }
        
        // 優(yōu)雅地清理魔法現(xiàn)場 ??
        void operator delete(void* ptr, size_t size) {
            customAllocator.deallocate(ptr, size); // 讓內(nèi)存重歸自然 ??
        }
    };
};

記住,優(yōu)化就像在魔法花園里培育珍貴的花朵 ?? - 需要耐心和智慧。不要急著摘取果實(shí),讓它們自然生長,在合適的時候綻放出最美的姿態(tài)。這樣,你的協(xié)程就會像精靈一樣輕盈,像鳳凰一樣優(yōu)雅,在代碼的世界里翱翔!??♀??

結(jié)語:未來可期

雖然協(xié)程之路充滿坎坷,但它確實(shí)讓我們的異步編程變得更加優(yōu)雅和直觀了!就像一位智者說的:

"協(xié)程就像是給異步編程穿上了同步的外衣,讓復(fù)雜的事情變得簡單!"

記住,親愛的程序員,我們的征程才剛剛開始!讓我們繼續(xù)在協(xié)程的海洋中探索吧!???

責(zé)任編輯:趙寧寧 來源: everystep
相關(guān)推薦

2023-11-04 20:00:02

C++20協(xié)程

2020-12-17 10:00:16

Python協(xié)程線程

2024-12-17 08:10:00

C++20LambdaC++

2023-09-03 19:13:29

AndroidKotlin

2020-11-10 09:01:52

DPDK網(wǎng)絡(luò)監(jiān)控

2021-11-08 18:37:45

MySQL解碼測試

2009-11-17 14:50:50

Oracle調(diào)優(yōu)

2009-11-06 16:05:37

WCF回調(diào)契約

2022-09-06 20:30:48

協(xié)程Context主線程

2024-10-25 15:56:20

2021-11-01 09:54:45

互聯(lián)網(wǎng)安全協(xié)議IPSec網(wǎng)絡(luò)協(xié)議

2018-06-26 09:37:07

時序數(shù)據(jù)庫FacebookNoSQL

2021-06-06 13:08:22

C#特性Attribute

2022-09-12 06:35:00

C++協(xié)程協(xié)程狀態(tài)

2021-04-23 09:50:41

topLinux命令

2020-09-14 11:30:26

HTTP3運(yùn)維互聯(lián)網(wǎng)

2013-09-17 09:49:29

程序集讀懂程序編程

2016-09-13 20:58:41

MySQ基礎(chǔ)入門Sql

2022-09-30 15:46:26

Babel編譯器插件

2016-08-03 16:01:47

GitLinux開源
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號