「C言語」の版間の差分
提供: Wikinote
細 (→下位 8 ビットマスク) |
細 |
||
| 行1: | 行1: | ||
| − | C | + | C 言語 <strike>''最高''</strike> 再考。 |
== 覚え書き == | == 覚え書き == | ||
2009年2月3日 (火) 20:56時点における版
C 言語 最高 再考。
覚え書き
printf のフォーマット
% で始まり、変換指定子で終わる。以下のプログラムで実験。
#include <stdio.h>
int main(void) {
float f;
printf("1234567890 1234567890\n");
printf("---------------------\n");
f = 123.456;
printf("%f %f\n", f, -f); // デフォルト
printf("%.2f %.2f\n", f, -f); // 小数点以下桁 (精度) 指定
printf("%10f %10f\n", f, -f); // 最小幅指定
printf("%10.2f %10.2f\n", f, -f);
printf("%010.2f %010.2f\n", f, -f); // 0 で埋める
printf("%-10.2f %-10.2f\n", f, -f); // 左揃え
printf("%+10.2f %+10.2f\n", f, -f); // 必ず符号をつける
printf("%*.2f %*.2f\n", 15, f, 15, -f); // 引数による幅指定
printf("%*3$.2f %*3$.2f\n", f, -f, 20); // 引数による幅指定 (引数指定)
printf("%.*3$f %.*3$f\n", f, -f, 10); // 引数による精度指定 (引数指定)
return 0;
}
実行結果は下記のようになる。
$ gcc -o printf printf.c; ./printf
1234567890 1234567890
---------------------
123.456001 -123.456001
123.46 -123.46
123.456001 -123.456001
123.46 -123.46
0000123.46 -000123.46
123.46 -123.46
+123.46 -123.46
123.46 -123.46
123.46 -123.46
123.4560012817 -123.4560012817
定数
| 定数の型 | 例 |
|---|---|
long
|
123456789L
|
unsigned
|
123U
|
unsigned long
|
123456789UL
|
double
|
123.456
|
unsigned double
|
123.456L
|
float
|
123.456F
|
| 8 進数 | 0123
|
| 16 進数 | 0x335F
|
16 進数 unsigned long
|
0x12ABUL
|
| 文字定数 | 'a'
|
| 8 進数ビットパターン | '\013'
|
| 16 進数ビットパターン | '\x1A'
|
| 文字列定数 | "hello, world"
|
※大文字、小文字の区別はない。(U, L, X はそれぞれ u, l, x でも同じ。)
- 列挙定数 (
enum) の初期値は 0。 - 文字列定数はコンパイル時に連結できるので、以下のような書き方も可能である。長い文章を出力するときなどに便利。OSS のソースを見ても、\ で折り返してるケースが多いが、こちらの方がインデントなどなにかと使いやすいように思える。
printf("aaaaaaaaaaaaaaa"
"bbbbbbbbbbbbbbb"
"ccccccccccccccc\n");
// print "aaaaaaaaaaaaaaabbbbbbbbbbbbbbbccccccccccccccc\n"
その他 (細かいこと)
-
#define行の末尾にはセミコロンはいらない -
externは宣言であって、定義ではない。つまり、領域の確保などは行われない。別ファイルで定義される変数などを利用する際に使う。疑問:ヘッダファイル中でextern宣言した場合、定義するファイルからそのヘッダをincludeしてもよいのか。⇒ よい (少なくとも、エラーや警告は出ない。)
テクニック
下位 8 ビットマスク
~ (1 の補数) やシフト演算子をうまく使うことで、ビット処理を行う。
x = x & ~0xFF;