• <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>

            牽著老婆滿街逛

            嚴以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            lua_yield為什么就必須在return表達式中被調用

            轉載自: http://m.shnenglu.com/kevinlynx/archive/2010/01/17/105883.aspx

            很早前在折騰掛起LUA腳本支持時,接觸到lua_yield這個函數。lua manual中給的解釋是:

            This function should only be called as the return expression of a C function。

            而這個函數一般是在一個注冊到LUA環境中的C函數里被調用。lua_CFunction要求的原型里
            ,函數的返回值必須返回要返回到LUA腳本中的值的個數。也就是說,在一個不需要掛起的
            lua_CFunction實現里,也就是一個不需要return lua_yield(...的實現里,我應該return
            一個返回值個數。

            但是為什么調用lua_yield就必須放在return表達式里?當時很天真,沒去深究,反正發現
            不按照lua manual里說的做就是不行。而且關鍵是,lua manual就不告訴你為什么。

            最近突然就想到這個問題,決定去搞清楚這個問題。侯捷說了,源碼面前了無秘密。我甚至
            在看代碼之前,還琢磨著LUA是不是操作了堆棧(系統堆棧)之類的東西。結果隨便跟了下
            代碼真的讓我很汗顏。有時候人犯傻了真的是一個悲劇。諾簡單的一個問題會被人搞得很神
            秘:

            解釋執行調用一個注冊進LUA的lua_CFunction是在ldo.c里的luaD_precall函數里,有如下
            代碼:

                n = (*curr_func(L)->c.f)(L);  /* do the actual call */
                lua_lock(L);
                
            if (n < 0)  /* yielding? */
                  
            return PCRYIELD;
                
            else {
                  luaD_poscall(L, L
            ->top - n);
                  
            return PCRC;
                }

             

            多的我就不說了,別人注釋寫得很清楚了,注冊進去的lua_CFunction如果返回值小于0,這
            個函數就向上層返回PCRYIELD,從名字就可看出是告訴上層需要YIELD。再找到lua_yield函
            數的實現,恰好該函數就返回-1。

            要再往上層跟,會到lvm.c里luaV_execute函數,看起來應該就是虛擬機在解釋執行指令:

                  case OP_CALL: {
                    
            int b = GETARG_B(i);
                    
            int nresults = GETARG_C(i) - 1;
                    
            if (b != 0) L->top = ra+b;  /* else previous instruction set top */
                    L
            ->savedpc = pc;
                    
            switch (luaD_precall(L, ra, nresults)) {
                      
            case PCRLUA: {
                        nexeccalls
            ++;
                        
            goto reentry;  /* restart luaV_execute over new Lua function */
                      }

                      
            case PCRC: {
                        
            /* it was a C function (`precall' called it); adjust results */
                        
            if (nresults >= 0) L->top = L->ci->top;
                        
            base = L->base;
                        
            continue;

            對于PCRYIELD返回值,直接忽略處理了。


            posted on 2011-06-01 18:14 楊粼波 閱讀(799) 評論(0)  編輯 收藏 引用

            免费国产99久久久香蕉| 99久久久精品免费观看国产| 国产精品久久自在自线观看| 久久99国产亚洲高清观看首页| 久久99精品国产99久久6| 久久无码高潮喷水| 久久九九久精品国产免费直播| 久久无码人妻一区二区三区| 久久精品国产99久久丝袜| 伊人久久亚洲综合影院| 久久se精品一区精品二区国产| 亚州日韩精品专区久久久| 99久久国产亚洲高清观看2024| 日产精品久久久久久久性色 | 国产国产成人精品久久| 狠狠干狠狠久久| 久久亚洲AV无码精品色午夜麻豆 | 色综合色天天久久婷婷基地| 久久久久一级精品亚洲国产成人综合AV区| 亚州日韩精品专区久久久| 97r久久精品国产99国产精| 亚洲国产成人精品91久久久 | 国产三级精品久久| 久久久久一区二区三区| 久久久久亚洲国产| 亚洲国产成人乱码精品女人久久久不卡 | 亚洲午夜久久久影院| 少妇久久久久久久久久| 精品久久8x国产免费观看| 亚洲欧美日韩精品久久亚洲区 | 粉嫩小泬无遮挡久久久久久| 久久99热这里只频精品6| 久久福利片| 国产高潮久久免费观看| 精品国产福利久久久| 久久精品www人人爽人人| 一本久久a久久精品综合夜夜| 久久久久人妻一区二区三区vr| 国产精品久久久久久久久久影院 | 一本久久知道综合久久| 久久久久亚洲AV成人网人人网站 |