青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
金慶的專欄
C++博客
::
首頁
::
新隨筆
::
聯系
::
聚合
::
管理
::
423 隨筆 :: 0 文章 :: 454 評論 :: 0 Trackbacks
公告
我的隨筆
我的評論
我參與的隨筆
留言簿
(12)
給我留言
查看公開留言
查看私人留言
隨筆分類
(502)
1. C/C++(166)
(rss)
2. 網游開發(108)
(rss)
3. Golang(20)
(rss)
4. Linux/Unix(30)
(rss)
5. 軟工與管理(44)
(rss)
6. Python(23)
(rss)
7. Erlang(18)
(rss)
8. Rust(16)
(rss)
9. 其它(77)
(rss)
隨筆檔案
(423)
2023年1月 (1)
2022年11月 (1)
2022年10月 (2)
2022年9月 (1)
2022年4月 (6)
2022年1月 (2)
2021年12月 (4)
2021年11月 (6)
2021年10月 (2)
2021年9月 (2)
2021年8月 (7)
2021年7月 (2)
2021年5月 (2)
2021年3月 (1)
2021年2月 (2)
2021年1月 (1)
2020年12月 (1)
2020年10月 (1)
2020年9月 (5)
2020年8月 (1)
2020年7月 (1)
2020年6月 (1)
2020年4月 (2)
2020年3月 (3)
2020年2月 (3)
2020年1月 (1)
2019年12月 (1)
2019年9月 (2)
2019年4月 (2)
2019年1月 (1)
2018年12月 (1)
2018年11月 (3)
2018年10月 (1)
2018年9月 (3)
2018年8月 (3)
2018年7月 (2)
2018年6月 (4)
2018年5月 (4)
2018年4月 (4)
2018年3月 (1)
2018年1月 (2)
2017年12月 (2)
2017年11月 (3)
2017年10月 (3)
2017年8月 (7)
2017年7月 (1)
2017年6月 (1)
2017年5月 (3)
2017年4月 (3)
2017年3月 (3)
2017年2月 (2)
2017年1月 (2)
2016年12月 (5)
2016年11月 (2)
2016年10月 (2)
2016年9月 (1)
2016年8月 (6)
2016年7月 (3)
2016年6月 (2)
2016年5月 (4)
2016年4月 (2)
2016年3月 (2)
2016年1月 (3)
2015年12月 (2)
2015年11月 (2)
2015年10月 (1)
2015年8月 (2)
2015年7月 (1)
2015年6月 (1)
2015年5月 (4)
2015年4月 (3)
2015年3月 (4)
2015年2月 (5)
2015年1月 (4)
2014年12月 (3)
2014年11月 (3)
2014年10月 (2)
2014年9月 (3)
2014年8月 (1)
2014年4月 (4)
2014年3月 (1)
2014年2月 (4)
2014年1月 (5)
2013年12月 (5)
2013年11月 (5)
2013年9月 (2)
2013年8月 (2)
2013年7月 (2)
2013年6月 (2)
2013年5月 (1)
2013年1月 (2)
2012年12月 (1)
2012年11月 (1)
2012年9月 (1)
2012年8月 (3)
2012年7月 (2)
2012年6月 (1)
2012年4月 (3)
2012年3月 (2)
2012年2月 (3)
2012年1月 (2)
2011年11月 (2)
2011年10月 (3)
2011年9月 (2)
2011年8月 (2)
2011年7月 (3)
2011年6月 (2)
2011年5月 (3)
2011年1月 (2)
2010年12月 (1)
2010年11月 (2)
2010年10月 (2)
2010年9月 (3)
2010年8月 (2)
2010年7月 (3)
2010年6月 (1)
2010年5月 (3)
2010年4月 (3)
2010年3月 (5)
2010年2月 (4)
2010年1月 (4)
2009年12月 (2)
2009年11月 (3)
2009年10月 (4)
2009年9月 (3)
2009年8月 (2)
2009年7月 (4)
2009年6月 (1)
2009年5月 (3)
2009年4月 (4)
2009年3月 (2)
2009年2月 (5)
2009年1月 (1)
2008年12月 (7)
2008年11月 (4)
2008年10月 (1)
2008年9月 (3)
2008年8月 (4)
2008年7月 (3)
2008年6月 (4)
2008年5月 (6)
2008年4月 (7)
2008年3月 (6)
2008年1月 (5)
2007年12月 (7)
2007年11月 (4)
2007年10月 (5)
2007年9月 (6)
2007年8月 (8)
2007年7月 (5)
相冊
公告照片
搜索
積分與排名
積分 - 660013
排名 - 25
最新評論
1.?re: boost::asio::spawn 將一統C++網絡庫
asio 成為C++首選網絡庫
--linda
2.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--金慶
3.?re: mingw編譯OrzNet
能發送一個mingw編譯好的OrzNet庫給我嗎? liuweiqcxy@163.com
謝謝!
--劉威
4.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--bigbad
5.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--bigbad
閱讀排行榜
1.?"multiple definition of" 錯誤(11061)
2.?SVN中邪惡的replace(10986)
3.?VS2005編譯libevent(10434)
4.?混音算法的學習與研究(10239)
5.?C調用lua腳本的效率測試(9020)
評論排行榜
1.?VC6正在被拋棄(35)
2.?VS2005編譯libevent(21)
3.?"multiple definition of" 錯誤(18)
4.?C++引用優于指針(17)
5.?ACE與ASIO之間關于Socket編程的比較(16)
lua變量缺少local造成unity死鎖
# lua變量缺少local造成unity死鎖
(金慶的專欄 2020.9.1)
這幾天在開發 grpc-tolua, 可以在 unity 項目中使用 lua 發送 grpc 請求,無需生成代碼.
現已實現 route_guide 示例中的全部4種rpc.
見:https://github.com/jinq0123/grpc-tolua
昨天的開發中就發現,運行 RecordRoute 和 RouteChat 之后Unity無法再次運行,必須殺進程。
在 await 語句添加 `ConfigureAwait(false)` 之后,好像 RouteChat 修復了,但 RecoreRoute 依舊。
ConfigureAwait(false) 保證了 await 之后不會搶占主線程,是解決死鎖的一種方法。
grpc 源碼中的 await 同樣都跟著這句。
今天再次測試,發現 RouteChat 并未真正修復,仍有較大可能卡死。
最初的猜想是 Lua 協程,C# 異步造成線程死鎖,因為對異步不熟,總是懷疑使用有誤。
后來轉變為查找讓 Unity 卡死的阻塞式操作,但是因為日志顯示不全,找遍代碼都沒結果。
除了在自己的代碼中查找錯誤,還在 tolua 代碼,grpc 代碼中查找,到處懷疑。
今天一整天都在添加日志,重啟Unity中度過。提出各種猜想,又反復驗證。
依次采用了以下方法:
* 比較C# route_guide 代碼,查找區別
* 為什么是 client streaming 類型的 rpc 有錯
* 查看 tolua 協程,Timer
* 添加 Delay, 更改協程的運行次序,提高或降低復現幾率
* 函數入口和返回添加日志,證明其沒有阻塞
查找錯誤的方法是在代碼中添加日志,找到異常之處。
最終的現象是Unity沒有Update()調用了,全部卡死。
錯誤源代碼是這樣的,錯誤版本中 awaiter 前面沒有 local.
```lua
local function await(awaitable)
local awaiter = awaitable:GetAwaiter()
coroutine.wait_until(function()
return awaiter.IsCompleted
end)
end
```
因為想實現一個特殊版本的 await() 用于測試, 把 awaiter.IsCompleted 改為總是 false。
復制代碼時,發現了變量缺少 local.
如果這個成為全局變量,第2次函數調用就會更改第1次調用的變量,我立刻意識到了這就是死鎖的原因。
添加 local 之后測試,一切都正常了。
分析結果是因為 awaiter 更改后,await() 在任務完成前就返回了,
以致于后面的讀取成為阻塞式操作,阻塞了主線程。
查錯效率低的主要問題是 Unity 日志在卡死前的日志沒有顯示,這一點直到最后死鎖復盤時才發覺。
因為日志缺失,根據日志得出的所有判斷幾乎都錯了。
本來可以根據日志快速定位的原因,現在完全找錯方向。
如果有工具警告全局變量,就可以避免這個錯誤。
Unity Profiler, VS Debugger 因為 Unity 完全卡死,所以沒什么幫助。
posted on 2020-09-02 13:37
金慶
閱讀(426)
評論(0)
編輯
收藏
引用
所屬分類:
2. 網游開發
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
How are dtLinks created in NavMesh
UE4 Blueprint Multiple Event BeginPlay
第9代游戲主機
Canvas Scaler 的3種模式
幀同步是否允許客戶端指定命令幀號
rpc應答太快造成請求超時
測試 tolua 例子 TestErrorStack
lua變量缺少local造成unity死鎖
C# tolua 之間互傳 byte[]
Unity使用異步grpc
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
在线中文字幕不卡
|
亚洲欧美日韩区
|
亚洲欧洲精品一区二区精品久久久
|
亚洲精品美女在线观看播放
|
亚洲综合久久久久
|
欧美高清视频一区二区
|
在线视频欧美精品
|
欧美成人精品影院
|
国产亚洲一区二区在线观看
|
9久草视频在线视频精品
|
牛人盗摄一区二区三区视频
|
麻豆av一区二区三区
|
国产欧美精品国产国产专区
|
亚洲美女精品一区
|
蜜臀av一级做a爰片久久
|
亚洲一区欧美激情
|
欧美日韩1234
|
亚洲精品久久久久久久久
|
亚洲日本电影
|
欧美国产91
|
亚洲黄色在线看
|
免费在线欧美黄色
|
久久免费99精品久久久久久
|
国产一级揄自揄精品视频
|
美女视频黄a大片欧美
|
欧美黑人国产人伦爽爽爽
|
亚洲欧美精品伊人久久
|
在线一区观看
|
一区二区三区在线看
|
久久综合久久综合久久综合
|
久久精品91久久香蕉加勒比
|
国产日韩免费
|
久久国产主播精品
|
欧美一区午夜视频在线观看
|
国语自产精品视频在线看一大j8
|
久久久国产精品一区
|
久久se精品一区精品二区
|
99视频一区
|
久久精品国产77777蜜臀
|
亚洲一区二区四区
|
欧美不卡一卡二卡免费版
|
久久精品国产清高在天天线
|
欧美日韩精品免费观看
|
欧美.日韩.国产.一区.二区
|
国产伦精品一区二区三
|
欧美在线日韩精品
|
久久久综合免费视频
|
亚洲精品欧美
|
久久er精品视频
|
午夜精品一区二区在线观看
|
性欧美xxxx视频在线观看
|
激情小说亚洲一区
|
亚洲欧美日韩综合aⅴ视频
|
亚洲综合视频一区
|
欧美日韩不卡视频
|
亚洲精选在线
|
很黄很黄激情成人
|
欧美一区二区三区免费在线看
|
在线免费观看欧美
|
一个色综合导航
|
国内偷自视频区视频综合
|
欧美国产综合一区二区
|
国产精品xxx在线观看www
|
久久综合久久综合九色
|
国产一区在线免费观看
|
午夜精品久久久99热福利
|
午夜在线一区
|
欧美日韩国产限制
|
99av国产精品欲麻豆
|
国产一区二区激情
|
久久精品一区二区三区不卡牛牛
|
夜夜爽夜夜爽精品视频
|
欧美黄色一区二区
|
鲁鲁狠狠狠7777一区二区
|
亚洲视频免费在线
|
欧美在线视频在线播放完整版免费观看
|
亚洲欧美电影院
|
国产农村妇女精品一区二区
|
在线欧美三区
|
久久天天躁狠狠躁夜夜av
|
牛人盗摄一区二区三区视频
|
亚洲人成毛片在线播放
|
久久成年人视频
|
猫咪成人在线观看
|
国产亚洲aⅴaaaaaa毛片
|
久久精品理论片
|
亚洲国产精品尤物yw在线观看
|
国产日韩一区二区三区在线
|
久久成人一区
|
亚洲国产毛片完整版
|
欧美一区深夜视频
|
欧美日本乱大交xxxxx
|
免费成人高清视频
|
99v久久综合狠狠综合久久
|
久久久久九九视频
|
亚洲欧洲日韩在线
|
欧美专区亚洲专区
|
亚洲经典一区
|
国产精品一卡
|
免费观看成人
|
亚洲欧美一区二区三区久久
|
中文在线资源观看网站视频免费不卡
|
国产精品久久久
|
一区二区三区欧美在线观看
|
久久久久久久久岛国免费
|
一本色道久久综合一区
|
极品少妇一区二区三区
|
欧美日韩国产综合视频在线
|
久久婷婷国产麻豆91天堂
|
一本色道久久综合亚洲精品婷婷
|
久久阴道视频
|
亚洲欧美一区在线
|
91久久综合
|
激情视频一区二区
|
国产精品久久久久久av福利软件
|
日韩午夜精品视频
|
蜜乳av另类精品一区二区
|
亚洲欧美视频一区二区三区
|
99精品国产在热久久
|
黄色亚洲免费
|
国产精品一二一区
|
国产精品theporn
|
女生裸体视频一区二区三区
|
欧美专区在线观看一区
|
一区二区黄色
|
日韩视频国产视频
|
91久久精品美女高潮
|
欧美成人综合一区
|
久久婷婷麻豆
|
久久精品一区蜜桃臀影院
|
亚洲欧美视频在线观看视频
|
亚洲视频高清
|
夜夜嗨av一区二区三区四区
|
亚洲高清免费
|
国产精品av久久久久久麻豆网
|
美日韩精品免费
|
久久一区中文字幕
|
久久久国产精品一区二区中文
|
欧美一区二区视频97
|
午夜精品久久久久久久蜜桃app
|
一区二区三区国产盗摄
|
欧美一区二区三区视频免费
|
羞羞色国产精品
|
午夜一级久久
|
久久精彩视频
|
老鸭窝毛片一区二区三区
|
亚洲欧美日韩在线高清直播
|
亚洲资源av
|
午夜精品一区二区三区在线视
|
亚洲欧洲av一区二区
|
欧美一级电影久久
|
久久国产精品99国产
|
久久另类ts人妖一区二区
|
在线亚洲观看
|
亚洲一区三区电影在线观看
|
午夜精品久久久久
|
欧美亚洲在线观看
|
久久亚洲春色中文字幕久久久
|
欧美国产在线视频
|
日韩视频一区二区三区在线播放免费观看
|
欧美涩涩视频
|
欧美成人r级一区二区三区
|
欧美激情亚洲自拍
|
久久九九热re6这里有精品
|
蜜月aⅴ免费一区二区三区
|
欧美资源在线
|
免费在线观看成人av
|
欧美日韩精品一本二本三本
|
国产精品免费区二区三区观看
|
欧美精品免费视频
|
国产精品嫩草99a
|
精品动漫3d一区二区三区
|
日韩视频在线观看免费
|
午夜国产精品影院在线观看
|
久久综合中文字幕
|
亚洲另类在线视频
|
亚洲欧美一区二区三区久久
|
蜜臀久久99精品久久久画质超高清
|
欧美日韩亚洲一区二区三区
|
欧美日韩国内
|
国产自产女人91一区在线观看
|
日韩一区二区久久
|
久久成人免费电影
|
亚洲第一视频
|
91久久精品视频
|
新狼窝色av性久久久久久
|
欧美a级大片
|
国产性猛交xxxx免费看久久
|
一区二区欧美日韩视频
|
久久综合一区二区三区
|
亚洲少妇在线
|
欧美劲爆第一页
|
怡红院精品视频
|
在线欧美不卡
|
欧美一二区视频
|
一本大道久久a久久精品综合
|
一区二区三区视频在线播放
|
免费国产一区二区
|
国产一区二区高清视频
|
亚洲免费小视频
|