• <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中一個(gè)容易被忽視的問(wèn)題

               MFC對(duì)話框模式的程序經(jīng)常有這樣一種業(yè)務(wù)需求:

                  對(duì)話框初始化 --> 取得數(shù)據(jù) --> 將數(shù)據(jù)顯示到對(duì)話框的控件中

               該流程有一個(gè)潛在的問(wèn)題,看下面的代碼:
            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;
            }

               這樣的代碼編譯出來(lái)的程序運(yùn)行起來(lái)有時(shí)會(huì)CRUSH,有時(shí)不會(huì),調(diào)試起來(lái)很讓人頭痛。
               錯(cuò)誤出在“GetDlgItem(IDC_SOMEEDITCTRL)->SetWindowText(szData);”這一句,這行代碼是在對(duì)話框初始化時(shí)調(diào)用的,此時(shí)對(duì)話框資源有可能還沒(méi)有創(chuàng)建起來(lái),因此GetDlgItem(IDC_SOMEEDITCTRL)有可能得到的就是空指針,也有可能得到的是非空卻被判斷為非窗口的指針。遇上這兩種情況,程序當(dāng)然就CRUSH掉了。
               這樣精簡(jiǎn)的代碼當(dāng)然很容易看出問(wèn)題來(lái),但是如果程序規(guī)模大了,資源多了,又有嵌套調(diào)用等等,發(fā)生這樣的錯(cuò)誤就很難檢查出來(lái)。

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


            posted on 2007-12-12 10:48 迷宮の未來(lái) 閱讀(2107) 評(píng)論(11)  編輯 收藏 引用

            評(píng)論

            # re: MFC中一個(gè)容易被忽視的問(wèn)題 2007-12-12 13:01 LOGOS

            不錯(cuò)。這個(gè)問(wèn)題確實(shí)比較容易被忽視  回復(fù)  更多評(píng)論   

            # re: MFC中一個(gè)容易被忽視的問(wèn)題 2007-12-12 15:49 agaric

            既然是MFC,基本上都會(huì)映射成一個(gè)成員變量來(lái)操作吧,就不會(huì)這么麻煩咯  回復(fù)  更多評(píng)論   

            # re: MFC中一個(gè)容易被忽視的問(wèn)題 2007-12-12 16:44 不懂

            有這種問(wèn)題??

            沒(méi)遇到過(guò),是你們使用的有問(wèn)題吧,如果MFC有這種不確定性的問(wèn)題,早就應(yīng)該發(fā)現(xiàn)了吧。  回復(fù)  更多評(píng)論   

            # re: MFC中一個(gè)容易被忽視的問(wèn)題 2007-12-13 13:18 vc

            '有時(shí)會(huì)CRUSH'?能給個(gè)代碼能crush的嗎?有興趣深入看一下  回復(fù)  更多評(píng)論   

            # re: MFC中一個(gè)容易被忽視的問(wèn)題 2007-12-14 13:53 追夢(mèng)時(shí)代

            @vc
            我做的是一個(gè)控制面板程序,之前會(huì)CRUSH掉的部分代碼如下:
            BOOL CStockF10SetDlg::OnInitDialog()
            {
            CDialog::OnInitDialog();
            // TODO: Add extra initialization here
            //Init contrl data
            .......
            //獲得注冊(cè)表的值
            if(GetRegValues())
            {
            //更新沒(méi)有值綁定的控件的顯示
            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這個(gè)時(shí)間值的小時(shí)部分顯示到控件
            GetDlgItem(IDC_UPDATETIMEH)->SetWindowText(szTemp);
            szTemp.Format("%02ld",getminute(m_nUpdateTime));
            //將m_nUpdateTime這個(gè)時(shí)間值的分鐘部分顯示到控件
            GetDlgItem(IDC_UPDATETIMEM)->SetWindowText(szTemp);
            }


            由于這個(gè)時(shí)間值我把它放在小時(shí)和分鐘兩個(gè)控件中顯示,所以沒(méi)有綁定成員變量,直接通過(guò)資源號(hào)來(lái)顯示數(shù)據(jù)的。代碼運(yùn)行到SetWindowText這里會(huì)CRUSH掉。   回復(fù)  更多評(píng)論   

            # re: MFC中一個(gè)容易被忽視的問(wèn)題 2007-12-15 22:03 Zero Lee

            提到的問(wèn)題,確實(shí)很有意思,沒(méi)遇到過(guò)。前不久做的一個(gè)項(xiàng)目中,寫(xiě)的代碼與“追夢(mèng)時(shí)代”的操作差不多,在VS2003.net和VS2005下不管哪種模式都沒(méi)有出現(xiàn)這種問(wèn)題啊。  回復(fù)  更多評(píng)論   

            # re: MFC中一個(gè)容易被忽視的問(wèn)題 2007-12-18 10:25 力為

            GetDlgItem(IDC_UPDATETIMEH)->SetWindowText(szTemp);
            這種寫(xiě)法本身就得挨批~  回復(fù)  更多評(píng)論   

            # re: MFC中一個(gè)容易被忽視的問(wèn)題 2007-12-25 22:05 秦歌

            這種情況不好說(shuō)  回復(fù)  更多評(píng)論   

            # re: MFC中一個(gè)容易被忽視的問(wèn)題 2007-12-28 14:56 123

            @力為
            94  回復(fù)  更多評(píng)論   

            # re: MFC中一個(gè)容易被忽視的問(wèn)題[未登錄](méi) 2007-12-29 11:32

            這行代碼是在對(duì)話框初始化時(shí)調(diào)用的,此時(shí)對(duì)話框資源有可能還沒(méi)有創(chuàng)建起來(lái),
            ---------------------------
            收到 WM_INITDIALOG, 則對(duì)話框和子窗口已經(jīng)創(chuàng)建起來(lái)
            執(zhí)行CDialog::OnInitDialog()之后, 則控件和變量已經(jīng)關(guān)聯(lián)起來(lái)(如果有的話)
            這個(gè)是肯定的

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

              回復(fù)  更多評(píng)論   

            # re: MFC中一個(gè)容易被忽視的問(wèn)題 2008-11-16 12:57 vane

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

            這就不會(huì)造成崩潰 但是,有可能那個(gè)控件沒(méi)數(shù)據(jù)  回復(fù)  更多評(píng)論   


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


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

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(10)

            隨筆檔案

            文章檔案

            最新隨筆

            搜索

            積分與排名

            最新隨筆

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            精品综合久久久久久98| 欧美久久一级内射wwwwww.| 精品久久久久成人码免费动漫| 久久久久99这里有精品10| 国产香蕉久久精品综合网| 无码人妻久久久一区二区三区| 99热成人精品热久久669| 国内精品免费久久影院| 精品久久久久久国产| 香蕉久久一区二区不卡无毒影院| 一97日本道伊人久久综合影院 | 精品久久久久久中文字幕大豆网 | 久久九九精品99国产精品| 热久久国产精品| 久久久久波多野结衣高潮| 国产日韩欧美久久| 狠狠干狠狠久久| 人妻精品久久无码区| 亚洲精品视频久久久| 亚洲综合精品香蕉久久网97| 久久久久高潮综合影院| 亚洲精品无码久久久久AV麻豆| 国产亚洲精午夜久久久久久| 国产精品无码久久综合 | 久久综合综合久久97色| 亚洲精品乱码久久久久久蜜桃图片 | 久久综合给合久久狠狠狠97色| 久久精品一区二区影院| 99久久国产热无码精品免费| 无码人妻久久一区二区三区蜜桃 | 狠狠色丁香婷婷综合久久来 | 久久噜噜久久久精品66| 精品久久久久久中文字幕| 亚洲国产美女精品久久久久∴| 久久久久人妻一区精品色 | 久久香蕉国产线看观看猫咪?v| 97超级碰碰碰碰久久久久| 天天综合久久久网| 国产精品久久久久久久久久免费| 精品综合久久久久久97超人| 久久精品aⅴ无码中文字字幕重口|