金慶的專欄
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 © 金慶
99精品国产免费久久久久久下载
|
久久精品中文騷妇女内射
|
伊人色综合久久天天
|
久久久精品久久久久久
|
久久久久久久久66精品片
|
久久精品天天中文字幕人妻
|
色综合久久中文综合网
|
久久精品国产免费观看三人同眠
|
狠色狠色狠狠色综合久久
|
久久亚洲日韩看片无码
|
99久久无码一区人妻
|
婷婷五月深深久久精品
|
久久久久亚洲AV无码去区首
|
97热久久免费频精品99
|
久久精品成人欧美大片
|
久久久久久国产精品美女
|
久久综合九色综合精品
|
久久久久久久久无码精品亚洲日韩
|
久久香综合精品久久伊人
|
97超级碰碰碰碰久久久久
|
久久天天躁狠狠躁夜夜网站
|
色欲久久久天天天综合网精品
|
久久综合久久综合亚洲
|
天天综合久久一二三区
|
久久久WWW免费人成精品
|
久久久久国产精品麻豆AR影院
|
久久精品国产久精国产果冻传媒
|
亚洲国产成人久久精品动漫
|
av无码久久久久不卡免费网站
|
99久久人人爽亚洲精品美女
|
亚洲精品高清久久
|
国产亚洲美女精品久久久久狼
|
久久精品无码专区免费青青
|
国产一级持黄大片99久久
|
国产亚洲欧美成人久久片
|
777久久精品一区二区三区无码
|
久久久久人妻一区精品
|
久久综合伊人77777
|
亚洲乱码日产精品a级毛片久久
|
久久久久99精品成人片
|
久久丝袜精品中文字幕
|