CおよびC ++でcharをintに変換する

2011年02月17日に質問されました。  ·  閲覧回数 1.9M回  ·  ソース

mainajaved picture
2011年02月17日

CおよびC ++でcharintに変換するにはどうすればよいですか?

回答

Foo Bah picture
2011年02月17日
601

あなたがやりたいことに依存します:

値を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') a - '0'と同等です。つまり、文字のASCII値が互いに減算されます。 0はASCIIテーブルの1直前にあるため(以下同様に9 )、2つの違いにより、文字a数値が得られます。を表します。

Vlad Isoc picture
2015年06月09日
114

さて、ASCIIコードでは、数字(数字)は48から始まります。 あなたがする必要があるのは:

int x = (int)character - 48;

または、文字「0」のASCIIコードは48

int x = character - '0';  // The (int) cast is not necessary.
Matt Joiner picture
2011年02月17日
62

CおよびC ++は、常に型を少なくともintプロモートします。 さらに、文字リテラルは型であるint C内とchar C ++で。

int割り当てるだけで、 charタイプを変換できます。

char c = 'a'; // narrowing on C
int a = c;
Lundin picture
2011年02月17日
34

charは1バイトの整数です。 char型には魔法はありません! shortをintに、intをlongに割り当てることができるのと同じように、charをintに割り当てることができます。

はい、プリミティブデータ型の名前はたまたま「char」です。これは、文字のみを含める必要があることを示唆しています。 しかし実際には、「char」は、言語を学ぼうとするすべての人を混乱させるための貧弱な名前の選択です。 より適切な名前はint8_tであり、コンパイラが最新のC標準に準拠している場合は、代わりにその名前を使用できます。

もちろん、文字列処理を行うときはchar型使用するもできます

  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として扱われます。

Fred Nurk picture
2011年02月18日
18

(この回答はC ++側に対応していますが、符号拡張の問題はCにも存在します。)

3つすべてのcharタイプ( signedunsigned 、およびchar )の処理は、最初に表示されるよりも繊細です。 0からSCHAR_MAX (8ビットcharは127)の範囲の値は簡単です。

char c = somevalue;
signed char sc = c;
unsigned char uc = c;
int n = c;

ただし、 somevalueがその範囲外の場合、 unsigned charを通過するだけで、3つのタイプすべての「同じ」 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.

これは、符号拡張のため、 isuppertoupperなどのctype.hの関数を使用する場合に重要です。

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 。これは、 ctype.h関数をsafe_ctypeでラップすることで簡単に実行でき

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.

これが機能するのは、3つのcharタイプのいずれかを受け取る関数は、他の2つのcharタイプも受け取ることができるためです。 これは、任意のタイプを処理できる2つの関数につながります。

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)は、負のcharまたは負のsigned charが渡された場合でも、常に非負の値を提供し、 chrは任意の値を取りますordは、まったく同じchar ord生成し、返します。

実際には、これらを使用する代わりにunsigned charキャストするだけですが、キャストを簡潔にラップし、 intからcharへのエラーチェックを追加するのに便利な場所を提供します。

herohuyongtao picture
2014年01月22日
13

static_cast<int>使用します:

int num = static_cast<int>(letter); // if letter='a', num=97

編集:おそらく(int)使用を避けるように努めるべきです

int num =(int)文字;

(int)xの代わりにstatic_cast <int>(x)を使用する 詳細については。

T.E.D. picture
2011年02月17日
7

それはあなたが「変換する」という意味に依存します。

「123456」のように整数を表す一連の文字がある場合、Cでそれを行う一般的な方法は2つあります。atoi()strtol()などの専用変換、または汎用sscanfを使用する() 。 C ++(これは実際にはアップグレードを装った別の言語です)は、3番目の文字列ストリームを追加します。

int変数の1つにある正確なビットパターンをcharとして扱いたい場合は、それが簡単です。 Cでは、さまざまな整数型は、実際の個別の「型」よりも実際には精神状態です。 charが要求された場所で使用を開始するだけで、問題はありません。 コンパイラがときどき泣き言をやめるように明示的な変換が必要になる場合がありますが、必要なのは256を超える余分なビットを削除することだけです。

Henke picture
2017年05月11日
7

私はCで絶対にnullスキルを持っていますが、単純な構文解析の場合:

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;
}
Cheers and hth. - Alf picture
2011年02月17日
3

おそらく、C標準ライブラリの関数を使用するためにこの変換が必要です。

その場合は、(C ++構文)を実行します

typedef unsigned char UChar;

char myCppFunc( char c )
{
    return char( someCFunc( UChar( c ) ) );
}

UChar( c )は、EOFを除いて、C関数でサポートされていない負の値を取り除くためにunsigned charに変換されます。

次に、その式の結果がint正式な引数の実際の引数として使用されます。 intへの自動プロモーションを取得する場所。 または、 int( UChar( c ) )ように最後のステップを明示的に記述することもできますが、個人的には冗長すぎると思います。

乾杯&hth。、

Mathorlaz picture
2011年11月17日
0

"7c7c7d7d7d7d7c7c7c7d7d7d7d7c7c7c7c7c7c7d7d7c7c7c7c7d7c7d7d7d7c7c2e2e2e"ようなchar配列を、「7C」で1つの16進値として表すことができる実際の整数値に変換する際に問題が発生しました。 それで、助けを求めてクルージングした後、私はこれを作成し、共有するのはクールだと思いました。

これにより、char文字列が正しい整数に分割され、私だけでなく多くの人に役立つ可能性があります;)

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;
}

それが役に立てば幸い!