char和csting类型转换.doc

  1. 1、本文档共23页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
char和csting类型转换

  CString位于头文件afx.h中。   CString 是一种很有用的数据类型。它们很大程度上简化了MFC中的许多操作,使得MFC在做字符串操作的时候方便了很多。不管怎样,使用CString有很多特殊的技巧,特别是对于纯C背景下走出来的程序员来说有点难以学习。这篇文章就来讨论这些技巧。   使用CString可以让你对字符串的操作更加直截了当。这篇文章不是CString的完全手册,但囊括了大部分常见基本问题。   这篇文章包括以下内容:   CString 对象的连接   格式化字符串(包括 int 型转化为 CString )   CString 型转化成 int 型   CString 型和 char* 类型的相互转化   char* 转化成 CString   CString 转化成 char* 之一:使用LPCTSTR强制转化   CString 转化成 char* 之二:使用CString对象的GetBuffer方法   CString 转化成 char* 之三: 和控件的接口   CString 型转化成 BSTR 型;   BSTR 型转化成 CString 型;   VARIANT 型转化成 CString 型;   载入字符串表资源;   CString 和临时对象;   CString 的效率;   总结   下面我分别讨论。 [ HYPERLINK /view/998109.htm 编辑本段] 1、CString 对象的连接   能体现出 CString 类型方便性特点的一个方面就是字符串的连接,使用 CString 类型,你能很方便地连接两个字符串,正如下面的例子:   CString gray(Gray);   CString cat(Cat);   CString graycat = gray + cat;   要比用下面的方法好得多:   char gray[] = Gray;   char cat[] = Cat;   char * graycat = malloc(strlen(gray) + strlen(cat) + 1);   strcpy(graycat, gray);   strcat(graycat, cat); [ HYPERLINK /view/998109.htm 编辑本段] 2、格式化字符串   与其用 sprintf() 函数或 wsprintf() 函数来格式化一个字符串,还不如用 CString 对象的Format()方法:   CString s;   s.Format(_T(The total is %d), total);   用这种方法的好处是你不用担心用来存放格式化后数据的缓冲区是否足够大,这些工作由CString类替你完成。   格式化是一种把其它不是字符串类型的数据转化为CString类型的最常用技巧,比如,把一个整数转化成CString类型,可用如下方法:   CString s;   s.Format(_T(%d), total);   我总是对我的字符串使用_T()宏,这是为了让我的代码至少有Unicode的意识,当然,关于Unicode的话题不在这篇文章的讨论范围。_T()宏在8位字符环境下是如下定义的:   #define _T(x) x // 非Unicode版本(non-Unicode version)   而在Unicode环境下是如下定义的:   #define _T(x) L##x // Unicode版本(Unicode version)   所以在Unicode环境下,它的效果就相当于:   s.Format(L%d, total);   如果你认为你的程序可能在Unicode的环境下运行,那么开始在意用 Unicode 编码。比如说,不要用 sizeof() 操作符来获得字符串的长度,因为在Unicode环境下就会有2倍的误差。我们可以用一些方法来隐藏Unicode的一些细节,比如在我需要获得字符长度的时候,我会用一个叫做DIM的宏,这个宏是在我的dim.h文件中定义的,我会在我写的所有程序中都包含这个文件:   #define DIM(x) ( sizeof((x)) / sizeof((x)[0]) )   这个宏不仅可以用来解决Unicode的字符串长度的问题,也可以用在编译时定义的表格上,它可以获得表格的项数,如下:   class Whatever { ... };   Whatever data[] = {   { ... },   ...   { ... },   };   for(int i = 0;

文档评论(0)

xcs88858 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档