最近排查軟件的一個(gè)問(wèn)題,百思不得其解,最后查下來(lái)竟然是一個(gè)變量沒(méi)有初始化引起的!

1、問(wèn)題排查過(guò)程
最近在按照新需求,開(kāi)發(fā)新功能,在調(diào)試某個(gè)功能時(shí),出現(xiàn)一個(gè)詭異的現(xiàn)象。在運(yùn)行通過(guò)release安裝包安裝的exe版本,始終是有問(wèn)題的,但是直接在VS2017中進(jìn)行release版本調(diào)試,發(fā)現(xiàn)功能居然是正常的!
同樣都是release版本,底層庫(kù)都是一樣的,兩個(gè)版本表現(xiàn)居然截然不同,這太奇怪了!百思不得其解!
于是繼續(xù)排查,想到這個(gè)問(wèn)題在之前穩(wěn)定版本是沒(méi)有的,應(yīng)該是最近開(kāi)發(fā)新功能引起的,于是使用svn查看了最近的代碼提交記錄,找到相關(guān)代碼模塊仔細(xì)排查,結(jié)果發(fā)現(xiàn)是一個(gè)BOOL變量影響了代碼的控制邏輯。在程序運(yùn)行的開(kāi)始階段,該變量應(yīng)該是FALSE的,出問(wèn)題的版本居然走到該控制變量為TRUE的分支中,導(dǎo)致代碼的控制邏輯出了問(wèn)題,所以導(dǎo)致上述問(wèn)題!
在變量沒(méi)有初始化時(shí),很多編譯器在debug下會(huì)自動(dòng)初始化,但在release下不會(huì)自動(dòng)初始化。release下變量如果沒(méi)有初始化,變量的值將會(huì)是一個(gè)隨機(jī)值,是給該變量分配的內(nèi)存時(shí)內(nèi)存中的值,所以會(huì)是隨機(jī)值,一旦出現(xiàn)了隨機(jī)值,程序運(yùn)行時(shí)會(huì)出現(xiàn)不可預(yù)知的結(jié)果。
本例中,直接運(yùn)行安裝包安裝的exe版本與release調(diào)試運(yùn)行,該控制變量會(huì)得到隨機(jī)值,所以導(dǎo)致兩種情況下的不同表現(xiàn)!
另外,有點(diǎn)迷惑人的地方是,幾乎每次直接運(yùn)行安裝包安裝的exe版本時(shí),該BOOL變量的隨機(jī)值都是TRUE,但在release下調(diào)試運(yùn)行時(shí)該變量的值一直是FALSE,這也許和兩種情況的啟動(dòng)運(yùn)行機(jī)制差異有關(guān)系吧!反正是變量沒(méi)有初始化引起的!
2、總結(jié)
以前我們?cè)陂_(kāi)發(fā)團(tuán)隊(duì)中一再?gòu)?qiáng)調(diào)變量要初始化,但還是有人說(shuō),變量不需要一上來(lái)就初始化,只要控制好自己的代碼邏輯就好了,我表示很不贊同!只有經(jīng)歷過(guò)問(wèn)題的人,才會(huì)有深刻體會(huì)吧!