計算機の内部にはメインメモりと呼ばれる装置が収まっている。メインメモリの役割は、数値を記録して置くことである。
メインメモリは沢山の記憶セルからなっており、個々の記憶セルは一般に1 byte ( = 8 bit )分の情報が保持できる( 0〜255 = 2^8 - 1 )あるいは、-128〜127の範囲の数値)。
個々の記憶セルはそれらを区別するために番地が付けられており、異なる番地のセルには異なる情報(数値)を記憶することができる。
セル数は、いわゆる「メインメモリのメモリサイズ」で、例えば、数学科の2008年度入学者に配布されている機種(vostro 1200)には、2 G byteのメモリが塔載されている([vostro 1200 のメインメモリのサイズを確認してみよう])。
[スタートメニュー]を開き、その中の[コンピュータ]の所で、右クリックしてみよう。すると、メニューが表示されるはずだ。この中の[プロパティ(P)]を左クリックすると[システムとメンテナンス>>システム]のウィンドウが表示される。この中の「メモリ(RAM):」の後に記載されている2038MBが、このNote-PCに塔載されているメインメモリのサイズだ。
メモリの特徴をまとめると次のようになる。
メモリの最小単位(メモリセルの記憶容量)は、byteであり、これ単独で記憶できるのは、0〜255の数値だけでである。つまり、「単独のメモリセル」では、皆さんの小遣いさえ、記憶できないことになる。
そこで、複数のメモリセルをまとめて扱い、それが一つで、大きな数を表していると考える事にする。こうしてまとめられたセルの事をワード([ワード長と表現できる数の範囲])と呼ぶ事がある。
K君:「ふむ、ふむ、なるほど、自分の10本の指で、足りなければ、友達の手の指を借りればよいわけか..」「一つのセルでは、250位ってことは、僕の月一万円の小遣いを記録するには、10000 / 250で40セルか?結構使うなぁ...、こんなんじゃ、2Gあっても足りなくならないか? 2Gって、20億位か、すると、これの250倍って、えっ?たった5000億?じゃあ、このコンピュータでは国家予算の計算もできないってこと??」
Y先生:「相変わらず、K君は慌てものだなぁ..。実はそんなことはないんだ。0〜255 ( = 256 - 1 )まで表現できるセルが二つあれば、実は、0〜65535 ( = 256 * 256 - 1 )まで表すことができる。つまり、君の御小遣いなら、セル二つで十分だってことだな。それに、我国の借金だって、1,000,000,000,000,000を越えないので、7 byteで十分だ。」
K君:「なるほど、和(256+256)ではなく、積(256*256)になるですね。」
Y先生:「そうそう、n個のセルを継いでできるワードが表現できる数の種類は、2^(8*n) = (2^8)^n = 256^nとなる。」
K君:「すると、友達の指が十の位を、自分の指が一の位を表すとすれば、なんと、0〜99の100個、すなわち、10^2 = 100個の数が表されるってことですね」
Y先生:「ふむ、その通りだ。それが位取法、十進法というわけだ。じゃあ、そこまで判ったんだったら、実は、片手でも32通り、両手なら1024通りまで表すことができることがわかるかな?」
K君:「えっ?こんな所でまで、宿題ですか?参ったなぁ..ええと..なるほど...。でも先生、普通の人は、こんな風に指を曲げることなんかできないですよねぇ..」
Y先生:「ふむ、それが『数学』というものだよ。はっはっはぁ...」
計算機が「計算を行う」ということは、どうゆう意味を持つのだろうか?実は、これは「メモリを書き換えること」という観点で意味を付けることができる。
例えば、「最初に、メモリの個々のセルに値が与えられており、プログラムを実行した後にメモリ内のセルの値がどのように変化したか」で、「プログラムを意味」を定める事ができる。
実際には、「計算結果をメモリに書き込んでいる」ので、やっぱり計算を行っているではないかと思われるが、逆に考えれば、「計算をしても、その結果がメモリに書き込まれなければ無意味」であり、また、「メモリに書き込まれた結果さえ同じであれば、その計算方法はどうでもよい」という点を考えると、実は主役が計算側にはなく、メモリ側にあることが解る。
C:\soft\20091113\ex\01>20091113-01 va=10 (0012FF68) vb=20 (0012FF64) vc=30 (0012FF60) Pointer=0012ff64 va=10 vb=200 vc=30 C:\soft\20091113\ex\01>
#include<stdio.h> int main() { int va = 10; int *ip = &va; char *cp = (char *)&va; printf ( "ip=%p\n", ip ); printf ( "ip + 1 = %p\n", ip + 1 ); printf ( "cp=%p\n", cp ); printf ( "cp + 1 = %p\n", cp + 1 ); va = 300; printf ( "va = %d\n", va ); *ip = 0; printf ( "va = %d\n", va ); va = 300; printf ( "va = %d\n", va ); *cp = 0; printf ( "va = %d\n", va ); }
#include <stdio.h> /* 文字列を格納する配列 */ #include <stdio.h> int main (void) { char arry_of_str[4]; /* 文字列を格納する配列 */ /* (@) str -> array_of_str */ char *str = arry_of_str; /* (@) array_of_str の別名としての str を追加 */ str[0] = 'A'; /* 代入 */ str[1] = 'B'; /* 代入 */ str[2] = 'C'; /* 代入 */ str[3] = '\0'; /* 代入 */ printf ( "文字列 str は %s です。\n", str ); /* 表示 */ return (0); }