#include "ctype.h"
下的
isalnum(char|unsigned)函数,里面有个断言
assert((unsigned) (c+1) <=256)所以,传递的char类型是无符号的。如果要传递signed char,那么要显示的转换下。
signed char到unsigned char会丢失;
请看下面:
unsigned char和char的区别和转换
本质上两种类型都占一个字节。
作为字符使用时,都是存储字符的ASCII码。比如:
unsigned char uc='a';
char c='a';
printf("%d %d",uc,c);
结果为: a a
作为整数使用时,两种类型的取值范围就不同了。unsigned char 可取0至255,而char可取-128至+127。比如:
unsigned char uc=255;
char c=255;
printf("%d %d",uc,c);
结果为: 255 -1
原因是没有用unsigned修饰的char类型系统将其存储的一个字节值(8位2进制)看作为一个有符号数来处理,最高位为0时,表示正数,为1时表示负数,表示负数时的值为余下7位二进制每一位取反后整体+1。
比如上例中:char c=255; 表面看来超过了char的范围,但系统并不是这样处理的。
系统将十进制数255转为二进制数11111111进行存储。在计算或打印时,发现最高位为1,是负数,余下7位1111111取反后为0000000,加1后为0000001,转为十进制数等于1,最后系统当作-1看待。所以此时按整数打印c时,输出为-1。
总的来说,系统最终存储的都是二进制数11111111,只是在参与运算或显示的时候,unsigned char和char才会有所区别。
//字母和数字的ascll编码都是大于0的
但是汉子的转换成ascll表示以后(多个字节表示一个汉字),那么这个汉字的一部分是小于0的。
main()
{
for(int i =1;i<128;i++)
{
cout<<i<<"="<<(char) i<<"\t";
cout输出ascll码对应的字符,或者指针的int表示时,都应该强制转换才行。
显示16,8,10进制可以用
cout << hex << oct << dec等来控制
}
}