如何在C和c++中将字符转换为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/。
其他回答
C和c++总是将类型提升到至少int。此外,字符字面量在C中是int类型,在c++中是char类型。
可以通过赋值给int类型来转换char类型。
char c = 'a'; // narrowing on C
int a = c;
这取决于你对“转换”的定义。
如果您有一系列表示整数的字符,如"123456",那么在C中有两种典型的方法:使用特殊用途的转换,如atoi()或strtol(),或通用用途的sscanf()。c++(实际上是一种伪装成升级版的不同语言)增加了第三种语言stringstreams。
如果你的意思是你想让你的int变量中的一个精确的位模式被视为一个char,那就更容易了。在C语言中,不同的整数类型实际上更多的是一种思想状态,而不是实际的独立“类型”。只要在需要字符的地方开始使用它,就可以了。你可能需要一个显式的转换,使编译器停止抱怨,但所有应该做的是删除超过256的任何额外比特。
我有一个问题,将“7c7c7d7d7d7d7c7c7c7d7d7d7d7c7c7c7d7d7c7d7c7d7c7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7d7c7c7c7c7c2e2e2e”这样的char数组转换成它的实际整数值,可以用“7C”表示为一个十六进制值。所以,在四处寻求帮助后,我创建了这个,并认为分享它会很酷。
这将字符字符串分离成正确的整数,可能对更多的人有帮助,而不仅仅是我;)
unsigned int* char2int(char *a, int len)
{
int i,u;
unsigned int *val = malloc(len*sizeof(unsigned long));
for(i=0,u=0;i<len;i++){
if(i%2==0){
if(a[i] <= 57)
val[u] = (a[i]-50)<<4;
else
val[u] = (a[i]-55)<<4;
}
else{
if(a[i] <= 57)
val[u] += (a[i]-50);
else
val[u] += (a[i]-55);
u++;
}
}
return val;
}
希望能有所帮助!
我在C语言中有绝对的零技能,但对于一个简单的解析:
char* something = "123456";
int number = parseInt(something);
...这招对我很管用:
int parseInt(char* chars)
{
int sum = 0;
int len = strlen(chars);
for (int x = 0; x < len; x++)
{
int n = chars[len - (x + 1)] - '0';
sum = sum + powInt(n, x);
}
return sum;
}
int powInt(int x, int y)
{
for (int i = 0; i < y; i++)
{
x *= 10;
}
return x;
}
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。
推荐文章
- decltype(auto)的一些用途是什么?
- Shared_ptr转换为数组:应该使用它吗?
- 使用C返回一个数组
- Printf与std::字符串?
- 禁用复制构造函数
- 只接受特定类型的c++模板
- c#和Java中的泛型有什么不同?和模板在c++ ?
- 为什么pthreads的条件变量函数需要互斥?
- c++ 11中的递归lambda函数
- 如何在构建目标之外生成gcc调试符号?
- 在c++中指针使用NULL或0(零)吗?
- 在c++中,如何将int值附加到字符串中?
- __FILE__宏显示完整路径
- 就性能而言,使用std::memcpy()还是std::copy()更好?
- 为什么布尔值是1字节而不是1位?