金慶的專欄
C++博客
::
首頁
::
新隨筆
::
聯(lián)系
::
聚合
::
管理
::
423 隨筆 :: 0 文章 :: 454 評(píng)論 :: 0 Trackbacks
公告
我的隨筆
我的評(píng)論
我參與的隨筆
留言簿
(12)
給我留言
查看公開留言
查看私人留言
隨筆分類
(502)
1. C/C++(166)
(rss)
2. 網(wǎng)游開發(fā)(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)
相冊
公告照片
搜索
積分與排名
積分 - 659016
排名 - 25
最新評(píng)論
1.?re: boost::asio::spawn 將一統(tǒng)C++網(wǎng)絡(luò)庫
asio 成為C++首選網(wǎng)絡(luò)庫
--linda
2.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評(píng)論內(nèi)容較長,點(diǎn)擊標(biāo)題查看
--金慶
3.?re: mingw編譯OrzNet
能發(fā)送一個(gè)mingw編譯好的OrzNet庫給我嗎? liuweiqcxy@163.com
謝謝!
--劉威
4.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評(píng)論內(nèi)容較長,點(diǎn)擊標(biāo)題查看
--bigbad
5.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評(píng)論內(nèi)容較長,點(diǎn)擊標(biāo)題查看
--bigbad
閱讀排行榜
1.?"multiple definition of" 錯(cuò)誤(11054)
2.?SVN中邪惡的replace(10972)
3.?VS2005編譯libevent(10429)
4.?混音算法的學(xué)習(xí)與研究(10230)
5.?C調(diào)用lua腳本的效率測試(9019)
評(píng)論排行榜
1.?VC6正在被拋棄(35)
2.?VS2005編譯libevent(21)
3.?"multiple definition of" 錯(cuò)誤(18)
4.?C++引用優(yōu)于指針(17)
5.?ACE與ASIO之間關(guān)于Socket編程的比較(16)
lua變量缺少local造成unity死鎖
# lua變量缺少local造成unity死鎖
(金慶的專欄 2020.9.1)
這幾天在開發(fā) grpc-tolua, 可以在 unity 項(xiàng)目中使用 lua 發(fā)送 grpc 請求,無需生成代碼.
現(xiàn)已實(shí)現(xiàn) route_guide 示例中的全部4種rpc.
見:https://github.com/jinq0123/grpc-tolua
昨天的開發(fā)中就發(fā)現(xiàn),運(yùn)行 RecordRoute 和 RouteChat 之后Unity無法再次運(yùn)行,必須殺進(jìn)程。
在 await 語句添加 `ConfigureAwait(false)` 之后,好像 RouteChat 修復(fù)了,但 RecoreRoute 依舊。
ConfigureAwait(false) 保證了 await 之后不會(huì)搶占主線程,是解決死鎖的一種方法。
grpc 源碼中的 await 同樣都跟著這句。
今天再次測試,發(fā)現(xiàn) RouteChat 并未真正修復(fù),仍有較大可能卡死。
最初的猜想是 Lua 協(xié)程,C# 異步造成線程死鎖,因?yàn)閷?duì)異步不熟,總是懷疑使用有誤。
后來轉(zhuǎn)變?yōu)椴檎易?Unity 卡死的阻塞式操作,但是因?yàn)槿罩撅@示不全,找遍代碼都沒結(jié)果。
除了在自己的代碼中查找錯(cuò)誤,還在 tolua 代碼,grpc 代碼中查找,到處懷疑。
今天一整天都在添加日志,重啟Unity中度過。提出各種猜想,又反復(fù)驗(yàn)證。
依次采用了以下方法:
* 比較C# route_guide 代碼,查找區(qū)別
* 為什么是 client streaming 類型的 rpc 有錯(cuò)
* 查看 tolua 協(xié)程,Timer
* 添加 Delay, 更改協(xié)程的運(yùn)行次序,提高或降低復(fù)現(xiàn)幾率
* 函數(shù)入口和返回添加日志,證明其沒有阻塞
查找錯(cuò)誤的方法是在代碼中添加日志,找到異常之處。
最終的現(xiàn)象是Unity沒有Update()調(diào)用了,全部卡死。
錯(cuò)誤源代碼是這樣的,錯(cuò)誤版本中 awaiter 前面沒有 local.
```lua
local function await(awaitable)
local awaiter = awaitable:GetAwaiter()
coroutine.wait_until(function()
return awaiter.IsCompleted
end)
end
```
因?yàn)橄雽?shí)現(xiàn)一個(gè)特殊版本的 await() 用于測試, 把 awaiter.IsCompleted 改為總是 false。
復(fù)制代碼時(shí),發(fā)現(xiàn)了變量缺少 local.
如果這個(gè)成為全局變量,第2次函數(shù)調(diào)用就會(huì)更改第1次調(diào)用的變量,我立刻意識(shí)到了這就是死鎖的原因。
添加 local 之后測試,一切都正常了。
分析結(jié)果是因?yàn)?awaiter 更改后,await() 在任務(wù)完成前就返回了,
以致于后面的讀取成為阻塞式操作,阻塞了主線程。
查錯(cuò)效率低的主要問題是 Unity 日志在卡死前的日志沒有顯示,這一點(diǎn)直到最后死鎖復(fù)盤時(shí)才發(fā)覺。
因?yàn)槿罩救笔В鶕?jù)日志得出的所有判斷幾乎都錯(cuò)了。
本來可以根據(jù)日志快速定位的原因,現(xiàn)在完全找錯(cuò)方向。
如果有工具警告全局變量,就可以避免這個(gè)錯(cuò)誤。
Unity Profiler, VS Debugger 因?yàn)?Unity 完全卡死,所以沒什么幫助。
posted on 2020-09-02 13:37
金慶
閱讀(425)
評(píng)論(0)
編輯
收藏
引用
所屬分類:
2. 網(wǎng)游開發(fā)
只有注冊用戶
登錄
后才能發(fā)表評(píng)論。
【推薦】100%開源!大型工業(yè)跨平臺(tái)軟件C++源碼提供,建模,組態(tài)!
相關(guān)文章:
How are dtLinks created in NavMesh
UE4 Blueprint Multiple Event BeginPlay
第9代游戲主機(jī)
Canvas Scaler 的3種模式
幀同步是否允許客戶端指定命令幀號(hào)
rpc應(yīng)答太快造成請求超時(shí)
測試 tolua 例子 TestErrorStack
lua變量缺少local造成unity死鎖
C# tolua 之間互傳 byte[]
Unity使用異步grpc
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
深夜久久AAAAA级毛片免费看
|
中文字幕乱码人妻无码久久
|
国产免费久久精品99久久
|
久久亚洲高清综合
|
久久久久无码精品国产
|
久久久九九有精品国产
|
久久婷婷人人澡人人
|
久久精品无码一区二区无码
|
99久久国产免费福利
|
人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区
|
精品国产福利久久久
|
欧美日韩久久中文字幕
|
99久久超碰中文字幕伊人
|
日本加勒比久久精品
|
99国内精品久久久久久久
|
亚洲AV无码久久精品色欲
|
草草久久久无码国产专区
|
性色欲网站人妻丰满中文久久不卡
|
亚洲精品高清国产一久久
|
久久亚洲精品成人av无码网站
|
久久久久久一区国产精品
|
久久九九全国免费
|
99久久婷婷国产综合亚洲
|
性做久久久久久久
|
久久人人爽人人爽人人片AV东京热
|
日韩久久无码免费毛片软件
|
韩国无遮挡三级久久
|
国产亚洲精品自在久久
|
国产亚洲美女精品久久久2020
|
一级A毛片免费观看久久精品
|
精品一久久香蕉国产线看播放
|
久久精品国产一区
|
色综合久久综精品
|
国产精品伊人久久伊人电影
|
五月丁香综合激情六月久久
|
久久精品国产99久久久古代
|
欧美亚洲国产精品久久高清
|
久久AV高潮AV无码AV
|
久久综合88熟人妻
|
国产精品久久久久9999高清
|
韩国三级大全久久网站
|