<@乌龟:>从c#到c++的一些容易出现的困惑(2)

      武汉的天气太热了.很早就逼得人起床-_-

      上次写了一点从c#到c++容易出现的一些问题, 今天接着写一点, 上一篇文章主要把精力集中在.H文件,命名空间等工程所需要的一些地方,今天主要说一说从语言的角度来说一些类型与c#迥然不同的用法.

      1. 枚举类型:

       c++的枚举类型用法非常的灵活,但是也带来一些很不方便的地方.下面是一段正常的c++的枚举类型的使用:

   1: # include <string>
   2: # include <iostream>
   3:  
   4: using namespace std;
   5:  
   6: enum Emotion
   7: {
   8:     Happy = 0,
   9:     Sad = 1,
  10:     Exciting = 2,
  11: };
  12:  
  13: #define Love Emotion(4);
  14:  
  15: void main()
  16: {
  17:     Emotion emotion = Love;
  18:     Emotion emotion2 = Emotion::Exciting;
  19:  
  20:     cout << (int)emotion << endl;
  21:     cout << (int)emotion2 << endl;
  22: }
       从代码上可以看到,首先是定义了一个Emotion的枚举,在使用的时候,既可以在枚举类型的前面加上枚举的说明符,又可以不加上.得到的结果是一样的.

       这里要注意一下13行的#define,枚举类型不仅可以再enum { }中定义,还可以再花括号之外定义.这种方法我是在d3d的头文件定义中看到的.

       下面再看一段代码

   1: enum Emotion
   2: {
   3:     Happy = 0,
   4:     Sad = 1,
   5:     Exciting = 2,
   6: };
   7:  
   8: enum Test
   9: {
  10:     Happy = 5;
  11:     Others = 6;
  12: };

      按c#的理解来说,这段代码应该是完全没有问题的,Emotion和Test属于两个不同的域,但是c++没有枚举域这个概念,其实c++的枚举定义更像是一堆的#define,上面的代码有编译错误,告诉我有Happy枚举量重定义. 上面的代码可以按这样的方式来理解:

   1: #define Happy 0;
   2: #define Sad 1;
   3: #define Exciting 2;
   4:  
   5: #define Happy 5;
   6: #define Others 6;

      但是不同的,这段代码就没有编译错误了,只是一个warning.

      2. WCHAR, CHAR, TCHAR以及相关的问题.

      这个问题其实网上有很多的文章来详细的描述,我只是谈谈我个人的一些感想以及总结一下网上查到的内容.

      对于c++可没有这么多的字符种类.一个String就可以包含所有的字符,而且还不需要进行转换.但是对于c++就不一样了,c++由于兼容c语言的一些特性,char类型就是代码ASCII码里面的字符,如果要描述中文,日文等等字符就需要对原来的char类型进行扩展,也就是UNICODE码,在c++里面被称为wchar_t类型.

      对于VC,认为wchar_t看起来不好看(我不知道最后的't'是什么意思)于是就将wchar_t定义成了WCHAR,其实两者之间是等价的.

      对于对WCHAR*字符串进行赋值的时候,注意要加上一个L宏,也就比如

   1: WCHAR* wStr = L"Hello World";

      TCHAR是一种为了统一两者的命名.下面这两句话可以很清楚的说明问题.

      定义了_UNICODE:    typedef wchar_t TCHAR ;
      没有定义_UNICODE: typedef char TCHAR ;

      TCHAR的宏是_T,TEXT,_TEXT,三者是等价的.

      下面给出一些常用的字符串函数的不同定义(针对WCHAR与char)

   1: size_t strlen( const char *string );
   2: size_t wcslen( const wchar_t *string );
   3:  
   4: char *strcpy( char *strDestination, const char *strSource );
   5: wchar_t *wcscpy( wchar_t *strDestination, const wchar_t *strSource );
   6:  
   7: char *strcat( char *strDestination, const char *strSource );
   8: wchar_t *wcscat( wchar_t *strDestination, const wchar_t *strSource );
   9:  
  10: int strcmp( const char *string1, const char *string2 );
  11: int wcscmp( const wchar_t *string1, const wchar_t *string2 );

      最后说说宽字符与普通字符之间的转化:

      一般大家使用现成的函数MultiByteToWideChar,与WideCharToMultiByte函数.

      给大家一个连接,上面讲的比较清楚了

      http://www.cppblog.com/sunraiing9/archive/2007/03/21/20281.html

posted on 2009-08-20 08:03  乌龟_毛驴  阅读(2753)  评论(8编辑  收藏  举报

导航