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

S.l.e!ep.¢%

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

檢測Lua腳本中的死循環(huán)

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

檢測Lua腳本中的死循環(huán)

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

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

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

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

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

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

run_user_script用來執(zhí)行用戶腳本,它首先通過GetTickCount把當前的時間記錄到g_begin中去。然后將g_counter加一,在執(zhí)行完用戶腳本后再將其加一,這樣就可以保證執(zhí)行用戶腳本時它是個奇數(shù),而不執(zhí)行時是偶數(shù),檢測腳本超時的代碼可以籍此來判斷當前是否在執(zhí)行用戶腳本。還要注意調(diào)用用戶腳本要使用lua_pcall而不是lua_call,因為我們中止腳本的執(zhí)行會產(chǎn)生一個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用來檢測腳本超時,需要在另外一個線程中周期性的調(diào)用,原因我想就不用解釋了吧。它首先檢查是否在執(zhí)行用戶腳本,或者是否已經(jīng)讓當前執(zhí)行的用戶腳本中止過。然后看這段腳本執(zhí)行了多長時間,超過限度就把當前腳本計數(shù)記錄到g_check中去,并通過lua_sethook設置一個鉤子函數(shù)timeout_break,這個鉤子函數(shù)會在用戶腳本執(zhí)行時被調(diào)用。

?1?void?check_script_timeout()
?2?{
?3?????long?counter?=?g_counter;
?4??
?5?????//?沒有執(zhí)行用戶腳本,?不檢查超時
?6?????if(?(counter?&?0x00000001)?==?0?)
?7?????????return;
?8??
?9?????//?已經(jīng)讓當前執(zhí)行的用戶腳本中止了
10?????if(?g_check?==?counter?)
11?????????return;
12??
13?????//?如果執(zhí)行時間超過了設置的超時時間(這里是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?}

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

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

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

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩三级一区二区| 亚洲自拍都市欧美小说| 亚洲一区二区三区影院| 亚洲精品三级| 久久精品av麻豆的观看方式| 亚洲一区二区在线看| 嫩草影视亚洲| 欧美mv日韩mv国产网站| 国产专区精品视频| 亚洲综合电影一区二区三区| 99在线热播精品免费99热| 久久久久久一区二区三区| 久久精品99国产精品酒店日本| 久久精品国产一区二区三区免费看| 欧美色精品天天在线观看视频| 亚洲激情啪啪| 亚洲黄色成人| 嫩草影视亚洲| 亚洲黄色三级| 宅男噜噜噜66一区二区66| 欧美国产亚洲另类动漫| 亚洲电影第三页| 91久久久久久国产精品| 猛男gaygay欧美视频| 欧美成人精品激情在线观看 | 欧美a级大片| 欧美成人tv| 最新国产成人在线观看| 欧美xxxx在线观看| 91久久综合| 亚洲天堂av在线免费观看| 欧美性猛交xxxx乱大交退制版| 亚洲美女在线视频| 亚洲综合好骚| 国产欧美日韩激情| 欧美伊人久久| 欧美阿v一级看视频| 亚洲激情自拍| 欧美午夜精品久久久久久孕妇 | 一本色道久久综合亚洲精品按摩| 欧美第一黄网免费网站| 亚洲日本中文字幕| 在线视频你懂得一区二区三区| 欧美色道久久88综合亚洲精品| 亚洲图中文字幕| 久久精品一区四区| 亚洲激情一区二区| 欧美日韩免费观看一区=区三区| 在线中文字幕一区| 久久精品国产亚洲5555| 亚洲第一毛片| 欧美午夜激情视频| 欧美亚洲综合久久| 欧美国产视频在线观看| 在线视频欧美一区| 国产一区二区三区观看| 免费日韩一区二区| 亚洲一区二区免费| 欧美成人免费网站| 亚洲一区二区三区精品在线观看| 国产日韩欧美一区二区| 麻豆精品视频在线| 一区二区三区日韩精品视频| 久久影音先锋| 亚洲图片欧洲图片日韩av| 国产午夜精品一区二区三区欧美| 免费国产自线拍一欧美视频| 一区二区三区你懂的| 男女激情久久| 亚洲男人第一网站| 亚洲三级网站| 国内精品国语自产拍在线观看| 欧美欧美在线| 久久亚洲欧美国产精品乐播| 中日韩美女免费视频网址在线观看 | 久久一区中文字幕| 亚洲午夜激情| 亚洲第一久久影院| 国产精品系列在线| 欧美连裤袜在线视频| 欧美在线观看一二区| 日韩天堂av| 亚洲成色999久久网站| 久久精品国产99国产精品| 日韩一区二区免费高清| 在线观看欧美视频| 国产欧美一区二区视频| 欧美日产一区二区三区在线观看 | 欧美三级在线视频| 免费欧美高清视频| 久久精品国产2020观看福利| 亚洲无玛一区| 一区二区成人精品 | 狠狠色狠色综合曰曰| 欧美日韩在线高清| 欧美国产成人精品| 麻豆成人综合网| 久久久久一区二区三区| 欧美一区综合| 久久aⅴ国产紧身牛仔裤| 亚洲欧美国产精品专区久久| 亚洲免费观看高清在线观看| 91久久黄色| 亚洲人成网在线播放| 亚洲第一页在线| 欧美激情精品久久久久久蜜臀| 久热精品在线| 麻豆国产精品一区二区三区 | 亚洲女同精品视频| 亚洲天堂网在线观看| 中文日韩欧美| 亚洲免费网址| 欧美一区二区免费| 欧美在线视频播放| 久久日韩粉嫩一区二区三区| 久久国产手机看片| 久久久精品一区二区三区| 久久国产精品第一页| 久久国产精品99久久久久久老狼 | 牛夜精品久久久久久久99黑人 | 亚洲国产日日夜夜| 亚洲国产精品成人va在线观看| 亚洲福利久久| 9色porny自拍视频一区二区| 这里只有精品电影| 欧美在线视频a| 老司机免费视频一区二区| 欧美激情第一页xxx| 欧美日韩亚洲一区在线观看| 国产精品剧情在线亚洲| 国产亚洲欧美激情| 樱花yy私人影院亚洲| 亚洲人成77777在线观看网| 99视频有精品| 欧美一区二区大片| 猛男gaygay欧美视频| 亚洲人www| 亚洲欧美文学| 久久字幕精品一区| 欧美天天在线| 国内一区二区三区在线视频| 亚洲电影专区| 亚洲免费一在线| 欧美高清在线一区二区| av成人免费| 久久精品国产久精国产一老狼| 老司机免费视频一区二区| 欧美无砖砖区免费| 伊人一区二区三区久久精品| 一区二区三区国产盗摄| 久久久久久精| 99精品视频网| 久久婷婷人人澡人人喊人人爽| 欧美日韩亚洲另类| 伊人久久大香线蕉综合热线 | 久久九九免费| 日韩视频永久免费| 欧美一区二区三区视频在线观看 | 久久九九精品99国产精品| 欧美金8天国| 伊人久久噜噜噜躁狠狠躁| 一本色道久久综合亚洲精品高清 | 在线亚洲免费| 免费亚洲一区| 国产在线精品一区二区中文| 一区二区三区**美女毛片 | 久久都是精品| 妖精视频成人观看www| 久久综合99re88久久爱| 国产嫩草影院久久久久| 99av国产精品欲麻豆| 免费欧美日韩| 欧美中文字幕在线播放| 国产精品一级二级三级| 一区二区高清在线观看| 欧美成人dvd在线视频| 午夜久久久久久久久久一区二区| 欧美日韩精品综合| 亚洲国产欧美一区二区三区丁香婷| 亚洲欧美影院| 亚洲视频自拍偷拍| 国产精品a久久久久久| 日韩一二三在线视频播| 欧美a级一区二区| 久久青青草综合| 激情婷婷亚洲| 久久婷婷国产麻豆91天堂| 亚洲欧美日韩综合| 国产精品自拍一区| 欧美在线视频免费观看| 亚洲综合电影| 国产日韩欧美在线播放| 欧美一区2区三区4区公司二百| 一本久道久久综合狠狠爱| 欧美精品一线| 亚洲一区二区视频在线观看| 99re热精品| 欧美午夜精品久久久| 亚洲欧美制服另类日韩| 亚洲私拍自拍|