C 言語で char が 1 バイトである理由

C Yan Yude Char Ga 1 Baitodearu Li You



C プログラマーとして、C 言語で char のサイズが 1 バイトしかない理由を疑問に思ったことがあるでしょう。些細なことのように思えるかもしれませんが、その背後にある理由を見つけることは、より効果的なプログラムを作成するのに役立ちます。

この記事では、C 言語で 1 バイト char を使用する理由に焦点を当てます。

C言語のcharとは

文字と文字を格納するために、C は char 型を使用します。 C の文字 (char) 値は 1 バイトのメモリに保持され、値の範囲は 0 ~ 255 または -128 ~ 127 です。コンピュータは、文字を表すために、数値コードを使用して各整数を一致する文字にマップする必要があります。最も一般的に使用される数値コードは ASCII で、これは情報交換のための米国標準コードを表します。







C 言語で char が 1 バイトである理由

char データ型が 1 バイトである理由は複数あります。



1 : 1 つ目の理由は、C 標準ライブラリで char サイズが事前定義されているためです。どのコンパイラを使用しても、1 バイト値を介して文字を格納および操作します。最も可能性の高い説明は、標準文字セットの char の (バイナリ) 同等物が 1 バイトに収まるということです。 C の初期開発時には、最も使用されていた標準は ASCII と EBCDIC で、それぞれ 7 ビットと 8 ビットのエンコードが必要でした。したがって、文字セット全体を記号化するには 1 バイトで十分でした。



2 : ASCII 文字は通常、256 文字のみを含む char で表されます。したがって、0 から 255 までの数値の範囲、つまり 8 ビット = 1 バイトを指定するだけで済みます。





3 : C は 16 ビットのアドレス空間を持つコンピューターで使用するように設計されているため、文字列に 1 バイトを超える文字列を使用することは無駄であると考えられていました。

4 : C 言語で 1 バイトの char を使用すると、プログラマーは自分のコードを別のマシンに簡単に移植できます。



5 : Java や C++ など、1 バイト文字を使用するプログラミング言語がいくつかあるため、異なる言語間での相互運用が容易になります。

char データ型のサイズを調べる方法

のサイズ 演算子を使用して、特定のプラットフォームでの型または変数の正確なサイズを決定できます。式 sizeof(type) は、オブジェクトまたは型のストレージ サイズをバイト単位で返します。

#include
int メイン ( ) {
char ch;
printf ( '文字のサイズ: %d バイト \n ' 、 のサイズ ( チャンネル ) ) ;
戻る 0 ;
}

上記のコードでは、 のサイズ の大きさを求める関数 チャー これは、以下の出力に示されているコンパイラによって確認された 1 バイトです。

出力

C言語での1バイト文字のメリットとデメリット

C 言語で 1 バイト char を持つことの利点は次のとおりです。

  • これにより、C 言語がより効率的になります。
  • 文字データ型にバイトを使用する他の言語との C 言語の一貫性を高めます。
  • 文字は、より複雑な操作を受けることができるようになりました。

1 バイトの char で得られる唯一の欠点は、一部の言語では 256 文字を超える文字が必要な場合があるため、大きなサイズの文字を扱うのが困難になることです。

結論

上記のガイドラインでは、C 言語の char データ型が 1 バイトであることがわかりました。これは、すべてのプラットフォームで一貫性を維持するためです。 char サイズを 1 バイトに固定することで、使用しているハードウェアやコンパイラに関係なく、同じ操作を異なるマシンで一貫した精度で実行できます。