
符串
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的效率;
总结
下面我分别讨论。
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);
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;i lstrcpyn(data,longstring,sizeof(data)-1);//WRONG! lstrcpyn(data,longstring,DIM(data)-1);//RIGHT WriteFile(f,data,DIM(data),&bytesWritten,NULL);//WRONG! WriteFile(f,data,sizeof(data),&bytesWritten,NULL);//RIGHT 造成以上原因是因为lstrcpyn需要一个字符个数作为参数,但是WriteFile却需要字节数作为参数。 同样需要注意的是有时候需要写出数据的所有内容。如果你仅仅只想写出数据的真实长度,你可能会认为你应该这样做: WriteFile(f,data,lstrlen(data),&bytesWritten,NULL);//WRONG 但是在Unicode环境下,它不会正常工作。正确的做法应该是这样: WriteFile(f,data,lstrlen(data)*sizeof(TCHAR),&bytesWritten,NULL);//RIGHT 因为WriteFile需要的是一个以字节为单位的长度。(可能有些人会想“在非Unicode的环境下运行这行代码,就意味着总是在做一个多余的乘1操作,这样不会降低程序的效率吗?”这种想法是多余的,你必须要了解编译器实际上做了什么,没有哪一个C或C++编译器会把这种无聊的乘1操作留在代码中。在Unicode环境下运行的时候,你也不必担心那个乘2操作会降低程序的效率,记住,这只是一个左移一位的操作而已,使用_T宏并不是意味着你已经创建了一个Unicode的程序,你只是创建了一个有Unicode意识的程序而已。如果你在默认的8-bit模式下编译你的程序的话,得到的将是一个普通的8-bit的应用程序(这里的8-bit 指的只是8位的字符编码,并不是指8位的计算机系统);当你在Unicode环境下编译你的程序时,你才会得到一个Unicode的程序。记住,CString在Unicode环境下,里面包含的可都是16位的字符哦。 本文由西安白癜风医院(http://www.njtaiji120.com/)网站负责人阿牧整理分享,转载请注明!
