今天用WINCE写测试tool,需要将从device端输入的字符串转换成10进制数。代码如下
DWORD transfer(char * str){
DWORD output = 0;
char * p = str;
while(*p!= '\0'){
RETAILMSG(1, (TEXT("[9293 REG] #### str = %s ####\r\n"),str));
output = 10 * output +( *p-'0');
RETAILMSG(1, (TEXT("[9293 REG] #### output = %d ####\r\n"),output));
++p;
RETAILMSG(1, (TEXT("[9293 REG] #### str = %d ####\r\n"),*p));
}
return output;
}
测试时发现while循环只执行一次,最后问题定位在++p,它直接加到字符串末尾。理论上每次应该只加一个字符,于是找度娘
因为C++支持两种字符串,即常规的ANSI编码(使用""包裹)和Unicode编码(使用L""包裹),这样对应的就有了两套字符串字符串处理函数,比如:strlen和wstrlen,分别用于处理两种字符串 微软将这两套字符集及其操作进行了统一,通过条件编译(通过_UNICODE和UNICODE宏)控制实际使用的字符集,这样就有了_T("")这样的字符串,对应的就有了_tcslen这样的函数 为了存储这样的通用字符,就有了TCHAR: 当没有定义_UNICODE宏时,TCHAR = char,_tcslen = strlen 当定义了_UNICODE宏时,TCHAR = wchar_t , _tcslen = wstrlen 当我们定义了UNICODE宏,就相当于告诉了编译器:我准备采用UNICODE版本。这个时候,TCHAR就会摇身一变,变成了wchar_t。而未定义UNICODE宏时,TCHAR摇身一变,变成了unsigned char 。这样就可以很好的切换宽窄字符集。 tchar可用于双字节字符串,使程序可以用于中日韩等国 语言文字处理、显示。使编程方法简化。
原来如此,记录一下,防止忘记了!