我一直認(rèn)為創(chuàng)建一個(gè)窗口的時(shí)候,窗口處理過(guò)程處理WM_CREATE是在處理WM_SIZE之前的,所以很多初始化的東西都放在WM_CREATE處來(lái)做,但最近弄一個(gè)程序發(fā)現(xiàn)到了WM_SIZE處出錯(cuò),原因是空指針,而這個(gè)指針應(yīng)該是在WM_CREATE的時(shí)候被賦值的,奇怪了,難道WM_SIZE會(huì)在WM_CREATE之前?于是設(shè)兩個(gè)斷點(diǎn),不看不知道,一看還真的如此,如下圖:

程序每次總是先觸到WM_SIZE的這個(gè)斷點(diǎn),難道我理解一直有誤?于是我創(chuàng)建了一個(gè)hello world程序,調(diào)試了半天,又發(fā)覺(jué)沒(méi)有這個(gè)問(wèn)題,WM_CREATE總是在WM_SIZE之前,我嘗試在別處重現(xiàn)問(wèn)題,無(wú)果……現(xiàn)在,你再仔細(xì)看一下上圖,你發(fā)現(xiàn)問(wèn)題了么?
我想經(jīng)過(guò)我這么提示,你應(yīng)該知道了:原因就是WM_CREATE這個(gè)斷點(diǎn)前一行的SetWindowLong這個(gè)調(diào)用,這個(gè)調(diào)用會(huì)引起一個(gè)WM_SIZE事件,所以這就制造了WM_SIZE在WM_CREATE之前這個(gè)假象。處理這個(gè)問(wèn)題很簡(jiǎn)單,把SetWindowLong這行拿掉,然后把WS_NONAVDONEBUTTON這個(gè)屬性交給CreateWindow,如下圖:

這樣就好了,我想順便提個(gè)問(wèn)題,我在設(shè)計(jì)一個(gè)程序的時(shí)候,也碰到了“布局”和“加載”的先后問(wèn)題,因?yàn)椴季挚赡苄枰匦抡{(diào)整加載的資源,而加載資源又需要參考布局的尺寸,由于功能上的原因,我必須把兩者分開(kāi),所以存在我前面說(shuō)的這個(gè)先雞先蛋的難題。最后我是這么弄的,做一個(gè)“資源是否已經(jīng)加載”的標(biāo)志,然后總是先“布局”,布局的時(shí)候檢查這個(gè)標(biāo)志,如果沒(méi)有資源的加載,那就只更改尺寸參數(shù)而不調(diào)整資源,這樣看起來(lái)就沒(méi)什么問(wèn)題了,從邏輯上來(lái)說(shuō)我的設(shè)計(jì)確實(shí)是WM_SIZE優(yōu)先于WM_CREATE……
歡迎對(duì)這些方面的設(shè)計(jì)問(wèn)題留言討論。