• <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())
            {
            ..................
            }

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

            <2008年1月>
            303112345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            導航

            統計

            常用鏈接

            留言簿(10)

            隨筆檔案

            文章檔案

            最新隨筆

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            久久久99精品成人片中文字幕| 99久久婷婷免费国产综合精品| 久久久久无码精品国产app| 国产成人久久777777| 国产精品久久久久久久人人看| 97精品国产97久久久久久免费 | 精品久久久久久久久中文字幕| 伊人久久大香线蕉影院95| 久久综合一区二区无码| 久久精品国产亚洲AV麻豆网站| 人人狠狠综合久久亚洲88| 亚洲伊人久久成综合人影院| 99久久99久久| 狠狠色噜噜色狠狠狠综合久久| 国产精品99久久久久久人| 国内精品久久久久影院老司| 丁香狠狠色婷婷久久综合| 中文成人无码精品久久久不卡 | 国产成人无码精品久久久久免费| 国产精品久久久久久久人人看 | 无码人妻精品一区二区三区久久 | 青青草原精品99久久精品66| 国产精品gz久久久| 久久被窝电影亚洲爽爽爽| 无码伊人66久久大杳蕉网站谷歌 | 久久精品一本到99热免费| 亚洲欧美日韩久久精品| 国产亚洲色婷婷久久99精品91| 久久综合给合久久狠狠狠97色69 | 久久综合丝袜日本网| 97精品国产91久久久久久| 亚洲中文久久精品无码| 狠狠精品久久久无码中文字幕| 久久天天婷婷五月俺也去| 久久久久国产| 武侠古典久久婷婷狼人伊人| 欧美日韩成人精品久久久免费看| 久久九九亚洲精品| 久久99精品国产99久久6| 久久99精品国产麻豆婷婷| 青青青青久久精品国产h久久精品五福影院1421 |