碰到一个微软的bug:CWinAppEx::GetString
在調試公司項目代碼的時候,有一個系統設置的功能,里面需要從注冊表中去讀取數據,因為使用了MFC框架所以,為了簡化代碼直接使用了CWinAppEx::GetString 、CWinAppEx::SetString、CWinAppEx::GetInt、CWinAppEx::SetInt等等框架內函數,因為使用它之間只需要SetRegistryKey(_T("Application Name"));設置一下就好了,遠比自己調用win32 API或者CRegKey類用起來方便多了。
發現一個GetString的在實現的時候有一個bug,起初是我在讀取一個注冊表String時發現,CWinAppEx::GetString即使傳入了第二個參數lpzDefault沒能成功訪問注冊表的話返回還是空字符串!
debug進入代碼中看:
首先可以發現GetString實際上是調用的GetSectionString函數:
CString CWinAppEx::GetString(LPCTSTR lpszEntry, LPCTSTR lpszDefault /*= ""*/) {return GetSectionString(_T(""), lpszEntry, lpszDefault); }afxwinappex.cpp:
CString CWinAppEx::GetSectionString( LPCTSTR lpszSubSection, LPCTSTR lpszEntry, LPCTSTR lpszDefault /*= ""*/) {ENSURE(lpszSubSection != NULL);ENSURE(lpszEntry != NULL);ENSURE(lpszDefault != NULL);CString strRet = lpszDefault;CString strSection = GetRegSectionPath(lpszSubSection);CSettingsStoreSP regSP;CSettingsStore& reg = regSP.Create(FALSE, TRUE);if (reg.Open(strSection)){reg.Read(lpszEntry, strRet);}return strRet; }從代碼中來看,前面幾行都沒有問題,按F11進入到reg.Read(lpszEntry, strRet);
afxsettingsstore.cpp:
BOOL CSettingsStore::Read(LPCTSTR lpszValueName, CString& strValue) {ENSURE(lpszValueName != NULL);strValue.Empty();DWORD dwCount = 0;if (m_reg.QueryStringValue(lpszValueName, NULL, &dwCount) != ERROR_SUCCESS){return FALSE;}if (dwCount == 0){return TRUE;}LPTSTR szValue = new TCHAR [dwCount + 1];BOOL bRes = m_reg.QueryStringValue(lpszValueName, szValue, &dwCount) == ERROR_SUCCESS;if (bRes){strValue = szValue;}delete [] szValue;return bRes; }在這里可以看到strValue.Empty();在最開始的時候就被調用了,明顯不對,就算你是否有正確的值傳進來,也不該首先就直接將default value清空啊,坑啊!
搜索看到國外有個哥們也遇到相同的問題:http://www.bcgsoft.com/cgi-bin/forum/topic.asp?TOPIC_ID=4485
轉載于:https://www.cnblogs.com/hyb1/p/3242949.html
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的碰到一个微软的bug:CWinAppEx::GetString的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 数据结构教程读书笔记_递归
- 下一篇: Ruby中的%表示法