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

S.l.e!ep.¢%

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

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

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

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

評(píng)論請(qǐng)移步:http://zbm.xuanwo.tk/2011/05/lua-deadloop.html

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

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

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

以下是幾個(gè)相關(guān)的全局變量(我是喜歡把C++當(dāng)C用的程序員,C++的忠實(shí)粉絲請(qǐng)忍耐一下:))的定義。

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

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

?1?void?check_script_timeout()
?2?{
?3?????long?counter?=?g_counter;
?4??
?5?????//?沒有執(zhí)行用戶腳本,?不檢查超時(shí)
?6?????if(?(counter?&?0x00000001)?==?0?)
?7?????????return;
?8??
?9?????//?已經(jīng)讓當(dāng)前執(zhí)行的用戶腳本中止了
10?????if(?g_check?==?counter?)
11?????????return;
12??
13?????//?如果執(zhí)行時(shí)間超過了設(shè)置的超時(shí)時(shí)間(這里是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è)鉤子函數(shù)了,它首先把鉤子去掉,因?yàn)檫@個(gè)鉤子只要執(zhí)行一次就行了。由于設(shè)置鉤子和執(zhí)行鉤子是在不同的線程中,并且鉤子從設(shè)置到執(zhí)行需要一定的時(shí)間,所以它要通過對(duì)比g_check和g_counter來判斷是否還在運(yùn)行判斷超時(shí)所執(zhí)行的那段腳本,不是就什么也不做,是就通過luaL_error產(chǎn)生一個(gè)錯(cuò)誤,并中止腳本的執(zhí)行,而這個(gè)錯(cuò)誤最終會(huì)被run_user_script中的lua_pcall捕獲。

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

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

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品裸体| 国产精品乱码| 狠狠色综合色区| 国内外成人在线| 欧美激情中文字幕一区二区| 欧美日本韩国一区二区三区| 欧美专区在线观看一区| 你懂的国产精品| 欧美在线free| 欧美精品免费播放| 久久精品首页| 欧美日韩亚洲视频| 开元免费观看欧美电视剧网站| 欧美国产高潮xxxx1819| 久久国产精品黑丝| 欧美日本亚洲视频| 久久婷婷成人综合色| 欧美精品一区三区| 久久蜜臀精品av| 国产精品www994| 亚洲高清视频在线| 国产色产综合产在线视频| 亚洲日本欧美天堂| 依依成人综合视频| 亚洲欧美日韩一区在线| 一区二区三区四区五区精品| 久久久久欧美| 欧美亚洲免费高清在线观看| 欧美日韩免费一区二区三区| 欧美成人午夜77777| 国产亚洲成av人片在线观看桃| 亚洲激情不卡| 亚洲高清不卡在线| 久久久久欧美精品| 久久嫩草精品久久久精品| 国产精品一区二区三区观看| 亚洲国产另类久久久精品极度| 狠狠久久婷婷| 久久国产欧美| 久久久999精品| 国产热re99久久6国产精品| 亚洲午夜精品国产| 亚洲一区尤物| 欧美日韩精品久久久| 亚洲国产精品嫩草影院| 亚洲国产高清一区二区三区| 欧美在线观看视频一区二区| 午夜日韩在线观看| 国产精品一区二区在线观看不卡 | 欧美精品videossex性护士| 美女999久久久精品视频| 国产一级精品aaaaa看| 亚洲在线成人| 欧美午夜久久久| 一区二区久久久久| 亚洲综合色激情五月| 国产精品视频九色porn| 亚洲欧美在线网| 久久免费国产精品| 尤物在线观看一区| 亚洲丰满在线| 久久久久久欧美| 久久精品一区二区三区中文字幕 | 亚洲精品视频二区| 亚洲视频免费在线| 国产精品视频免费一区| 欧美在线影院| 亚洲福利视频专区| 在线视频亚洲一区| 欧美日韩国产限制| 亚洲欧美日韩精品久久久久| 久久久之久亚州精品露出| 亚洲国产欧美一区二区三区丁香婷| 欧美激情aaaa| 亚洲亚洲精品在线观看| 久久亚洲精品一区二区| 日韩视频一区二区| 国产精品久久精品日日| 久久久久9999亚洲精品| 亚洲人久久久| 久久精品国产精品亚洲| 亚洲精品男同| 国产一区二区| 欧美日韩一二三四五区| 久久av在线| 99视频精品全部免费在线| 久久婷婷丁香| 亚洲一区亚洲二区| 亚洲欧洲日本国产| 国产精品夜夜夜| 欧美成人日本| 欧美在线免费观看亚洲| 亚洲人成在线观看一区二区| 欧美在线视频播放| 日韩视频三区| 伊人久久av导航| 欧美日韩一区二区三区四区五区| 欧美在线亚洲一区| 一本色道久久综合亚洲精品小说 | 国产精品日韩在线观看| 免费看成人av| 欧美在线观看www| 一本久久综合亚洲鲁鲁| 欧美xxx成人| 欧美在线91| 亚洲午夜伦理| 亚洲精品在线三区| 伊人久久亚洲影院| 国产欧美日韩中文字幕在线| 欧美日韩喷水| 欧美成人精品三级在线观看| 欧美中文字幕久久| 亚洲欧美日韩另类| 亚洲天堂网站在线观看视频| 亚洲美女毛片| 亚洲精品久久久久| 91久久精品国产91性色| 欧美韩日亚洲| 欧美成人乱码一区二区三区| 久久午夜av| 久久男人av资源网站| 久久久久国产精品一区三寸 | 国产精品日日做人人爱| 欧美日韩不卡一区| 欧美国产丝袜视频| 欧美激情一区二区三区四区| 久久精品国产2020观看福利| 亚洲欧洲av一区二区三区久久| 欧美三级视频在线| 亚洲一区欧美一区| 亚洲一二区在线| 夜夜嗨av色综合久久久综合网| 亚洲欧洲日韩在线| 亚洲人成网站精品片在线观看 | 国产亚洲精久久久久久| 国产精品一区二区你懂得| 国产精品美女一区二区在线观看| 欧美日韩影院| 国产精品videosex极品| 国产精品福利av| 国产伦精品一区二区三区在线观看| 国产精品久久久久久久久婷婷 | 宅男66日本亚洲欧美视频| 日韩午夜在线播放| 国产精品99久久久久久宅男| 亚洲图片激情小说| 亚洲女优在线| 久久99在线观看| 久久久夜精品| 欧美激情综合网| 国产精品国产亚洲精品看不卡15 | 亚洲精品五月天| 一区二区激情| 午夜老司机精品| 久久久久久噜噜噜久久久精品| 久久夜色精品国产亚洲aⅴ| 免费观看成人鲁鲁鲁鲁鲁视频| 亚洲国内欧美| 妖精成人www高清在线观看| 亚洲一区二区三区乱码aⅴ| 欧美影院成年免费版| 久久尤物视频| 欧美三区在线观看| 国产欧美日韩视频在线观看 | 亚洲欧美偷拍卡通变态| 久久久久久穴| 欧美日韩国产在线一区| 国产欧美日韩精品一区| 在线观看日韩欧美| 亚洲性图久久| 六月丁香综合| 日韩亚洲欧美高清| 欧美怡红院视频| 欧美日韩激情小视频| 国产一区视频观看| 一二三四社区欧美黄| 久久av一区二区| 亚洲国产人成综合网站| 亚洲综合国产| 欧美精品激情在线观看| 国产伦精品一区二区三区四区免费 | 一本一本大道香蕉久在线精品| 性色av一区二区三区在线观看| 美女诱惑黄网站一区| 一区二区日韩伦理片| 久久精品99无色码中文字幕| 欧美看片网站| 精品二区视频| 午夜精品一区二区三区在线播放| 欧美成人精品影院| 亚洲欧美国产视频| 久久夜色精品国产欧美乱极品| 性做久久久久久免费观看欧美| 欧美成人国产一区二区| 国产日韩欧美成人| 亚洲图片你懂的| 欧美激情精品久久久久久久变态 | 一本大道久久a久久精二百| 久久久久国产精品麻豆ai换脸| 99精品欧美一区二区三区|