• <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>

            08年08月12日

            Posted on 2008-08-12 20:09 RichardHe 閱讀(1579) 評(píng)論(8)  編輯 收藏 引用
            原因:今天游戲出現(xiàn)一個(gè)很嚴(yán)重的BUG,就是通過帳號(hào)服務(wù)器驗(yàn)證時(shí),有時(shí)候驗(yàn)證完以后進(jìn)入角色選擇時(shí),竟然出現(xiàn)別人的帳號(hào)角色;
            這可不是一個(gè)小BUG,對(duì)于一個(gè)程序員來說可是致命的錯(cuò)誤;由于在本地服務(wù)器測(cè)試時(shí),同時(shí)通過驗(yàn)證帳號(hào)服務(wù)器的消息是十分少的,
            所以在本地一開始沒發(fā)現(xiàn)這個(gè)BUG;還有就是看來我在程序中使用全局變量實(shí)在是不好,才使得這個(gè)BUG沒及時(shí)發(fā)現(xiàn).
            問題是這樣產(chǎn)生的,如果很多消息同時(shí)過來請(qǐng)求帳號(hào)服務(wù)器,那在那個(gè)唯一一個(gè)對(duì)應(yīng)帳號(hào)的數(shù)字ID為最后一個(gè).而在登錄LOGIN中的帳號(hào)
            和ID傳遞時(shí)的ID和本身的ID是不一樣的,所以才會(huì)出現(xiàn)這個(gè)帳號(hào)對(duì)應(yīng)別人的角色列表.我恨,這個(gè)問題沒意識(shí)到.

            解決:先在傳遞的時(shí)候把帳號(hào)和ID綁定,或者用一個(gè)HASH_MAP把帳號(hào)和ID和服務(wù)器列表保存起來,再轉(zhuǎn)到LOGIN服務(wù)器是時(shí)再根據(jù)用戶
            名找到他的ID,從而再轉(zhuǎn)角色服務(wù)器.這樣就不會(huì)錯(cuò)了!


            Feedback

            # re: 08年08月12日  回復(fù)  更多評(píng)論   

            2008-08-12 20:42 by lonkil
            這個(gè)Bug可不是一般的Bug。

            # re: 08年08月12日  回復(fù)  更多評(píng)論   

            2008-08-12 20:46 by 陳梓瀚(vczh)
            囧,我的程序是完全沒有全局變量的,不得不有的那幾個(gè)要么就是singleton專門用來初始化一些必要的API調(diào)用,要么在占有的時(shí)候絕對(duì)會(huì)有critical section。我保證在所有new操作在main開始之后開始,所有delete操作在main結(jié)束之前結(jié)束。

            # re: 08年08月12日  回復(fù)  更多評(píng)論   

            2008-08-12 21:08 by RichardHe
            @lonkil
            是的啊..真汗顏啊!

            # re: 08年08月12日  回復(fù)  更多評(píng)論   

            2008-08-12 21:13 by RichardHe
            @陳梓瀚(vczh)
            弄同步確實(shí)是個(gè)好方法,不過有時(shí)候?qū)Ψ降某绦蚓褪钱惒?弄的你也只能這樣.
            呵呵..向你學(xué)習(xí)了!

            # re: 08年08月12日  回復(fù)  更多評(píng)論   

            2008-08-13 11:17 by abettor
            @陳梓瀚(vczh)

            囧,我的程序是完全沒有全局變量的,不得不有的那幾個(gè)要么就是singleton專門用來初始化一些必要的API調(diào)用,要么在占有的時(shí)候絕對(duì)會(huì)有 critical section。我保證在所有new操作在main開始之后開始,所有delete操作在main結(jié)束之前結(jié)束。

            ——好習(xí)慣!現(xiàn)在如果還在面向?qū)ο蟮某绦蚶锎罅糠簽E的使用全局變量,那恐怕肯定是要出問題的了。singleton雖然有點(diǎn)矯情,但是是非常有效的。我的方法是,singleton中的對(duì)象必須用get/set訪問,而get/set方法本身就是synchorized的。這樣一來,大家用起來就省心又放心了。

            # re: 08年08月12日  回復(fù)  更多評(píng)論   

            2008-08-13 12:29 by RichardHe
            @abettor
            而get/set方法本身就是synchorized的???

            具體怎么實(shí)現(xiàn)的啊?

            # re: 08年08月12日  回復(fù)  更多評(píng)論   

            2008-08-13 12:31 by 空明流轉(zhuǎn)
            一定要同步。vc說的對(duì)。

            # re: 08年08月12日  回復(fù)  更多評(píng)論   

            2008-08-13 13:23 by RichardHe
            @空明流轉(zhuǎn)
            我也知道同步當(dāng)然是好了.但是對(duì)方處理的不是同步.所以我們這邊也只能對(duì)它單獨(dú)處理了.能同步的話什么問題都解決了.

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            posts - 94, comments - 138, trackbacks - 0, articles - 94

            Copyright © RichardHe

            精品久久久久久99人妻| 精品久久久久久中文字幕| 久久精品毛片免费观看| www.久久精品| 久久中文字幕人妻丝袜| 一本一道久久精品综合| 国产精品日韩深夜福利久久| 青青草国产成人久久91网| 精品午夜久久福利大片| 狠狠色丁香婷综合久久| 77777亚洲午夜久久多喷| 免费久久人人爽人人爽av| 国产L精品国产亚洲区久久| 香港aa三级久久三级| 久久精品无码一区二区日韩AV | 久久婷婷激情综合色综合俺也去| 亚洲国产成人乱码精品女人久久久不卡 | 国产精品久久久久天天影视| 久久人人爽人人爽人人爽| 漂亮人妻被中出中文字幕久久| 99久久国产综合精品五月天喷水| 国内精品久久久久久麻豆| 93精91精品国产综合久久香蕉 | 久久精品这里只有精99品| 久久丝袜精品中文字幕| 久久这里只有精品18| 亚洲国产成人久久综合区| 2021国产精品久久精品| 日韩欧美亚洲国产精品字幕久久久 | 国产免费福利体检区久久| 国内精品人妻无码久久久影院导航 | 亚洲国产另类久久久精品小说| 成人国内精品久久久久影院VR| 久久精品中文字幕有码| 国产成人精品免费久久久久| 亚洲欧美成人综合久久久| 久久天天婷婷五月俺也去| 精品久久人妻av中文字幕| 久久综合给久久狠狠97色| 2019久久久高清456| 久久成人小视频|