青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運轉,開心的工作
簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

檢測Lua腳本中的死循環

Posted on 2011-05-13 16:32 S.l.e!ep.¢% 閱讀(1216) 評論(0)  編輯 收藏 引用 所屬分類: Lua

檢測Lua腳本中的死循環

評論請移步:http://zbm.xuanwo.tk/2011/05/lua-deadloop.html

論壇 上有人問,所以把以前做的東西拿出來秀一下。

Lua是一門小巧精致的語言,特別適用于嵌入其它的程序為它們提供腳本支持。不過腳本通常是用戶編寫的,很有可能出現死循環,雖說這是用戶的問題,但卻會造成我們的宿主程序死掉。所以檢測用戶腳本中的死循環并中止這段腳本的運行就顯得非常重要了。

可是,一個現實的問題是死循環并不好檢測,一些隱藏較深的死循環連人都很難找出來,更不用說讓機器去找了。所以實際采用的方案多是檢測腳本的執行時間,如果超過一定的限度,就認為里面有死循環,我下面的例子也是用的這種方法。

以下是幾個相關的全局變量(我是喜歡把C++當C用的程序員,C++的忠實粉絲請忍耐一下:))的定義。

1?lua_State*?g_lua?=?NULL;????????????//?lua腳本引擎
2?volatile?unsigned?g_begin?=?0;????????//?腳本開始執行的時間
3?volatile?long?g_counter?=?0;????????//?腳本執行計數,?用于判斷執行超時
4?volatile?long?g_check?=?0;???????????//?進行超時檢查時的執行計數

run_user_script用來執行用戶腳本,它首先通過GetTickCount把當前的時間記錄到g_begin中去。然后將g_counter加一,在執行完用戶腳本后再將其加一,這樣就可以保證執行用戶腳本時它是個奇數,而不執行時是偶數,檢測腳本超時的代碼可以籍此來判斷當前是否在執行用戶腳本。還要注意調用用戶腳本要使用lua_pcall而不是lua_call,因為我們中止腳本的執行會產生一個Lua中的“錯誤”,在C/C++中它是一個異常,只有用lua_pcall才能保證這個錯誤被Lua腳本引擎正確處理。

1?int?run_user_script(?int?nargs,?int?nresults,?int?errfunc?)
2?{
3?????g_begin?=?GetTickCount();
4?????_InterlockedIncrement(?&g_counter?);
5?????int?err?=?lua_pcall(?g_lua,?nargs,?nresults,?errfunc?);
6?????_InterlockedIncrement(?&g_counter?);
7?????return?err;
8?}

下面的check_script_timeout用來檢測腳本超時,需要在另外一個線程中周期性的調用,原因我想就不用解釋了吧。它首先檢查是否在執行用戶腳本,或者是否已經讓當前執行的用戶腳本中止過。然后看這段腳本執行了多長時間,超過限度就把當前腳本計數記錄到g_check中去,并通過lua_sethook設置一個鉤子函數timeout_break,這個鉤子函數會在用戶腳本執行時被調用。

?1?void?check_script_timeout()
?2?{
?3?????long?counter?=?g_counter;
?4??
?5?????//?沒有執行用戶腳本,?不檢查超時
?6?????if(?(counter?&?0x00000001)?==?0?)
?7?????????return;
?8??
?9?????//?已經讓當前執行的用戶腳本中止了
10?????if(?g_check?==?counter?)
11?????????return;
12??
13?????//?如果執行時間超過了設置的超時時間(這里是1秒),?終止它
14?????if(?GetTickCount()?-?g_begin?>?1000?)
15?????{
16?????????g_check?=?counter;
17?????????int?mask?=?LUA_MASKCALL?|?LUA_MASKRET?|?LUA_MASKLINE?|?LUA_MASKCOUNT;
18?????????lua_sethook(?g_lua,?timeout_break,?mask,?1);
19?????}
20?}

最后就是那個鉤子函數了,它首先把鉤子去掉,因為這個鉤子只要執行一次就行了。由于設置鉤子和執行鉤子是在不同的線程中,并且鉤子從設置到執行需要一定的時間,所以它要通過對比g_check和g_counter來判斷是否還在運行判斷超時所執行的那段腳本,不是就什么也不做,是就通過luaL_error產生一個錯誤,并中止腳本的執行,而這個錯誤最終會被run_user_script中的lua_pcall捕獲。

1?void?timeout_break(?lua_State*?L,?lua_Debug*?ar?)
2?{
3?????lua_sethook(?L,?NULL,?0,?0?);
4?????//?鉤子從設置到執行,?需要一段時間,?所以要檢測是否仍在執行那個超時的腳本
5?????if(?g_check?==?g_counter?)
6?????????luaL_error(?L,?"script?timeout."?);
7?}

上面的檢測使用了兩個線程,其實在一個線程中也可以做到,并且更簡單。但那樣會導致鉤子函數頻繁執行,影響效率,如果對性能沒什么要求的話,也可以采用。

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美精品一区二区三区在线播放| 亚洲精品自在久久| 亚洲动漫精品| 激情综合色丁香一区二区| 国产免费观看久久黄| 国产午夜精品在线| 在线播放日韩欧美| 亚洲人成绝费网站色www| 亚洲乱码精品一二三四区日韩在线 | 亚洲人午夜精品| 亚洲国产精品美女| 99视频有精品| 午夜精品美女自拍福到在线| 午夜亚洲激情| 欧美刺激性大交免费视频| 欧美三级精品| 狠狠色噜噜狠狠狠狠色吗综合| 欧美视频1区| 亚洲欧美日韩中文播放| 久久av资源网| 亚洲国产天堂久久综合| 亚洲一区二区三区精品动漫| 久久精品成人欧美大片古装| 欧美精品一区二区在线播放| 国产欧美日韩一区二区三区在线| 亚洲国产毛片完整版| 午夜精品在线观看| 亚洲高清免费在线| 欧美一区二区三区男人的天堂| 欧美激情第8页| 国产一区二区三区最好精华液| 亚洲精品在线观看免费| 午夜精品一区二区三区四区| 亚洲级视频在线观看免费1级| 亚洲夜晚福利在线观看| 欧美成va人片在线观看| 国产视频在线观看一区二区| 中日韩视频在线观看| 亚洲电影在线免费观看| 久久激情网站| 国产日韩精品久久| 亚洲综合日韩| 亚洲精品一区二区三区婷婷月 | 麻豆精品视频在线观看| 亚洲永久免费精品| 欧美激情中文字幕乱码免费| 黄色欧美日韩| 久久精品国产免费观看| 亚洲性线免费观看视频成熟| 欧美三级在线播放| av不卡在线看| 亚洲日本国产| 欧美国内亚洲| 亚洲精品美女在线观看播放| 免费一级欧美片在线观看| 欧美一区亚洲一区| 国产一区二区三区电影在线观看| 羞羞色国产精品| 午夜精品影院| 国产日韩欧美在线看| 欧美在线综合| 午夜久久福利| 激情成人在线视频| 老司机亚洲精品| 久久一综合视频| 亚洲黄色在线看| 亚洲国产精品精华液网站| 欧美激情在线| 午夜精品久久久久久久99水蜜桃| 亚洲天堂av电影| 国产日韩欧美二区| 久久一二三区| 中文欧美日韩| 亚洲午夜激情网站| 亚洲午夜视频在线观看| 欧美大片一区二区三区| 蜜臀久久99精品久久久画质超高清 | 99re热精品| 亚洲人成网在线播放| 欧美日韩精品欧美日韩精品| 亚洲伊人伊色伊影伊综合网| 亚洲午夜成aⅴ人片| 国产午夜亚洲精品理论片色戒| 久久久蜜桃一区二区人| 鲁大师成人一区二区三区| 亚洲精品婷婷| 这里只有精品电影| 激情欧美日韩一区| 亚洲区一区二| 国产日韩欧美综合| 欧美国产三区| 国产精品毛片在线| 免费不卡中文字幕视频| 欧美日韩久久精品| 久久亚洲不卡| 欧美天堂亚洲电影院在线观看 | 欧美精品福利| 伊人久久大香线| 99视频一区| 一区二区三区在线免费视频| 亚洲日本中文| 国内精品伊人久久久久av一坑| 91久久久久久久久| 国精品一区二区三区| 99热精品在线| 亚洲高清视频一区| 香蕉av777xxx色综合一区| 日韩一级欧洲| 美女露胸一区二区三区| 久久精品国产99| 欧美性做爰毛片| 亚洲电影免费观看高清完整版在线观看| 国产精品xxxxx| 亚洲国产一区二区三区在线播| 国产亚洲人成网站在线观看| 夜夜嗨一区二区三区| 日韩亚洲视频| 母乳一区在线观看| 蜜桃伊人久久| 国产亚洲欧美在线| 亚洲专区欧美专区| 这里只有精品视频| 欧美+亚洲+精品+三区| 久久久久免费视频| 国产精品一区二区三区成人| 亚洲美女av在线播放| 亚洲国内高清视频| 老牛影视一区二区三区| 久久久国产一区二区三区| 欧美日韩一区二区在线 | 亚洲男人第一网站| 亚洲成色www久久网站| 激情五月***国产精品| 午夜国产一区| 欧美一级日韩一级| 国产欧美日韩亚洲一区二区三区| 一区二区三区欧美激情| 夜夜嗨av一区二区三区免费区| 你懂的国产精品永久在线| 欧美91视频| 日韩写真视频在线观看| 欧美乱在线观看| 一本色道久久加勒比88综合| 亚洲一区二区三区高清| 国产精品成人免费| 亚洲伊人久久综合| 久久久成人网| 亚洲国产精品久久久久婷婷老年 | 免费精品视频| 亚洲欧洲精品一区二区三区不卡 | 欧美夜福利tv在线| 久久婷婷丁香| 亚洲国产欧美精品| 欧美极品在线观看| 9色精品在线| 性欧美大战久久久久久久久| 国产日韩欧美制服另类| 久久午夜视频| 亚洲人成在线观看一区二区| 亚洲综合国产精品| 激情国产一区二区| 欧美国产亚洲视频| 亚洲一区欧美激情| 久久午夜精品一区二区| 亚洲人成网站在线播| 欧美性jizz18性欧美| 欧美一区二区高清在线观看| 亚洲国产va精品久久久不卡综合| 在线视频亚洲欧美| 国产午夜久久久久| 欧美激情第10页| 亚洲影院一区| 亚洲国产精品一区二区第一页| 亚洲综合不卡| 亚洲日本成人| 国产日韩高清一区二区三区在线| 开元免费观看欧美电视剧网站| 亚洲精品欧美极品| 久久久综合网站| 一本色道久久综合亚洲精品婷婷| 国产欧美在线观看| 欧美日韩123| 久久久人成影片一区二区三区| 亚洲欧洲日产国产网站| 久久一区二区三区国产精品| 亚洲午夜一区二区三区| 亚洲第一中文字幕| 国产女主播在线一区二区| 欧美久久九九| 久久视频这里只有精品| 亚洲欧美另类国产| 日韩一级大片在线| 欧美激情第三页| 久久aⅴ国产紧身牛仔裤| 亚洲精品一级| 欧美在线观看网站| 久久国产日本精品| 在线视频欧美日韩| 亚洲欧洲精品天堂一级| 国产综合第一页|