
No.5ベストアンサー
- 回答日時:
atoiを使う限り、あらゆる(標準規格に準拠した)Cコンパイラで使えるような厳密なエラー検出法はありません。
shortは16bit以上であることが保証されているだけで、short=int=16bitという可能性もあるからです。解決方法は、自分でatoiライクな関数を書いて、自分で調べることです。
現実的には、int=32bit,short=16bitと仮定して、一旦intの変数に入れ、shortに入るかどうか確認することでしょうか。それでも、sizeof(int)=sizeof(short)なら、エラーがあっても知らないよという、コメントを書いておくべきでしょう。
ちなみに、errnoは、システムコールを呼んだ際のエラー原因を返すための変数です。atoiはシステムコールではないし、システムコールを呼ぶわけでもありません。
signalは、0による割り算は検出できる処理系が多いですが、オーバフローはありません。
No.7
- 回答日時:
atoi ではなくて strtol を使えば、
オーバーフロー(long に対する)は検出できます。
errno に ERANGE が設定されるので。
long に収まって short に収まらない場合を検出するには、
strtol の戻り値を一旦 long で受けて、
SHRT_MAX (limits.h で定義されています)
と比較すればいんじゃないかと。
No.6
- 回答日時:
shortは16ビットと決まっているわけではなく「intよりも長くない」と決まっているだけです。
また、C言語の規格ではデータオブジェクトのサイズに「ビット」という単位は使いません。
規格上決まっているのは「charが1バイト」のみです。
厳密に「移植性」を考えた場合、1バイトが9ビットのコンピュータ、負の表現が1の補数であるコンピュータの存在が無視できません。
結果、より大きいことが保証されているデータオブジェクトを経由して調べる以外に方法はありません。
long long a ;
short b ;
b = (short)(a = atoi(string)) ;
if ((long long)b != a) {
// 何らかのエラーが起こったため、値が変わっている。
//オーバーフローの可能性が高い
long long型は唯一「整数型でintよりも長い」ことが保証されたデータオブジェクトです。
No.4
- 回答日時:
ごめん、質問よく見てなかったけど、「65535」ってのは、unsigned shortのMAXです。
また、if(atoi(str) >= SHORT_MAX)
の等号は不要でした(はずかし)。
No.3
- 回答日時:
>とでもしないと、移植性がないのでは?
あっそうだったんですか?
short型もint型のように処理系に依存するんですか?
常に2バイト長だと思っていましたし、そのような記述の本しか読んだことなかったです。
No.1
- 回答日時:
自分で対処するしかないんじゃない。
#define SHORT_MAX 65535
if(atoi(str) >= SHORT_MAX){
fprintf(stderr, "ERROR: Over flow\n");
return -1; /* なり exit(-1)なり */
}else{
seisuu = atoi(str);
}
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
実行時エラー 438になった時の...
-
Outlook.ApplicationをCreateOb...
-
なぜこんな初歩的なVBAのIf文で...
-
VBAでのエラー
-
【マクロ】エラー【#DIV/0!】が...
-
実行時エラー3001「引数が間違...
-
VB.netでのオートフィルタについて
-
ADODB.Streamを使用してUTF-8を...
-
デバッグ時はOK、デバッグ無し...
-
C言語 mallocのエラーに関する質問
-
実行時エラー -'-2147417848
-
EXCEL/VBAで、自分のPCだけエラ...
-
VB6+SQL サーバー 2000 で 実行...
-
実行時エラー9 インデックスが...
-
VBAでピボットテーブルの作成(...
-
VBA Sortメソッドについて
-
EOFError: EOF when reading a ...
-
なぜエラーになるのでしょうか...
-
実行時エラー48発生時のDLL特定...
-
『実行時エラー 5 プロシージャ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
実行時エラー 438になった時の...
-
VBAがブレークモードになっ...
-
【マクロ】エラー【#DIV/0!】が...
-
なぜこんな初歩的なVBAのIf文で...
-
VBAでのエラー
-
実行時エラー -'-2147417848
-
実行時エラー48発生時のDLL特定...
-
マクロについて教えてください...
-
ExcelVBA Range クラスの Page...
-
EXCEL VBAマクロ中断でデバッグ...
-
実行時エラー3001「引数が間違...
-
EXCEL/VBAで、自分のPCだけエラ...
-
VB6+SQL サーバー 2000 で 実行...
-
VBAのエラー発生場所をメッセー...
-
ADODB.Streamを使用してUTF-8を...
-
【Excel VBA】マクロをボタンに...
-
OLEDB.NETで接続できない
-
なぜエラーになるのでしょうか...
-
INSERT INTOステートメント構文...
-
Outlook.ApplicationをCreateOb...
おすすめ情報