首先感谢大家近来对我在MSDN上发表的翻译文章的鼓励。最初开始为MSDN翻译文章,纯粹是处于个人兴趣,也是希望可以对大家有所帮助吧。因为是业余行为,所以工作繁忙时(更多是懒惰啦),就会放弃这项事情。不过发表了几篇后,陆续收到一些朋友的回应,多有赞美之词,尽管自己知道尚有不少不尽之处,毕竟我自己也不是专职翻译人员,而且不少文章也是我自己一边学习一边尝试翻译出来和大家分享,不过还是难免飘飘然哦 J。同时还带来了一个附加的好处,就是有新的动力来更新自己的blog了。看看自己的更新间隔,实在汗颜。
那天有位朋友看到我在MSDN上发表的文章,顺便向我问了一个C++中关于字符问题。唉,我发现这一年多来和字符和字符串可谓纠缠不休,于是我推荐她/他去看了我的一篇历史文章,以为可以有所帮助。结果那位朋友看后,提出了新的疑问。看看下面的代码:
char a = ‘ab’;
结果会怎样呢?我们都知道char是一个字节,’ab’显然是两个字节,另外一位朋友看了也立刻说“编译出错吧”。我尝试了一下,竟然编译通过,a的值是’b’。我也是第一次见到这样的语法,经过试验,发现最多支持4个字符(注意,不是4个字符的字符串):
char a = ‘abcd’;
a的值是’d’。我们认为,因为编译器最多支持32位的整数,上面的代码相当于
a = 0x60616263; // ‘a’的ASCII码是0x60,依次类推
编译器把这样一个整数截断后将最低字节赋值为char,所以a的结果是0x63。在我们做的codec程序中,使用FourCC的形式表示codec的版本,比如wmva四个字符,编码时一般使用一个无符号32位整数DWORD支持,以前我们都使用移位的方式实现,使用这样的语法可以简单写成:
DWORD dwFourCC = ‘wmva’;
最后,注意不要这样使用中文字符:
char a = ‘蔡’;
这样a的结果是汉字(使用双字节表示,相当于一个无符号16位整数)的低字节,不过编译器会有警告信息(可能需要level4,我不是很肯定,大家可以自己试验),所以如果你认真检查编译器的警告信息,也可以发现和避免这个问题。
谢谢网友goodbaby的思考和提出这个问题。