如何在C和c++中将字符转换为int ?
当前回答
想必您需要这种转换来使用C标准库中的函数。
在这种情况下,do (c++语法)
typedef unsigned char UChar;
char myCppFunc( char c )
{
return char( someCFunc( UChar( c ) ) );
}
表达式UChar(c)转换为unsigned char以消除负值,除了EOF外,c函数不支持负值。
然后,该表达式的结果被用作int形式参数的实际参数。你会自动提升到int。您也可以显式地编写最后一步,如int(UChar(c)),但我个人认为这太啰嗦了。
干杯!
其他回答
Char只是一个1字节的整数。char类型没有什么神奇之处!就像你可以将short类型赋值给int类型,或将int类型赋值给long类型一样,你也可以将char类型赋值给int类型。
是的,原始数据类型的名称恰好是“char”,这暗示它应该只包含字符。但实际上,“char”只是一个糟糕的名字选择,会让每个试图学习这门语言的人感到困惑。更好的名称是int8_t,如果您的编译器遵循最新的C标准,则可以使用该名称。
当然,在进行字符串处理时应该使用char类型,因为经典ASCII表的索引适合1个字节。不过,您也可以使用常规int类型进行字符串处理,尽管在现实世界中没有任何实际原因可以解释为什么要这样做。例如,下面的代码将完美地工作:
int str[] = {'h', 'e', 'l', 'l', 'o', '\0' };
for(i=0; i<6; i++)
{
printf("%c", str[i]);
}
你必须意识到字符和字符串只是数字,就像计算机中的其他东西一样。当您在源代码中写入'a'时,它会被预处理为数字97,这是一个整数常数。
如果你写一个表达式
char ch = '5';
ch = ch - '0';
这实际上等价于
char ch = (int)53;
ch = ch - (int)48;
然后通过C语言的整数提升
ch = (int)ch - (int)48;
然后截断为一个字符以适应结果类型
ch = (char)( (int)ch - (int)48 );
行与行之间有很多微妙的东西,其中char被隐式地当作int。
int charToint(char a){
char *p = &a;
int k = atoi(p);
return k;
}
您可以使用此atoi方法将char转换为int。想了解更多信息,可以参考这个http://www.cplusplus.com/reference/cstdlib/atoi/, http://www.cplusplus.com/reference/string/stoi/。
对于char或short to int,只需要赋值。
char ch = 16;
int in = ch;
与int64相同。
long long lo = ch;
所有值都是16。
这取决于你想做什么:
如果要以ASCII码的形式读取该值,可以写入
char a = 'a';
int ia = (int)a;
/* note that the int cast is not necessary -- int ia = a would suffice */
要转换字符'0' -> 0,'1' -> 1,等等,你可以写
char a = '4';
int ia = a - '0';
/* check here if ia is bounded by 0 and 9 */
解释: A - '0'等价于((int) A) - ((int)'0'),这意味着字符的ASCII值相互相减。因为在ascii表中0直接出现在1之前(以此类推,直到9),两者之间的差就给出了字符a所代表的数字。
这取决于你对“转换”的定义。
如果您有一系列表示整数的字符,如"123456",那么在C中有两种典型的方法:使用特殊用途的转换,如atoi()或strtol(),或通用用途的sscanf()。c++(实际上是一种伪装成升级版的不同语言)增加了第三种语言stringstreams。
如果你的意思是你想让你的int变量中的一个精确的位模式被视为一个char,那就更容易了。在C语言中,不同的整数类型实际上更多的是一种思想状态,而不是实际的独立“类型”。只要在需要字符的地方开始使用它,就可以了。你可能需要一个显式的转换,使编译器停止抱怨,但所有应该做的是删除超过256的任何额外比特。
推荐文章
- 为什么这个结合赋值和相等检查的if语句返回true?
- cplusplus.com给出的错误、误解或坏建议是什么?
- C多行宏:do/while(0) vs作用域块
- 找出质数最快的算法是什么?
- time_t最终的类型定义是什么?
- 我需要显式处理负数或零时,总和平方数字?
- c++枚举类可以有方法吗?
- 函数名周围的括号是什么意思?
- 用C语言创建自己的头文件
- 格式化IO函数(*printf / *scanf)中的转换说明符%i和%d之间的区别是什么?
- 将析构函数设为私有有什么用?
- main()中的Return语句vs exit()
- 为什么c#不提供c++风格的'friend'关键字?
- 如果不是内存地址,C指针到底是什么?
- 在函数的签名中添加关键字