本文目錄一覽:
- 1、在C語言中,可編址是什麼
- 2、用c語言如何獲取內存地址?
- 3、c語言可以直接訪問內存地址嗎
- 4、理解C語言指針和內存地址的關係
- 5、C語言編程中,內存物理地址是什麼概念?
- 6、C語言中什麼叫內存地址?
在C語言中,可編址是什麼
可編址是指可以對
內存地址
值進行操作,如指針的使用就是可編址的具體表現~~
用c語言如何獲取內存地址?
1、獲得函數的地址
函數名實際上就是指針,所以可以通過強制類型轉換來獲取函數的地址。
int i = 0;
i = (int)main;
printf(「%d\n」,i);
這樣我們就獲取了main函數的地址了,其他的自定義的函數也是同樣的道理啊。
2、獲取變數地址
int variab = 0;
int addrvar = 0;
addrvar = (int)variab;
在變數addrvar中保存了變數variab的地址。
3、獲得數組的地址
數組本身就是指針,它本身就是內存地址,和獲得函數地址的方法一樣啊。比如
int array[10];
int addrarr;
addrarr = (int)array;
c語言可以直接訪問內存地址嗎
您好,很高興回答您的問題。在c語言中,是可以通過取地址符號來取出數據在內存中的地址的,也就是訪問其數據所在位置的內存地址。可以定義指針變數如int *a,用來存放某個變數的內存地址。
理解C語言指針和內存地址的關係
一個內存地址存著一個對應的值,這是比較容易理解的。
如果程序員必須清楚地知道某塊內存存著什麼內容和某個內容存在哪個內存地址里了,那他們的負擔可想而知。
彙編語法對「一個內存地址存著一個對應的數」,作了簡單的「抽象」:把內存地址用變數名代替了,對內存地址的取值和賦值方式不變。
c語言對此進行了進一步的抽象:變數 ==
(一個內存地址,對應的值)(這裡忽略類型等信息)。
把C語言中的基本類型(int,long,float等),指針,數組等還原為(一個內存地址,對應的值)後,就能更清淅地理解它們了。
內存就相當於(addr,val)的大hash表,c語句的語義基本就是改變hash值。
什麼叫hash表?:根據關鍵碼值key直接進行內存訪問的數據結構。
為了下文的方便,特定義如下語義(遵循C的標準語義):
var==(addr, val)(var為一個變數名,addr為var在內存中的首地址,val為var的值)
var == addr
var==
var作為左值出現(即等式左邊)時,var等價於 addr;
var作為右值出現(即等式右邊)時,var等價於val;
*var == val
註:符號”==”右邊出的等式x = y(x是一個內存地址,y是一個值);表示將內存地址為x的內容置為值y,如addr = 3表示置內存addr里的值為3
現在利用上面的語義解釋一下這些例子:
int i = 3;
假設i的內存地址為0x8049320 ,那麼這句話的語義是0x8049320 = 3,經過i =
3後,i為(0x8049320,3)
int b = i;
假設b的內存地址為0x8049324 ,那麼這句話的語義是0x8049324 = i對應的val
= 3,此時b為(0x8049324,3)
int *p = b
指針p也是一個變數,int **p,int *p[8],在這些申明中p都只是一個指針變數,它和其他的變數的不同之處在於它的大小是定的,它的類型信息只是編譯器用來進行類型檢查和其他一些作用的(如果沒有類型檢查,你可以用任何的方式對一個變數進行操作如int i; ****i = 3)。假設p的地址為0x8049328,則根據p = b的語義p.addr = b.addr,p為(0x8049328,0x8049324)
*p = 5;
語義為0x8049324 = 5,此時只改變了內存地址為0x8049324的值,即改變了b的值(0x8049324,5),而p的值並未改變
int **q = p; //如果寫為int **q = i; gcc編譯不通過
假設q的內存地址為0x8049330,語義為0x8049330 = addr(p) = 0x8049328;所以q為(0x8049330,
0x8049328)
(int **q = i,要是編譯過了則q應該表示為(0x8049330,
x),內存地址為x的地方表示為(x,0x8049320),那麼地址x為多少呢? )
**q = 6
語義為val(val(q)) =
val(0x8049328) = 0x8049324 = 6,將內存地址為0x8049324的內容置為6,即將b的值置為6,b為(0x8049324,6)
對於結構,這些語義也適用,因為結構里的成員也是有對應地址的,也能表示為(addr,val)的形式。
C語言編程中,內存物理地址是什麼概念?
用於內存晶元級的單元定址,與處理器和CPU連接的地址匯流排相對應。
——這個概念應該是這幾個概念中最好理解的一個,但是值得一提的是,雖然可以直接把物理地址理解成插在機器上那根內存本身,把內存看成一個從0位元組一直到最大空量逐位元組的編號的大數組,然後把這個數組叫做物理地址,但是事實上,這只是一個硬體提供給軟體的抽像,內存的定址方式並不是這樣。所以,說它是「與地址匯流排相對應」,是更貼切一些,不過拋開對物理內存定址方式的考慮,直接把物理地址與物理的內存一一對應,也是可以接受的。也許錯誤的理解更利於形而上的抽像。
C語言中什麼叫內存地址?
任何一個變數或者一個程序都得需要給它分配一塊內存空間,而這塊內存空間的標識號碼就把它叫做內存地址。內存地址是用16進位數表示的。
例如:ABC8F40
有了內存地址我們就可以更好的針對指定的內存進行操作,修改等。
比如一個變數是1,我們可以修改存放這個變數的內存地址的里的內容,把他改為2。
內存地址的訪問通過指針來實現。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/228691.html