我一直認(rèn)為創(chuàng)建一個(gè)窗口的時(shí)候,窗口處理過程處理WM_CREATE是在處理WM_SIZE之前的,所以很多初始化的東西都放在WM_CREATE處來做,但最近弄一個(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ā)覺沒有這個(gè)問題,WM_CREATE總是在WM_SIZE之前,我嘗試在別處重現(xiàn)問題,無果……現(xiàn)在,你再仔細(xì)看一下上圖,你發(fā)現(xiàn)問題了么?
我想經(jīng)過我這么提示,你應(yīng)該知道了:原因就是WM_CREATE這個(gè)斷點(diǎn)前一行的SetWindowLong這個(gè)調(diào)用,這個(gè)調(diào)用會(huì)引起一個(gè)WM_SIZE事件,所以這就制造了WM_SIZE在WM_CREATE之前這個(gè)假象。處理這個(gè)問題很簡單,把SetWindowLong這行拿掉,然后把WS_NONAVDONEBUTTON這個(gè)屬性交給CreateWindow,如下圖:

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