これまで、int型、double型、そしてchar型という3つのデータ型を使ってきました。

ここでは、

基本データ型

char型

char型は、文字を表します。 整数として扱うことができます。

符号付き整数型

これまで使ってきたint型は、符号付きの整数を表します。 符号付きであることは省略できるので、これまでは省略していました。 省略せずに書くと、signed int型です。

int型の記憶容量(サイズ)を基本として、int型より小さいサイズにしたり、大きいサイズにすることができます。

符号付き整数型をサイズの小さい順に並べると、次のようになります。

  • signed char
  • short (signed short)
  • int (signed int)
  • long (long int, signed long int)
  • long long (long long int, signed long long int)

ただし、実際のサイズは実行環境に依存します。 long型とlong long型のサイズが同じという環境もあります。

符号なし整数型

符号なし整数型は、符号付きであることを表すsignedの代わりに、unsignedと書いて表します。

また、C99から、0または1で論理値を表す_Bool型が追加されました。

符号なし整数型をサイズの小さい順に並べると、次のようになります。

  • _Bool
  • unsigned char
  • unsigned short int (unsigned short)
  • unsigned int
  • unsigned long (unsigned long int)
  • unsigned long long (unsigned long long int)

浮動小数点型

double型は、倍精度の浮動小数点数を表します。 浮動小数点数については、計算機アーキテクチャーや数値解析Iの授業できちんと勉強してください。

浮動小数点数型には、double型の半分のサイズのfloat型と、double型よりも大きなサイズのlong double型があります。

(実数を表す)浮動小数点数型をサイズの小さい順に並べると、次のようになります。

  • float
  • double
  • long double

また、C99から、複素数を表す型(型名の後ろに_Complexが付く)が追加されました。

複素数を表す浮動小数点数型をサイズの小さい順に並べると、次のようになります。

  • float _Complex
  • double _Complex
  • long double _Complex

符号付き整数型と符号なし整数型の違い

符号付き整数型では、先頭ビットが符号を表します。 符号なし整数型には、符号を表すビットは存在しません。

このため、符号なし整数型は、符号付き整数型の約2倍の範囲の数を表すことができます。

次のプログラムは、8ビットの大きさの符号付きchar型と符号なしchar型に、8ビット符号なし整数の最大値である255を代入して表示します(プログラム1)。

    signed char sc = 255;
  unsigned char uc = 255;

  printf(">> %d\n", sc);
  printf(">> %d\n", uc);

これを実行すると、次のようになります。

luna% a.out
>> -1
>> 255

255は、2進数で表すと 11111111 ですが、符号付き整数では負の数を2の補数として表現するので、これを2の補数として解釈し、-1 と出力されています。 2の補数については、計算機アーキテクチャーの授業できちんと勉強してください。

また、符号付き整数と符号なし整数では、あとで勉強するシフト演算の振る舞いが異なります。

演習1

プログラム1を作成し、実行結果を確認せよ。

列挙型

int型の値で、かつ、取りうる値が決まっているとき、列挙型とすることによって、変数の値を制限することができます。

列挙型は、次のように宣言します。

  printf("%d\n", 10);
  printf("%d\n", 010);
  printf("%d\n", 0x10);
  printf("%04x\n", 16);

列挙子には、先頭から順に 0, 1, 2 と値が割り当てられますが、代入演算子 = をつけて値を指定することもできます。 また、同じ値を複数の列挙子に割り当てることもできます。

次のプログラムは、enum deptという名前の列挙型を宣言し、変数 d をenum dept型として宣言しています(プログラム2)。 こうすることによって、変数 d にはenum dept型の列挙子の並びに宣言された値しか代入できなくなります。

luna% a.out
10
8
16
0010

これを実行すると、次のようになります。

  printf("%f\n", 1.01);
  printf("%f\n", 1.01e2);
  printf("%f\n", 1.01e-2);
  printf("%f\n", 0x1.01p12);

演習2

プログラム2を作成し、実行結果を確認せよ。

定数

変数がプログラム実行中に変化する可能性がある数であるのに対し、定数はプログラム実行中に変化することがありません。プログラムの中に直接書かれている値も、定数です。

正定数

正定数には、10進数、8進数、16進数があります。

10進数は、0 以外の数字で始まり0 から 9 までの数字だけで表します。 たとえば、10 は、10進数の 10 を表します。 整数をprintf関数を用いて10進数表記で出力するときの変換指定子は %d です。

8進数は、0 で始まり0 から 7 までの数字だけで表します。 たとえば、010 は、8進数の 10 を表し、10進数にすると 8 です。 符号なし整数をprintf関数を用いて8進数表記で出力するときの変換指定子は %o です。

16進数は、0x で始まり0 から 9 までの数字と a から f までの英字だけで表します。 たとえば、0x10は、16進数の 10 を表し、10進数にすると 16 です。 符号なし整数をprintf関数を用いて16進数表記で出力するときの変換指定子は %x です。

定数が符号なし整数や(上位が 0 の)長いビット列を表すこともあるので、定数の後ろに接尾語をつけて定数の型を明確にすることができます。 接尾語をつけないとint型とみなされます。

接尾語 u は、unsigned int型であることを表します。 接尾語 l は、long型(long int型)であることを表します。 接尾語 ll は、long long型(long long int型)であることを表します。

浮動小数点定数

浮動小数点定数には、10進浮動小数点数、指数表現10進浮動小数点数、指数表現16進浮動小数点数があります。

10進浮動小数点数は、0 以外の数字で始まり、0 から 9 までの数字と小数点だけで表します。 たとえば、1.01 は、10進数の 1.01 を表します。

指数表現10進浮動小数点数は、10進浮動小数点数の後に e と指数部を表す10進数をつけて表します。 たとえば、1.01e2 は、[math]1.01 \times 10^2[/math]で 101、1.01e−2 は、[math]1.01 \times 2^{-2}[/math]で 0.0101 を表します。

指数表現16進浮動小数点数は、0x で始まり、0 から 9 までの数字と a から f までの英字と小数点、その後に p と指数部を表す10進数をつけて表します。 基数は2なので、指数部は2の何乗倍であるかを表します。 たとえば、0x1.01p12 は、16進数 1.01 の2の12乗倍を表し、2進数 0001.0000 0001 を左に12ビットだけシフトしたものなので2進数 0001 0000 0001 0000、10進数にすると 4,102 です。 printf関数で指数表現16進浮動小数点数の形を出力するときの変換指定子は ''

浮動小数点定数にも接尾語があります。 接尾語をつけないとdoube型であるとみなされます。

接尾語 f は、float型であることを表します。 接尾語 l は、long double型であることを表します。

文字定数

文字定数は、シングル・クォーテーションで囲まれた文字です。

英大文字 A-Z、英小文字 a-z、数字 0-9、記号 ! " # % & ( ) * + , - . / : ; < = > ? [ ] ^ { | } ~、または \ で始まるエスケープ・シーケンスのいずれかです。

値を変更できない変数

変数を宣言するときに、型名の前に const を付けて宣言すると、その変数には初期化のときにしか値を代入できなくなり、プログラムの実行中に値を変更できなくなります。

1.010000
101.000000
0.010100
4112.000000

型が配列でないときは、初期化子を囲む波括弧 { } は省略できます。

変数の有効範囲(スコープ)

変数は、宣言する場所によって、その有効範囲が異なります。

ブロック有効範囲

波括弧 { } で囲まれたブロック内で宣言された変数は、そのブロック内だけで有効です。

C89ではブロックの先頭で宣言しなければなりませんでしたが、C99ではこの制限がなくなりました。

ただし、現在のgcc 4.xでC99に準拠したプログラムをコンパイルするには、stdオプションを指定する必要があります。

  const 型 定数名 = { 初期化子 };

ファイル有効範囲

変数の有効期限

静的記憶域期間

自動記憶域期間

C言語の世界標準規格(おまけ)

C言語は、1989年に最初の世界標準規格が作られました。 この規格は、C89と呼ばれています。

その後、1999年と2011年に規格が改定され、それぞれ、C99C11と呼ばれています。 (現在のgccには、C99とC11のほとんどの機能が実装されています。)

C言語の教科書、参考書を読むときには、どの規格に基づいて書かれているのか、確認しておきましょう。

トップ   新規 一覧 単語検索 最終更新   ヘルプ   最終更新のRSS