在Unicode的环境下,CString的format函数怎么这么奇怪?

hzyem 2013-01-02 02:21:58
在Unicode的环境下,CString的format函数怎么这么奇怪?
在Unicode的环境下,我的下面两行代码结果不正常:
iFlag = 1;
m_szRegPath.Format(_T("SYSTEM\\ControlSet00%d\\Control\\Class\\"), iFlag); //注册表路径

format后本m_szRegPath应该是"SYSTEM\\ControlSet001\\Control\\Class\\"才对,但是实际结果是"S",只有字符串的第一个字母,后面的都没了,这是什么原因?
...全文
278 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
hzyem 2013-01-03
  • 打赏
  • 举报
回复
问题找到了,是设置的问题,需要在Project->setting->C/C++->Preprocessor->Undefined symbols加入"_DEBUG",搞不懂为什么,仅供参考,也求高人解说。
向立天 2013-01-03
  • 打赏
  • 举报
回复
format函数事不会有问题的 你这里的问题是把Unicode的字符串当作ASCII的了
smilenot 2013-01-03
  • 打赏
  • 举报
回复
你用的是CStringA 还是CString ?
jimette 2013-01-02
  • 打赏
  • 举报
回复
断点跟踪把!
hzyem 2013-01-02
  • 打赏
  • 举报
回复
断点跟踪到format这行代码,就发现m_szRegPath的值就有问题了,跟后面的代码无关。
oyljerry 2013-01-02
  • 打赏
  • 举报
回复
引用 4 楼 hzyem 的回复:
引用 2 楼 akirya 的回复:肯定是你用ascii的方式输出了 此话怎讲? 在后面m_szRegPath也是作为参数给RegOpenKeyEx使用的,这部分代码是读写注册表的,之前在非Unicode的环境下工作正常,现在挪过来发现有问题,跟踪了一下才发现是m_szRegPath不对。
还是你后面使用的不对,具体代码自己调试
hzyem 2013-01-02
  • 打赏
  • 举报
回复
引用 2 楼 akirya 的回复:
肯定是你用ascii的方式输出了
此话怎讲? 在后面m_szRegPath也是作为参数给RegOpenKeyEx使用的,这部分代码是读写注册表的,之前在非Unicode的环境下工作正常,现在挪过来发现有问题,跟踪了一下才发现是m_szRegPath不对。
hzyem 2013-01-02
  • 打赏
  • 举报
回复
同样的代码在非Unicode环境下是正常的,只是在Unicode环境下才有上述问题,真是晕。
  • 打赏
  • 举报
回复
肯定是你用ascii的方式输出了
oyljerry 2013-01-02
  • 打赏
  • 举报
回复
m_szRegPath字符串是否处理正确.Format没啥问题
随笔 - 764 文章 - 3 评论 - 196 CString,string,char*之间的转换(转) 这三种类型各有各的优点,比如CString比较灵活,是基于MFC常用的类型,安全性也最高,但可移植性最差。string是使用STL时必不可少的类型,所以是做工程时必须熟练掌握的;char*是从学习C语言开始就已经和我们形影不离的了,有许多API都是以char*作为参数输入的。所以熟练掌握三者之间的转换十分必要。 以下我用简单的图示指出三者之间的关系,并以标号对应转换的方法。 1 string to CString CString.format("%s",string.c_str()); 2 CString to string string str(CString.GetBuffer(str.GetLength())); 3 string to char * char *p=string.c_str(); 4 char * to string string str(char*); 5 CString to char * strcpy(char,CString,sizeof(char)); 6 char * to CString CString.format("%s",char*); CStringformat方法是非常好用的。string的c_str()也是非常常用的,但要注意和char *转换时,要把char定义成为const char*,这样是最安全的。 以上函数UNICODE编码也没问题:unicode下照用,加个_T()宏就行了,像这样子_T("%s") 补充: CString 可能是 CStringW/CStringA,在与 string 转换时,如果是 CStringW,还涉及编码转换问题。下面以 CStringA 来说明。 1 string to CString CString.format("%s",string.c_str()); CStringA = string.c_str() 就可以了 2 CString to string string str(CString.GetBuffer(str.GetLength())); GetBuffer 有参数的话,可能导致内部的分配空间动作,要进行后续 ReleaseBuffer 操作。 string = CStringA string = CStringA.GetBuffer(); 3 string to char * char *p=string.c_str(); 4 char * to string string str(char*); 5 CString to char * strcpy(char *,CString,sizeof(char)); 按照 3 风格,这里应该 char * = CStringA; 或者 char *p = CStringA.GetBuffer(); 6 char * to CString CStringA = char * 就可以了

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧