如何在C和c++中将字符转换为int ?
当前回答
使用“long long”而不是“int”,这样它适用于更大的数字。这里是优雅的解决方案。
long long ChardToint(char *arr, size_t len){
int toptenf=1;
long long toptenLf=10000000LL;
long long makeintf=3000000000000;
makeintf= 0LL;
int holdNumberf=0;
for(int i=len-1;i>=0 ;i--){
switch(arr[i]){
case '0':
holdNumberf=0;
break;
case '1':
holdNumberf=1;
break;
case '2':
holdNumberf=2;
break;
case '3':
holdNumberf=3;
break;
case '4':
holdNumberf=4;
break;
case '5':
holdNumberf=5;
break;
case '6':
holdNumberf=6;
break;
case '7':
holdNumberf=7;
break;
case '8':
holdNumberf=8;
break;
case '9':
holdNumberf=9;
break;
default:
holdNumberf=0;
}
if(toptenf>=10000000){
makeintf=makeintf+holdNumberf*toptenLf;
toptenLf=toptenLf*10;
}else{
makeintf=makeintf+holdNumberf*toptenf;
toptenf=toptenf*10;
}
}
return makeintf;
}
其他回答
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中也存在符号扩展问题。)
处理所有三种char类型(有符号、无符号和char)比最初看起来更精细。0到SCHAR_MAX(对于8位字符是127)范围内的值很容易:
char c = somevalue;
signed char sc = c;
unsigned char uc = c;
int n = c;
但是,当somevalue超出该范围时,只有通过unsigned char才能在所有三种类型中获得“相同”char值的一致结果:
char c = somevalue;
signed char sc = c;
unsigned char uc = c;
// Might not be true: int(c) == int(sc) and int(c) == int(uc).
int nc = (unsigned char)c;
int nsc = (unsigned char)sc;
int nuc = (unsigned char)uc;
// Always true: nc == nsc and nc == nuc.
这在使用ctype.h中的函数时很重要,例如isupper或toupper,因为符号扩展:
char c = negative_char; // Assuming CHAR_MIN < 0.
int n = c;
bool b = isupper(n); // Undefined behavior.
注意到int的转换是隐式的;这有相同的UB:
char c = negative_char;
bool b = isupper(c);
要解决这个问题,使用unsigned char,这很容易通过safe_ctype包装ctype.h函数:
template<int (&F)(int)>
int safe_ctype(unsigned char c) { return F(c); }
//...
char c = CHAR_MIN;
bool b = safe_ctype<isupper>(c); // No UB.
std::string s = "value that may contain negative chars; e.g. user input";
std::transform(s.begin(), s.end(), s.begin(), &safe_ctype<toupper>);
// Must wrap toupper to eliminate UB in this case, you can't cast
// to unsigned char because the function is called inside transform.
这是可行的,因为任何接受三种char类型中的任何一种的函数也可以接受另外两种char类型。它导致两个可以处理任何类型的函数:
int ord(char c) { return (unsigned char)c; }
char chr(int n) {
assert(0 <= n); // Or other error-/sanity-checking.
assert(n <= UCHAR_MAX);
return (unsigned char)n;
}
// Ord and chr are named to match similar functions in other languages
// and libraries.
Ord (c)总是给你一个非负值-即使传递一个负字符或负符号字符- CHR取Ord产生的任何值并返回完全相同的字符。
在实践中,我可能只使用unsigned char类型而不是使用这些类型,但它们确实简洁地包装了类型转换,提供了一个方便的地方来添加int-to-char类型的错误检查,并且在需要多次使用它们时更简短、更清楚。
这取决于你想做什么:
如果要以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所代表的数字。
C和c++总是将类型提升到至少int。此外,字符字面量在C中是int类型,在c++中是char类型。
可以通过赋值给int类型来转换char类型。
char c = 'a'; // narrowing on C
int a = c;
对于char或short to int,只需要赋值。
char ch = 16;
int in = ch;
与int64相同。
long long lo = ch;
所有值都是16。