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

            MFC中一個容易被忽視的問題

               MFC對話框模式的程序經常有這樣一種業務需求:

                  對話框初始化 --> 取得數據 --> 將數據顯示到對話框的控件中

               該流程有一個潛在的問題,看下面的代碼:
            BOOL CTestDlg::OnInitDialog()
            {
                CDialog::OnInitDialog();
                
            // TODO: Add extra initialization here

                
            // Get data here
                char* szData = GetData();

                
            // Set Ctrl value here
                GetDlgItem(IDC_SOMEEDITCTRL)->SetWindowText(szData);

                
            return TRUE;
            }

               這樣的代碼編譯出來的程序運行起來有時會CRUSH,有時不會,調試起來很讓人頭痛。
               錯誤出在“GetDlgItem(IDC_SOMEEDITCTRL)->SetWindowText(szData);”這一句,這行代碼是在對話框初始化時調用的,此時對話框資源有可能還沒有創建起來,因此GetDlgItem(IDC_SOMEEDITCTRL)有可能得到的就是空指針,也有可能得到的是非空卻被判斷為非窗口的指針。遇上這兩種情況,程序當然就CRUSH掉了。
               這樣精簡的代碼當然很容易看出問題來,但是如果程序規模大了,資源多了,又有嵌套調用等等,發生這樣的錯誤就很難檢查出來。

               解決的方法有很多,一定要確保在InitDialog結束之后再對控件資源進行操作。最簡單的方法是在InitDialog結束的時候PostMessage,然后在消息處理里面處理資源操作。


            posted on 2007-12-12 10:48 迷宮の未來 閱讀(2095) 評論(11)  編輯 收藏 引用

            評論

            # re: MFC中一個容易被忽視的問題 2007-12-12 13:01 LOGOS

            不錯。這個問題確實比較容易被忽視  回復  更多評論   

            # re: MFC中一個容易被忽視的問題 2007-12-12 15:49 agaric

            既然是MFC,基本上都會映射成一個成員變量來操作吧,就不會這么麻煩咯  回復  更多評論   

            # re: MFC中一個容易被忽視的問題 2007-12-12 16:44 不懂

            有這種問題??

            沒遇到過,是你們使用的有問題吧,如果MFC有這種不確定性的問題,早就應該發現了吧。  回復  更多評論   

            # re: MFC中一個容易被忽視的問題 2007-12-13 13:18 vc

            '有時會CRUSH'?能給個代碼能crush的嗎?有興趣深入看一下  回復  更多評論   

            # re: MFC中一個容易被忽視的問題 2007-12-14 13:53 追夢時代

            @vc
            我做的是一個控制面板程序,之前會CRUSH掉的部分代碼如下:
            BOOL CStockF10SetDlg::OnInitDialog()
            {
            CDialog::OnInitDialog();
            // TODO: Add extra initialization here
            //Init contrl data
            .......
            //獲得注冊表的值
            if(GetRegValues())
            {
            //更新沒有值綁定的控件的顯示
            SetCtrlState();
            //更新有值綁定的控件的顯示
            UpdateData(FALSE);
            }
            else
            {
            MessageBox("Get regedit values error!");
            }
            return TRUE; // return TRUE unless you set the focus to a control
            // EXCEPTION: OCX Property Pages should return FALSE
            }


            void CStockF10SetDlg::SetCtrlState()
            {
            //EnableForceSend
            ......
            szTemp.Format("%02ld",gethour(m_nUpdateTime));
            //將m_nUpdateTime這個時間值的小時部分顯示到控件
            GetDlgItem(IDC_UPDATETIMEH)->SetWindowText(szTemp);
            szTemp.Format("%02ld",getminute(m_nUpdateTime));
            //將m_nUpdateTime這個時間值的分鐘部分顯示到控件
            GetDlgItem(IDC_UPDATETIMEM)->SetWindowText(szTemp);
            }


            由于這個時間值我把它放在小時和分鐘兩個控件中顯示,所以沒有綁定成員變量,直接通過資源號來顯示數據的。代碼運行到SetWindowText這里會CRUSH掉。   回復  更多評論   

            # re: MFC中一個容易被忽視的問題 2007-12-15 22:03 Zero Lee

            提到的問題,確實很有意思,沒遇到過。前不久做的一個項目中,寫的代碼與“追夢時代”的操作差不多,在VS2003.net和VS2005下不管哪種模式都沒有出現這種問題啊。  回復  更多評論   

            # re: MFC中一個容易被忽視的問題 2007-12-18 10:25 力為

            GetDlgItem(IDC_UPDATETIMEH)->SetWindowText(szTemp);
            這種寫法本身就得挨批~  回復  更多評論   

            # re: MFC中一個容易被忽視的問題 2007-12-25 22:05 秦歌

            這種情況不好說  回復  更多評論   

            # re: MFC中一個容易被忽視的問題 2007-12-28 14:56 123

            @力為
            94  回復  更多評論   

            # re: MFC中一個容易被忽視的問題[未登錄] 2007-12-29 11:32

            這行代碼是在對話框初始化時調用的,此時對話框資源有可能還沒有創建起來,
            ---------------------------
            收到 WM_INITDIALOG, 則對話框和子窗口已經創建起來
            執行CDialog::OnInitDialog()之后, 則控件和變量已經關聯起來(如果有的話)
            這個是肯定的

            至于樓主為什么會CRUSH,,,,,,奇怪....
            除非GetDlgItem(IDC_SOMEEDITCTRL) 中的ID對應的控件不存在

              回復  更多評論   

            # re: MFC中一個容易被忽視的問題 2008-11-16 12:57 vane

            至于樓主為什么會CRUSH,,,,,,奇怪....
            除非GetDlgItem(IDC_SOMEEDITCTRL) 中的ID對應的控件不存在
            控件沒創建好,返回的是一個空指針GetDlgItem返回值是一個CWnd*
            我們可以這樣CWnd *pWnd = GetDlgItem(IDC_SOMEEDITCTRL);
            if(pWnd->GetSafeHwnd())
            {
            ..................
            }

            這就不會造成崩潰 但是,有可能那個控件沒數據  回復  更多評論   

            <2007年12月>
            2526272829301
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            導航

            統計

            常用鏈接

            留言簿(10)

            隨筆檔案

            文章檔案

            最新隨筆

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            久久伊人亚洲AV无码网站| 亚洲αv久久久噜噜噜噜噜| 国内精品久久九九国产精品| 久久久国产精品福利免费| 久久最新精品国产| 欧美精品福利视频一区二区三区久久久精品 | 综合久久精品色| 久久天天躁狠狠躁夜夜avapp| 久久99热国产这有精品| 亚洲欧美日韩精品久久亚洲区| 一本久久知道综合久久| 91麻精品国产91久久久久| 无码人妻精品一区二区三区久久久| 久久精品国产99国产精品澳门| 久久午夜福利无码1000合集| 精品久久久久久综合日本| 久久久无码精品亚洲日韩蜜臀浪潮| 国产精品美女久久久| 77777亚洲午夜久久多人| 久久免费香蕉视频| 国产成人无码精品久久久免费| 久久亚洲精品成人AV| 亚洲欧美日韩久久精品第一区| 久久国产成人精品国产成人亚洲| 久久99热只有频精品8| 亚洲中文久久精品无码ww16| 色妞色综合久久夜夜| 尹人香蕉久久99天天拍| 久久无码国产| 色综合久久88色综合天天 | 99久久亚洲综合精品成人| 久久99精品国产99久久6男男| 久久AV高清无码| www.久久精品| 久久99国产精品久久久| 久久九九青青国产精品| 国产精品毛片久久久久久久 | 国产精品永久久久久久久久久| 国产午夜精品久久久久免费视| 久久婷婷成人综合色综合| 久久综合狠狠综合久久|