• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            君子性非異也,善假于物也。

            如有恒,何須三更起,半夜眠;最怕莫,三天打魚兩天曬網(wǎng),竹籃打水一場(chǎng)空!
            posts - 31, comments - 23, trackbacks - 0, articles - 30
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
            ?1 #include? < stdio.h >
            ?2 #include? < setjmp.h >
            ?3 jmp_buf?buf;
            ?4
            ?5 static ? void ?babana()
            ?6 {
            ?7 ????printf( " in?babana()\n " );
            ?8 ????longjmp(buf, 1 );
            ?9 ????printf( " never?see?me\n " );
            10 }

            11
            12 int ?main()
            13 {
            14 ???? if (setjmp(buf))
            15 ???? {
            16 ????????printf( " back?in?main\n " );
            17 ????}

            18 ???? else
            19 ???? {
            20 ????????printf( " first?time?through\n " );
            21 ????????babana();
            22 ????}

            23 ???? return ? 0 ;
            24 }
            ?setjmp()首先被調(diào)用,并且返回0.
            goto是不能跳出當(dāng)前函數(shù)的,而longjmp甚至可以跳到其他文件的函數(shù)中去(估計(jì)就是為什么要在名字里加個(gè)long的原因吧,:)).
            但 longjmp只能跳回到曾經(jīng)去過的地方,而setjmp正是標(biāo)記到過的地方,所以從這角度來想的話,longjmp更像是"從何處來"而不是goto"去哪里".

            這也可以所就是C++中" catch "," throw "?的一個(gè)起源吧.

            Feedback

            # re: C中的跳轉(zhuǎn)語句[非goto]  回復(fù)  更多評(píng)論   

            2006-11-06 10:54 by 藍(lán)色feel's Blog
            沒有用過
            但是跨函數(shù)的跳轉(zhuǎn)會(huì)不會(huì)出問題呢
            棧上東西怎么辦?

            # re: C中的跳轉(zhuǎn)語句[非goto]  回復(fù)  更多評(píng)論   

            2006-11-06 11:18 by shaohua
            to:@藍(lán)色feel's Blog
            不會(huì)出問題的;
            這個(gè)只是用于跳轉(zhuǎn)的,棧上的數(shù)據(jù)當(dāng)然就是離開后被銷毀了啊,沒有辦法做保存的.

            # re: C中的跳轉(zhuǎn)語句[非goto]  回復(fù)  更多評(píng)論   

            2006-11-07 10:37 by 藍(lán)色feel's Blog

            嗯,剛才實(shí)驗(yàn)了一下,此話只對(duì)了一半
            確實(shí)是被銷毀了,但是沒有調(diào)用析構(gòu)函數(shù)
            而C++中 throw catch 是能夠?qū)I系膶?duì)象正確析構(gòu)的

            #include <iostream>
            #include <stdio.h>
            #include <setjmp.h>

            jmp_buf buf;

            class Foo
            {
            public:
            Foo() { std::cout << "Ctor" << std::endl; }
            ~Foo(){ std::cout << "Dtor" << std::endl; }
            };

            static void babana()
            {
            Foo foo;
            printf( " in babana()\n " );
            longjmp(buf, 1 );
            printf( " never see me\n " );
            }


            int main()
            {
            if (setjmp(buf))
            {
            printf( " back in main\n " );
            }
            else
            {
            printf( " first time through\n " );
            babana();
            }
            return 0;
            }

            # re: C中的跳轉(zhuǎn)語句[非goto]  回復(fù)  更多評(píng)論   

            2006-11-07 10:47 by shaohua
            to:@藍(lán)色feel's Blog
            的確正如你說的那樣的,但我們平常一般都不會(huì)顯式地去釋放棧上的內(nèi)存的,如果一定要這樣做的話也是沒有錯(cuò)的,但其實(shí)沒有多大的必要的,因?yàn)橄到y(tǒng)自己會(huì)對(duì)棧進(jìn)行很好的管理的.
            国产成人精品免费久久久久| 久久伊人精品青青草原高清| 伊人久久大香线蕉亚洲| 久久国产免费观看精品3| 伊人丁香狠狠色综合久久| 色播久久人人爽人人爽人人片AV| 久久亚洲日韩精品一区二区三区| segui久久国产精品| 亚洲国产精品高清久久久| 久久久久无码中| 91精品国产91久久综合| 伊人色综合九久久天天蜜桃| 九九久久99综合一区二区| 偷偷做久久久久网站| 久久艹国产| 久久国产精品久久久| 新狼窝色AV性久久久久久| 伊人热热久久原色播放www| 亚洲国产精品一区二区久久| 少妇人妻88久久中文字幕| 天天做夜夜做久久做狠狠| 嫩草影院久久国产精品| 99久久中文字幕| 久久A级毛片免费观看| 人妻无码精品久久亚瑟影视 | 久久笫一福利免费导航 | 97精品国产97久久久久久免费| 精品无码久久久久久久久久 | 亚洲精品高清国产一线久久| 色天使久久综合网天天| 久久久久国产精品三级网| 精品久久久久久久久久久久久久久| 69SEX久久精品国产麻豆| 久久精品a亚洲国产v高清不卡| 久久精品中文騷妇女内射| 99精品国产综合久久久久五月天 | AA级片免费看视频久久| 一本色道久久88加勒比—综合| 久久国产免费观看精品| 国内精品久久久久久久久| 国产69精品久久久久99尤物|