atwiki-logo
  • 新規作成
    • 新規ページ作成
    • 新規ページ作成(その他)
      • このページをコピーして新規ページ作成
      • このウィキ内の別ページをコピーして新規ページ作成
      • このページの子ページを作成
    • 新規ウィキ作成
  • 編集
    • ページ編集
    • ページ編集(簡易版)
    • ページ名変更
    • メニュー非表示でページ編集
    • ページの閲覧/編集権限変更
    • ページの編集モード変更
    • このページにファイルをアップロード
    • メニューを編集
    • 右メニューを編集
  • バージョン管理
    • 最新版変更点(差分)
    • 編集履歴(バックアップ)
    • アップロードファイル履歴
    • ページ操作履歴
  • ページ一覧
    • ページ一覧
    • このウィキのタグ一覧
    • このウィキのタグ(更新順)
    • このページの全コメント一覧
    • このウィキの全コメント一覧
    • おまかせページ移動
  • RSS
    • このウィキの更新情報RSS
    • このウィキ新着ページRSS
  • ヘルプ
    • ご利用ガイド
    • Wiki初心者向けガイド(基本操作)
    • このウィキの管理者に連絡
    • 運営会社に連絡(不具合、障害など)
ページ検索 メニュー
雑記
  • ウィキ募集バナー
  • 目安箱バナー
  • 操作ガイド
  • 新規作成
  • 編集する
  • 全ページ一覧
  • 登録/ログイン
ページ一覧
雑記
  • ウィキ募集バナー
  • 目安箱バナー
  • 操作ガイド
  • 新規作成
  • 編集する
  • 全ページ一覧
  • 登録/ログイン
ページ一覧
雑記
ページ検索 メニュー
  • 新規作成
  • 編集する
  • 登録/ログイン
  • 管理メニュー
管理メニュー
  • 新規作成
    • 新規ページ作成
    • 新規ページ作成(その他)
      • このページをコピーして新規ページ作成
      • このウィキ内の別ページをコピーして新規ページ作成
      • このページの子ページを作成
    • 新規ウィキ作成
  • 編集
    • ページ編集
    • ページ編集(簡易版)
    • ページ名変更
    • メニュー非表示でページ編集
    • ページの閲覧/編集権限変更
    • ページの編集モード変更
    • このページにファイルをアップロード
    • メニューを編集
    • 右メニューを編集
  • バージョン管理
    • 最新版変更点(差分)
    • 編集履歴(バックアップ)
    • アップロードファイル履歴
    • ページ操作履歴
  • ページ一覧
    • このウィキの全ページ一覧
    • このウィキのタグ一覧
    • このウィキのタグ一覧(更新順)
    • このページの全コメント一覧
    • このウィキの全コメント一覧
    • おまかせページ移動
  • RSS
    • このwikiの更新情報RSS
    • このwikiの新着ページRSS
  • ヘルプ
    • ご利用ガイド
    • Wiki初心者向けガイド(基本操作)
    • このウィキの管理者に連絡
    • 運営会社に連絡する(不具合、障害など)
  • atwiki
  • 雑記
  • 100 × 200 =32?:変数のオーバーフローの話

雑記

100 × 200 =32?:変数のオーバーフローの話

最終更新:2006年02月17日 00:36

匿名ユーザー

- view
管理者のみ編集可
変数には「型」があります。

この「型」って言うのは何なのかというと、
主に値を格納できるサイズの違いです。


C言語の場合、整数型の変数の型としては
char、int、short int、long int、long long int 
がありますね。
(実数型も入れたらdouble、floatなどもありますが)

それぞれ、1byte、2byte、4byte、8byteの領域を持っています。

1byteは8bitでした。なので、1byteで256通りの状態を表せるのでした。

ということは、
2byteなら256×256通り、
4byteなら256の4乗通り、
8byteなら256の8乗通りの状態が表せるわけです。

これは逆に言うと、ある型で表せる範囲が限定されているということでもあります。

unsigned long long intなら0~18,446,744,073,709,551,615まで表せるわけで、まあ普通の数値であれば収まるとは思いますが。

でも例えばcharの変数には1000なんて数字を表すことはできません。

これは結構、不便なことなのです。それは、

例えばunsigned charの変数ca,cbがあったとします。
この二つの変数の乗算の結果を受け取るためには、
unsigned shortの変数が必要となります。
unsigned short同士の乗算であれば、unsigned longがやはり同様に必要です。

なぜかというのはお分かりだと思います。
計算の結果が変数の表せる値の範囲におさまらないことがあるためです。

このような「変数の表せる値の範囲におさまらない」値を代入しようとした時には、はみ出した部分は捨てられてしまいます。これを「変数のオーバーフロー」といいます。

例えば、
unsigned char ca = 100, cb = 200; 
ca *= cb; 
などとするとcaには20000(0x4E20)が入って欲しいわけですが、caは1byteしかないためはみ出した部分(0x4E)が捨てられます。
なので、結果としてcaには32(0x20)が格納されるわけです。

100×200の答えが、32になってしまうわけです。恐ろしいですね。

同様に、100 + 200も300(0x012C)ではなく44(0x2C)となります。

結局、たとえlong long intを使ったとしても、表せる状態は多くなりますが限界があることには変わりません。

変数の計算(特に加算・乗算)には特に注意をしましょう。



逆に、この切り捨てられることを利用したのがチェックサムと呼ばれるデータの整合性の保障方法です。
あるデータが100byteあるとして、
unsigned char dat[100]; 
unsigned char sum; 
int i; 
・・・ 
for(i = 0; i < sizeof(dat); i++) 
{ 
  sum += dat[i]; 
} 
などとして1byteのサム(SUMとは合計のこと)をとります。
オーバーフローすることを逆手に取るわけです。

通信する際にデータの最後にこのサム値を付加してやり
受信側でも受信後同様の処理を行って、
計算したサムと受信したサム値が一致していればノイズなどがのることなく正常に受信できたと解釈できるわけです。

もちろん、1/255の確立で偶然一致することもありえます。
(例えばデータ{100,200}のチェックサムは0x2cですが、
データ{256,200}のチェックサムも0x2cとなってしまいます)

しかしながら通信におけるデータの整合性チェックは簡便かつ軽量であることも求められるので、クリティカルなデータで無い場合にはこれで十分チェックの役割を果たします。


変数の表せる範囲に限界があるということは、結構見落としがちなことで、思わぬ不具合につながることがあります。

プログラムを書いた本人は思い込みもあるので、ソースを追っていっても不具合の原因がわからず、デバッガでステップ実行していったりして始めて原因がわかるようなことにもなりかねません。

「数値」は最も基本的で、もっとも扱うことの多いデータです。だからこそ、たかが足し算、掛け算であってもプログラミングする際にはキチンと気をつけることが重要だと思います。



【おまけ】
bitを表示するデバッグ用関数。
いろいろな変数を食わせて雰囲気つかんでください。

使い方:
第一引数にデバッグ用の文字列
第二引数にbitデータのポインタ
第三引数にbitデータのサイズ(byte単位)
※以下のコードはWebできれいに見せるために
 全角スペースを含んでいます!!
void vDbgBit(char* str, unsigned char* ucp, size_t len) 
{ 
  unsigned char ucWork, i; 

  printf("[DBG]vDbgBit:%s [", str); 

  for(i = 0; i < (len * 8); i++) 
  { 
    ucWork = 0x80 >> (i % 8); 
    printf("%c", 
      ((ucp[i / 8] & ucWork) ? '1' : '0')); 
    if(!(i / 4)) 
    { 
    printf(" "); 
    } 
  } 
  printf("]\n"); 
} 
「100 × 200 =32?:変数のオーバーフローの話」をウィキ内検索
LINE
シェア
Tweet
雑記
記事メニュー
トップページ

本棚


両手で1000まで数えられますか?:2進法の話
数値 - 危険物取り扱い注意
100 × 200 =32?:変数のオーバーフローの話
パリティビット
小数の扱いについて
ぽいんた
ぽいんた2
ぽいんた3
ジ・オリジン
ジ・オリジン:補足
かっこつける話
かっこつける話2
文字列のこと
タイミングの話
拡張性の話
取り込む話
staticな話

コンパイルの話1
コンパイルの話2:止まらぬビルド
コンパイルの話3:マシン語に落ちるということ1:メモリの話
コンパイルの話4:マシン語に落ちるということ2:最適化
コンパイルの話5:マシン語に落ちるということ3:変数とスタック
コンパイルの話6:コンパイラはそもそも何をやってくれるのか??
リンクの話
プリプロセッサの話

OS、というもの

オブジェクト指向1
オブジェクト指向:2
オブジェクト指向:3

オブジェクト指向:番外 C言語のソースファイルの話
オブジェクト指向:番外 C言語での「再利用性」と「カプセル化」データ構造とアルゴリズム


抽象的な話

寝込んで布団の中で考えたこと
こんなの、常識??
お仕事プログラミング
ソフトでハードなプログラム
プログラムするということ
お勉強
プログラムを学ぶということの補足
C言語:「学問」と「実務」
統合開発環境
C言語ってポータブルですか?
C言語ってポータブルですか?:2
あなたは、どう読みますか?
ああ勘違い
試してガッテン
低級品
質問をするということ
ポカ
「何もしない」 != 「無駄」
エディタの話
もっと手を抜こう

いまどきの、アセンブラ

VisualStudio2005
VisualStudio2005:2

戦争の防ぎ方、に対する私の考え
身近な差別
改革
地球に優しいなんて大嘘
統計で嘘をつく方法

言葉について
言葉について:2

神が死んだということ
善悪の彼岸から、力への意思を目覚めさせるということ

本を読むということ
本を読むということ:2

絵を描く話
地図
地球儀

オカルトのお話
がんだむさん
RPGソフトウェア
記紀神話の不思議



メニュー
記事メニュー2
つらつらと、日々考えたことを書いていこうと思います。
blogでなくてwikiなのは、なんとなくです。
将来的に、他の方にも編集をしてもらえたら、楽かな、と。

さまざまなガラクタな話しかありませんが。。まさに雑記。



  • スポーツベットとは?初心者向けに仕組みと楽しみ方を徹底解説!
  • カジノディーラーの魅力と役割
  • タイのカジノの魅力と体験談
  • カジノの種類を知ろう!初心者からプロまで楽しめるカジノゲームの世界
  • 日本のカジノ現状と楽しみ方
  • カジノルーレットの魅力!楽しく遊べるルーレットの全て
  • オンラインカジノでカウンティングはできる?攻略法の使用について
  • オンラインカジノは稼げるのか?勝率をアップさせる儲かる方法を調査
  • 初心者必見!オンラインカジノの基礎講座とおすすめオンカジ3選
  • オンラインカジノって危なくない?どうして始めたの?質問にお答えします。

10 item(s)
Last-Modified:2025/03/07 20:33:00
最近更新されたページ
  • 7079日前

    メニュー
  • 7079日前

    もっと手を抜こう
  • 7084日前

    統計で嘘をつく方法
  • 7090日前

    地球に優しいなんて大嘘
  • 7094日前

    右側
  • 7095日前

    プリプロセッサの話
  • 7096日前

    リンクの話
  • 7098日前

    小数の扱いについて
  • 7099日前

    パリティビット
  • 7101日前

    100 × 200 =32?:変数のオーバーフローの話
もっと見る
最近更新されたページ
  • 7079日前

    メニュー
  • 7079日前

    もっと手を抜こう
  • 7084日前

    統計で嘘をつく方法
  • 7090日前

    地球に優しいなんて大嘘
  • 7094日前

    右側
  • 7095日前

    プリプロセッサの話
  • 7096日前

    リンクの話
  • 7098日前

    小数の扱いについて
  • 7099日前

    パリティビット
  • 7101日前

    100 × 200 =32?:変数のオーバーフローの話
もっと見る
ウィキ募集バナー
新規Wikiランキング

最近作成されたWikiのアクセスランキングです。見るだけでなく加筆してみよう!

  1. 機動戦士ガンダム EXTREME VS.2 INFINITEBOOST wiki
  2. MadTown GTA (Beta) まとめウィキ
  3. R.E.P.O. 日本語解説Wiki
  4. シュガードール情報まとめウィキ
  5. ソードランページ @ 非公式wiki
  6. AviUtl2のWiki
  7. Dark War Survival攻略
  8. シミュグラ2Wiki(Simulation Of Grand2)GTARP
  9. 星飼いの詩@ ウィキ
  10. 2025.3.15 小田急線運用表
もっと見る
人気Wikiランキング

atwikiでよく見られているWikiのランキングです。新しい情報を発見してみよう!

  1. アニヲタWiki(仮)
  2. ストグラ まとめ @ウィキ
  3. 機動戦士ガンダム EXTREME VS.2 INFINITEBOOST wiki
  4. ゲームカタログ@Wiki ~名作からクソゲーまで~
  5. 初音ミク Wiki
  6. 検索してはいけない言葉 @ ウィキ
  7. 発車メロディーwiki
  8. 機動戦士ガンダム バトルオペレーション2攻略Wiki 3rd Season
  9. モンスター烈伝オレカバトル2@wiki
  10. Grand Theft Auto V(グランドセフトオート5)GTA5 & GTAオンライン 情報・攻略wiki
もっと見る
全体ページランキング

最近アクセスの多かったページランキングです。話題のページを見に行こう!

  1. 参加者一覧 - ストグラ まとめ @ウィキ
  2. 魔獣トゲイラ - バトルロイヤルR+α ファンフィクション(二次創作など)総合wiki
  3. 機体一覧 - 機動戦士ガンダム EXTREME VS.2 INFINITEBOOST wiki
  4. 鬼レンチャン(レベル順) - 鬼レンチャンWiki
  5. いのちのたま(ポケモン) - アニヲタWiki(仮)
  6. 千鳥の鬼レンチャン 挑戦者一覧 - 千鳥の鬼レンチャン サビだけカラオケデータベース
  7. ドンキーコング バナンザ - アニヲタWiki(仮)
  8. チンポ画像収集場 - 検索してはいけない言葉 @ ウィキ
  9. 危険度7 - 検索してはいけない言葉 @ ウィキ
  10. フランクリン・リチャーズ - アメコミ@ wiki
もっと見る

  • このWikiのTOPへ
  • 全ページ一覧
  • アットウィキTOP
  • 利用規約
  • プライバシーポリシー

2019 AtWiki, Inc.