アフィリエイト広告を利用しています

広告

posted by fanblog

2017年11月15日

《その129》 符号付き整数と符号無し整数(3)


 符号付き整数と符号無し整数

 前回《その128》に引き続いて、ちょっとしつこいですが、もう一回だけ・・・ (ノω・`;


 自分の使っている処理系では、unsigned char は 8ビット、int は 32ビットです。
この二つの整数型間の型変換のルールについて、新版明解C++中級編に次のように書かれています。


[1] unsigned char x から int への型変換

       変換後の値 … x


[2] int x から unsigned char への型変換

  (@)  x >= 0 の場合
       変換後の値 … x % (1 + 255)

  (A)  x < 0 の場合
       変換後の値 … (1 + 255) - (-x % (1 + 255))




[1] のときは値が変わらないので問題なしです。


[2] の (@) のときは、

 例えば、int の 2147483645 を unsigned char に型変換すると、

2147483645 % (1 + 255)

 を計算して、253 になります。


[2] の (A) のときは、

 例えば、int の -6 を unsigned char に型変換すると、

(1 + 255) - (-(-6) % (1 + 255))

 を計算して、250 になります。


 この計算が何をやってるのか、やっぱりちょっと・・・(;^ω^) なので、ビジュアルでいきます。

d02_00111.png
d02_0012.png

[2] の (@) の場合
int の 2147483645 は 32ビットですが、unsigned char は 8ビットなので、
最初の表の 32ビットの 01111111111111111111111111111101 から
末尾の 8ビットを取り出すと 11111101
二番目の表からこれは unsigned char の 253 だとわかります。

[2] の (A) の場合
int の -6 は 32ビットですが、unsigned char は 8ビットなので、
最初の表の 32ビットの 11111111111111111111111111111010 から
末尾の 8ビットを取り出すと 11111010
二番目の表からこれは unsigned char の 250 だとわかります。



新版 明解C 入門編 (明解シリーズ)

新品価格
¥2,916から
(2017/11/10 13:13時点)

新版 明解C 中級編 (明解シリーズ)

新品価格
¥2,916から
(2017/11/10 13:14時点)





この記事へのコメント
コメントを書く

お名前:

メールアドレス:


ホームページアドレス:

コメント:

※ブログオーナーが承認したコメントのみ表示されます。

この記事へのトラックバックURL
https://fanblogs.jp/tb/6972066
※ブログオーナーが承認したトラックバックのみ表示されます。

この記事へのトラックバック

 たまに、クリック お願いします m(_ _)m

 AA にほんブログ村 IT技術ブログ C/C++へ

こうすけ:メール kousuke_cpp@outlook.jp

【1】★★C++ 記事目次★★ ← 利用可能です。
・新版明解C++入門編 / 新版明解C++中級編
・その他 C++ 関連記事

【2】★★こうすけ@C#★★
・C# の初歩的な記事


検索
<< 2018年08月 >>
      1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31  
プロフィール
こうすけさんの画像
こうすけ

 たまに、クリック お願いします m(_ _)m

 AA にほんブログ村 IT技術ブログ C/C++へ

こうすけ:メール kousuke_cpp@outlook.jp

【1】★★C++ 記事目次★★ ← 利用可能です。
・新版明解C++入門編 / 新版明解C++中級編
・その他 C++ 関連記事

【2】★★こうすけ@C#★★
・C# の初歩的な記事


×

この広告は30日以上新しい記事の更新がないブログに表示されております。