A 回答 (5件)
- 最新から表示
- 回答順に表示
No.5
- 回答日時:
CPUのビット数がアドレス幅を決めるのではありません。
同じ16ビットCPUでもi8086は1MBまで、MC68000は16MBまでのアドレッシングが可能でした。8ビットCPUならば、どれも64KBまでが有効アドレスですが、命令が多機能に出来ているMC6809は他のCPUでは冗長になりがちな処理を短くまとめられるので無駄が少なく、プログラムに必要とされるメモリーの節約と高速化に役立っていました。
また、8086と80386を比べると、同じ1MBしかメモリーを使わなくても、80386の方がレジスタの幅が大きいので32ビット演算が1命令で出来たり、32ビット単位でデータ転送するなど、処理の無駄を減らしたり、高速化が可能になっています。
無駄が減らせるという長所を考慮すると、8ビットCPUはアドレス幅が同じだから皆同じとは言えない面もあるように思います。
CPUは必要に応じたメモリーを扱えれば良いわけで、8ビットCPUでもバンク切り替えで1MBまで使えるように設計されたパソコンもありましたし、32ビットCPUでも初期の32ビットパソコンは16~32MBしか使えない時代もありました。
64ビットCPUは64ビット幅のアドレスだから16PBまで使えるわけではなく、すでに限界がわかっている集積技術がネックになって、最大でも数テラバイトまでしか使えずに終わりそうです。
No.4
- 回答日時:
ちょっと調べたら 4004 のネタも出てきた. やるときはやるなぁ, Intel....
4004: データバス/アドレスバスは 4bit. ただし 1word=8bit かつアドレスは 12bit.
No.3
- 回答日時:
Intel をかばうわけじゃないですが, その表現はちと Intel に厳しすぎのような気もしますよ>#2. 8bit/16bit の時代から「アーキテクチャをひきずってきた (ひきずらざるをえなかった)」Intel と「8bit→16bit, 32bit→RISC のそれぞれで過去のアーキテクチャを捨て去った」Motorola の違いともいえますので.
でふるい話をいくと Motorola 6809 はデータバス 8bit, アドレスバス 16bit. こいつは A, B の 2個のアキュムレータを持っていて, 連結して D レジスタ (16bit) としても使えます. このシリーズでは「4個の 8bit アキュムレータを連結して 32bit として使えます」とかいう謎の機能を持った CPU もいました.
Intel 8080, Zilog Z80 もバス幅は同じ. こいつらは, 内部的には 4bit ずつ処理をしていたんじゃなかったかなぁ.
Intel の 8086 以降を追うと
8086: データバス 16bit, アドレスバス 20bit (8088 はデータバスが 8bit).
80286: データバス 16bit, アドレスバス 24bit
80386: データバス 32bit, アドレスバス 32bit (80386SX はデータバス 16bit, アドレスバス 24bit)
Pentium: データバス 64bit, アドレスバス 32bit.
PentiumPRO: データバス 64bit, アドレスバス 36bit.
EM64T を持つとアドレスバスが 40bit になります.
だから, Intel の場合 CPU のビット数は「レジスタのビット数」と一致してます. 「バス幅」でみると 8088 とか 80386SX のようなやつらもいるけど.
Motorola の方は
MC68000: #2 にあるようにデータバス 16bit, アドレスバス 24bit (68008 はデータバス 8bit. アドレスバスは 20bit だったような気がする)
68020: データバス 32bit, アドレスバス 32bit.
ついでにいえば, Motorola といえど「8bit レジスタと 16bit レジスタが完全に独立」ということはなくって, 「各レジスタの下位部分が 8bit レジスタとして使える」ということです.
No.2
- 回答日時:
CPUのバスには「アドレスバス」と「データバス」があります。
CPUの処理能力を言う場合はデータバス幅を使うのが正当だと思うのですが、インテルでは昔から「数字が多く良さそうな方」を使っていました。つまり、データバスではなくアドレスバスです。対してモトローラではデータバス幅を使用していました。それが理由かどうかは分かりませんが、モトローラのCPUは動作クロックがインテルと比べて遙かに見劣りするのにインテルCPUを搭載したPCより処理能力が高かったものです。
モトローラのMC68000はデータバス16bit、アドレスバス24bit。i386はデータバス16bit、アドレスバス32bitだったかな?
※MC68000は16bitCPU、i386は32bitCPUと呼ばれていた。
インテルCPUのレジスタは扱いが一寸特殊で8bitレジスタをペアで使用して16bitレジスタとして扱うこともあります。モトローラでは8bitレジスタと16bitレジスタが完全に独立していたはず。
そういった意味ではインテルのCPUは未だ8bit/16bitからの脱却が完全には出来ていないと思っています。
Pentiumになってからアセンブラを勉強していないのでハッキリ言ってよく分かりません。
No.1
- 回答日時:
一致しないのが一般的です。
コンピュータの動作原理を説明するためにご質問のような単純なアーキテクチャを想定することはありますけれど(基本情報技術者試験のCASLIIなど)
http://ja.wikipedia.org/wiki/CASL
8bitパソコンなんて昔の時代からCPU内部の処理単位とアドレスバス幅とは一致していません。
http://www.atmarkit.co.jp/icd/root/02/5785802.html
http://www.keyman.or.jp/search/server2/30000858_ …
(それ以前がどうだったかは私よりもっとオジサンが知っているでしょう(^^;
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Win11で画像ファイルが突然開け...
-
F5アタックとは
-
中華ゲーム機のGame Console R3...
-
結構前にパソコン工房で購入し...
-
パソコンがあできなくてもつけ...
-
インストールできない
-
アガサハークネスを字幕で見た...
-
blenderで両眼立体計測法を用い...
-
WindowsのパソコンとiPhoneをUS...
-
Windows標準のメモ帳でファイル...
-
サイトに入ったら文字列ばっかり
-
エクスプローラーで検索すると...
-
zipって何
-
昨日、仕事からの帰宅時に部屋...
-
レポート提出のため、印字され...
-
ゴミ箱から間違えて・・・
-
ドラマの火事やその他台風などA...
-
Windows版のiTunesを使ってiPho...
-
ドローン操縦士の居場所
-
パソコンがフリーズする
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
レジストってなんですか?
-
レジスタの数
-
シーケンサのデータレジスタD...
-
SRAMとレジスタの違いは何でし...
-
biosとは人の体でいえば脳のよ...
-
トリムレジスタ
-
PICでUSARTのフレーミングエラ...
-
なぜソフトウェアでハードウェ...
-
CPUのビット数と、メモリ(主記...
-
PIC16F1シリーズマイコンのNCO...
-
FILOとLIFO
-
レジスタとメモリについて
-
Z80、6502、i8086、MC68000につ...
-
命令パイプライン、データハザ...
-
命令
-
キャッシュメモリとレジスタの...
-
CPUは何故、16bit→32bit→64bit...
-
回答が貰えるように質問文の添...
-
インデックスレジスタについて。
-
0xffffとは?
おすすめ情報