国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
C++11 lambda表達(dá)式

C++11引入了lambda表達(dá)式,使得程序員可以定義匿名函數(shù),該函數(shù)是一次性執(zhí)行的,既方便了編程,又能防止別人的訪問(wèn)。

Lambda表達(dá)式的語(yǔ)法通過(guò)下圖來(lái)介紹:

 

         這里假設(shè)我們定義了一個(gè)如上圖的lambda表達(dá)式?,F(xiàn)在來(lái)介紹途中標(biāo)有編號(hào)的各個(gè)部分是什么意思。

  1. Lambda表達(dá)式的引入標(biāo)志,在‘[]’里面可以填入‘=’或‘&’表示該lambda表達(dá)式“捕獲”(lambda表達(dá)式在一定的scope可以訪問(wèn)的數(shù)據(jù))的數(shù)據(jù)時(shí)以什么方式捕獲的,‘&’表示一引用的方式;‘=’表明以值傳遞的方式捕獲,除非專門(mén)指出。
  2. Lambda表達(dá)式的參數(shù)列表
  3. Mutable 標(biāo)識(shí)
  4. 異常標(biāo)識(shí)
  5. 返回值
  6. “函數(shù)”體,也就是lambda表達(dá)式需要進(jìn)行的實(shí)際操作

 

將上圖的代碼片段補(bǔ)充完整:

    int x = 10;

    int y = 3;

    int z ;

    z = [=]()mutable throw() -> int { int n = x + y; x = y ; y = n; return n;}();

    cout<<z<<endl;

    cout<<"x:"<<x<<"\t"<<"y:"<<y<<endl;

運(yùn)行結(jié)果為:

13

x: 10  y: 3

因?yàn)槭且灾祩鬟f的方式訪問(wèn)x,y所以x,y的值并沒(méi)有發(fā)生改變

 

現(xiàn)在我們隊(duì)lambda表達(dá)式的基本語(yǔ)法已經(jīng)有一些了解,下面來(lái)舉幾個(gè)例子。

 

 

首先這個(gè)例子說(shuō)明如何向lambda表達(dá)式里面?zhèn)鬟f參數(shù):

#include <iostream>

using namespace std;

int main()

{

   int n = [] (int x, int y) { return x + y; }(5, 4);

   cout << n << endl;

}

運(yùn)行結(jié)果為:9

通過(guò)這個(gè)例子我們可以看出,通過(guò)“函數(shù)體”后面的‘()’傳入?yún)?shù)。

 

接下來(lái)這個(gè)例子可以看出,可以像調(diào)用函數(shù)一樣使用lambda表達(dá)式,但是感覺(jué)這種方式和普通函數(shù)的定義與調(diào)用就差不多了,這里只是學(xué)習(xí)使用方式而已。

#include <iostream>

using namespace std;

int main()

{

 

   auto f = [] (int x, int y) { return x + y; };

 

   cout << f(21, 12) << endl;

}

運(yùn)行結(jié)果為:33

 

Lambda表達(dá)式與STL算法一起使用,自己寫(xiě)測(cè)試代碼的時(shí)候經(jīng)常用到排序、輸出數(shù)組什么的,通過(guò)下面列舉的幾個(gè)算法也比較方便:

#include <iostream>

#include <algorithm>

#include <ctime>

using namespace std;

 

int main()

{

    int a[10] = {0};

 

    srand(time(NULL));

    generate(a,a+10,[]()->int { return rand() % 100; });

 

    cout<<"before sort: "<<endl;

        for_each(a, a+10, [&](int i){ cout<< i <<" "; });

 

    cout<<endl;

    cout<<"After sort"<<endl;

    sort(a,a+10);

    for_each(a, a+10, [&](int i){ cout<< i <<" "; });

    return 0;

}

 

Lambda表達(dá)式的嵌套:

#include <iostream>

int main()

{

   using namespace std;

 

   int m = [](int x)

      { return [](int y) { return y * 2; }(x) + 3; }(5);

 

   cout << m << endl;

}

運(yùn)行結(jié)果:13

 

以上代碼在VC10和VC11上都能順利編譯通過(guò)。感覺(jué)lambda表達(dá)式還是比較有意思的語(yǔ)法,也是我接觸的第一個(gè)VC11擴(kuò)展。

 

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
C++Lambda表達(dá)式詳解
Lambda表達(dá)式用法超詳細(xì)整理?。?!
匿名函數(shù)Lambda認(rèn)識(shí)一下
C++ lambda的類(lèi)型
揭開(kāi)C/C++中數(shù)組形參的迷霧
他來(lái)了,他來(lái)了,C 17新特性精華都在這了
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服