[解決済み] ビットシフトはエンディアンに依存するか?
質問
という数字があるとします。
'numb'=1025 [00000000 00000000 00000100 00000001]
を表現しています。
リトル・エンディアン・マシンについて。
00000001 00000100 00000000 00000000
Big-Endian Machineについて。
00000000 00000000 00000100 00000001
ここで、10ビットに左シフトをかけると(つまり、numb <<= 10)、こうなるはずだ。
[A] Little-Endian Machineで。
GDBで気づいたのですが、リトルエンディアンは3つのステップで左シフトを行います。[処理内容を理解しやすくするために、3つのステップを示しました]。
-
ビッグエンディアン条約でNo.を処理する。
00000000 00000000 00000100 00000001
-
Left-Shiftを適用します。
00000000 00010000 00000100 00000000
-
結果をもう一度リトルエンディアン語で表現してください。
00000000 00000100 00010000 00000000
[B]. Big-Endian Machineで。
00000000 00010000 00000100 00000000
私の質問です。
リトルエンディアンの左シフトを直接適用した場合 という規約があるはずです。
numb
:
00000001 00000100 00000000 00000000
numb << 10
:
00010000 00000000 00000000 00000000
でも実は、与えるんです。
00000000 00000100 00010000 00000000
2番目の結果だけを得るために、上記では3つの仮想的なステップを示しました。
上記の2つの結果が異なる理由を教えてください:実際の結果は
numb << 10
が期待される結果と異なる。
どのように解決するのですか?
エンディアンとは、メモリにおける値の格納方法のことです。プロセッサにロードされた場合、エンディアンに関係なく、ビットシフト命令はプロセッサのレジスタの値に対して動作しています。したがって、メモリからプロセッサへのロードはビッグエンディアンに変換することと同じで、シフト動作が次に来て、新しい値がメモリに戻され、そこで再びリトルエンディアンのバイトオーダーが有効になるのです。
更新、@jwwに感謝。PowerPC では、ベクターシフトとローテートはエンディアンに依存します。ベクターレジスターに値があり、その値をシフトすることができます。 はリトルエンディアンとビッグエンディアンで異なる結果をもたらします。 .
関連
-
解決済み] g++ コンパイルエラー: ')'トークンの前に一次式があることが予想される
-
Cエラー [エラー] 代入_Ashesの左オペランドにlvalueが必要です-プログラマーズ・シークレット
-
関数 'malloc' の暗黙の宣言に対する解決策
-
警告:符号付き整数式と符号なし整数式の比較 [-Wsign-compare]
-
警告: 'struct XXX' はパラメータリストの内部で宣言されています。
-
[解決済み] C 言語で const char* を char* に変換するには?
-
[解決済み] 1ビットのセット、クリア、トグルはどのように行うのですか?
-
[解決済み] C言語では「?」演算子は何をするのですか?
-
[解決済み] C言語における「static」の意味とは?
-
[解決済み] なぜ16進数には0xがつくのですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[C] レポートエラー 代入の左オペランドとしてlvalueが必要
-
ポインタ定数および定数ポインタ
-
Solve Dev-c++ [エラー] 'for' ループの初期宣言は、C99 または C11 モードでのみ許可されます。
-
未定義の `__isoc99_sscanf' への参照
-
C - 添え字の値が配列でもポインタでもベクトルでもないエラー
-
エラー: 宣言されていない識別子 'bool' の使用と C コンパイラでの問題点
-
警告: 'struct XXX' はパラメータリストの内部で宣言されています。
-
[解決済み] 初期化でポインタ対象の型から修飾語を捨てる
-
[解決済み] なぜsizeof(x++)はxをインクリメントしないのですか?
-
[解決済み] なぜalloca()の使用はグッドプラクティスとみなされないのでしょうか?