C語言指針的意思
A. c語言中指針是什麼意思有例句來說明一下
通俗講點 指針就是計算機內存空間的的一個位置(地址)
你所需要記錄的信息都說存在計算機內存或硬碟里的一個位置!訪問的時候,用指針可以快速的定位這個計算機中的位置(機器識別的稱之為指針的東西)
例: 你買了個鉛筆,上學要用!你就放在你的文具盒裡
當要用鉛筆的時候 你就知道去文具盒裡找!就這個道理
所以 你現在想想 什麼是文具盒?就是別人規定的
學習C語言也一樣!先記憶定義 然後實踐!別人說沒用 自己理解吧
B. c語言指針詳解
指針是一個特殊的變數,它裡面存儲的數值被解釋成為內存里的一個地址。數據在內存中的地址也稱為指針,如果一個變數存儲了一份數據的指針,我們就稱它為指針變數。
計算機中所有的數據都必須放在內存中,不同類型的數據佔用的位元組數不一樣,例如 int 佔用 4 個位元組,char 佔用 1 個位元組。
為了正確地訪問這些數據,必須為每個位元組都編上號碼,就像門牌號、身份證號一樣,每個位元組的編號是唯一的,根據編號可以准確地找到某個位元組。
C語言用變數來存儲數據,用函數來定義一段可以重復使用的代碼,它們最終都要放到內存中才能供 CPU 使用。數據和代碼都以二進制的形式存儲在內存中,計算機無法從格式上區分某塊內存到底存儲的是數據還是代碼。
當程序被載入到內存後,操作系統會給不同的內存塊指定不同的許可權,擁有讀取和執行許可權的內存塊就是代碼,而擁有讀取和寫入許可權(也可能只有讀取許可權)的內存塊就是數據。
CPU 只能通過地址來取得內存中的代碼和數據,程序在執行過程中會告知 CPU 要執行的代碼以及要讀寫的數據的地址。
如果程序不小心出錯,或者開發者有意為之,在 CPU 要寫入數據時給它一個代碼區域的地址,就會發生內存訪問錯誤。這種內存訪問錯誤會被硬體和操作系統攔截,強製程序崩潰,程序員沒有挽救的機會。
變數名和函數名為我們提供了方便,讓我們在編寫代碼的過程中可以使用易於閱讀和理解的英文字元串,不用直接面對二進制地址,那場景簡直讓人崩潰。
需要注意的是,雖然變數名、函數名、字元串名和數組名在本質上是一樣的,它們都是地址的助記符,但在編寫代碼的過程中,我們認為變數名表示的是數據本身,而函數名、字元串名和數組名表示的是代碼塊或數據塊的首地址。
(2)C語言指針的意思擴展閱讀
指針使用(* 和 &)
*&a可以理解為*(&a),&a表示取變數 a 的地址(等價於 pa),*(&a)表示取這個地址上的數據(等價於 *pa),繞來繞去,又回到了原點,*&a仍然等價於 a。
&*pa可以理解為&(*pa),*pa表示取得 pa 指向的數據(等價於 a),&(*pa)表示數據的地址(等價於 &a),所以&*pa等價於 pa。
對星號*的總結
在我們目前所學到的語法中,星號*主要有三種用途:
1、表示乘法,例如int a = 3, b = 5, c; c = a * b;,這是最容易理解的。
2、表示定義一個指針變數,以和普通變數區分開,例如int a = 100; int *p = &a;。
3、表示獲取指針指向的數據,是一種間接操作,例如int a, b, *p = &a; *p = 100; b = *p;。
C. 論述C語言中指針的概念和作用,並舉例說明
1、指針概念:變數的地址(計算機內存位元組的編號)叫做指針,存放變數地址的變數叫指針變
量,
簡言之,指針是用來存放地址的。
2、作用:指向這個變數或數組的首地址,是變數的間接引用方式。其值如果改變,變數的值或數組元素的值也會跟著改變。程序對變數的操作實際上是對變數所在的存儲空間讀取和寫入數據。方便對變數的操作。
舉例說明:
int
a=3;/*定義一個整型變數a,並賦初值3*/
int
*p;/*定義一個指針變數P*/
p=&a;/*讓p指向a的首地址,也就是a的地址*/
程序為a分配一個2個位元組的存儲單元,假如2個位元組的地址分別為(ABCD1和ABCD2,唯一),那麼p裡面放的值就是ABCD1,不是3。這時可通過p直接引用a,實際上*p=3。以後不管a存放在內存中的哪個地方,只用通過調用p就可以引用a。這時如果令*p=4,則最後的a值也為4。對於數組,指針是指向數組的首地址。
D. C語言中指針是什麼
指針是c語言的難點,很難被學生接受。本部分主要演示:指針的定義,普通變數的定義,建立關聯,直接賦值,間接賦值。為了簡便,暫時只討論整形。
設計:
在組合框中選擇操作的類型,在彈出的對話框中做進一步的處理。二十個編輯模擬內存,十個為整形,十個為指針區.由於「內存」的限制,很容易「內存不足」。二十個靜態控制項顯示變數名及模擬內存地址。
整形數組記錄數值,字元串數組記錄變數名,注意對應。
定義:加上變數名,並隨機賦初值。
關聯:在對話框的組合框中選擇變數,前有提示信息"=&",改變指針的值,並將相應的編輯框連線。
賦值:在個對話框中選擇整形變數或指針變數,並輸入值。
有必要的話,將CEdit改成CRichEdit,用SetSel反向顯示正在處理的模擬空間。
測試:
1, 注意空懣狀態。
2,多次重復同一操作。
E. C語言里的指針是什麼意思,起什麼作用
1:指針是一個地址,指向的是個類型:
我們知道,c語言中的類型有int,char,bool(這個不常用),一般我們使用int,char就可以滿足一般的類型需求的,如果對於變數的長度過大,就是用long ,float,double,關於各個類型使用的的長度問題,可以使用sizeof(int)或者sizeof(long)來查看各個類型,在系統中的小。
而指針就是一個8個位元組(64系統)。
2:指針指向的是地址,地址指向的是內容:
我們需要一個變數,來存儲地址,這個變數的值是地址,但是我們可以通過修改變數的值,來不斷的改變地址,但是,我們如果需要改變該個地址的值的話,就需要,對地址的值進行修改,而不改變地址。
int a = 10;
int *p ;
p = &a;
*p =11;
a=?
這里我們看到,p 是一個變數,我們使用p來存儲變數a的地址,這是,我們使用*p對於這個變數進行賦值,那麼a的值最後,是多少呢,結果是11,因為我們使用*p賦值,就相當於a=11,賦值效果一樣的。
3:指針的指針,是面對於指針的變數:
我們說,指針的指針的時候,就有點不清楚了,到底怎麼區分指針和指針的指針呢。
char *p;
char **pr;
pr = &p;
我們這樣看就清楚了一點,char *(*pr); *pr是一個存儲的值為指針的變數,pr就是存儲上個變數地址的變數。整合起來就是,pr是一個存儲的值為指針的地址的變數。
這樣,我們就基本,對於指針有一個直接的了解了。
F. C語言中指針是什麼
我們都知道:C語言中的數組是指 一類 類型,數組具體區分為 int 類型數組,double類型數組,char數組 等等。同樣指針 這個概念也泛指 一類
數據類型,int指針類型,double指針類型,char指針類型等等。
通常,我們用int類型保存一些整型的數據,如 int num = 97 , 我們也會用char來存儲字元: char ch = 'a'。
我們也必須知道:任何程序數據載入內存後,在內存都有他們的地址,這就是指針。而為了保存一個數據在內存中的地址,我們就需要指針變數。
因此:指針是程序數據在內存中的地址,而指針變數是用來保存這些地址的變數。
G. C語言中的指針是什麼意思
其實與其你在這里問,還不如看一看c語言教科書,上面寫的都很詳細
以下是譚浩強版的
在計算機中,所有的數據都是存放在存儲器中的。一般把存儲器中的一個位元組稱為一個內存單元,不同的數據類型所佔用的內存單元數不等,如整型量佔2個單元,字元量佔1個單元等,在前面已有詳細的介紹。為了正確地訪問這些內存單元,必須為每個內存單元編上號。根據一個內存單元的編號即可准確地找到該內存單元。內存單元的編號也叫做地址。
既然根據內存單元的編號或地址就可以找到所需的內存單元,所以通常也把這個地址稱為指針。
內存單元的指針和內存單元的內容是兩個不同的概念。
可以用一個通俗的例子來說明它們之間的關系。我們到銀行去存取款時,
銀行工作人員將根據我們的帳號去找我們的存款單,
找到之後在存單上寫入存款、取款的金額。在這里,帳號就是存單的指針,
存款數是存單的內容。對於一個內存單元來說,單元的地址即為指針,其中存放的數據才是該單元的內容。在C語言中,允許用一個變數來存放指針,這種變數稱為指針變數。因此,一個指針變數的值就是某個內存單元的地址或稱為某內存單元的指針。
嚴格地說,一個指針是一個地址,是一個常量。而一個指針變數卻可以被賦予不同的指針值,是變數。但常把指針變數簡稱為指針。為了避免混淆,我們中約定:「指針」是指地址,是常量,「指針變數」是指取值為地址的變數。定義指針的目的是為了通過指針去訪問內存單元。
既然指針變數的值是一個地址,那麼這個地址不僅可以是變數的地址,也可以是其它數據結構的地址。在一個指針變數中存放一個數組或一個函數的首地址有何意義呢?
因為數組或函數都是連續存放的。通過訪問指針變數取得了數組或函數的首地址,也就找到了該數組或函數。這樣一來,凡是出現數組,函數的地方都可以用一個指針變數來表示,只要該指針變數中賦予數組或函數的首地址即可。這樣做,將會使程序的概念十分清楚,程序本身也精練,高效。在C語言中,一種數據類型或數據結構往往都佔有一組連續的內存單元。
用「地址」這個概念並不能很好地描述一種數據類型或數據結構,而「指針」雖然實際上也是一個地址,但它卻是一個數據結構的首地址,它是「指向」一個數據結構的,因而概念更為清楚,表示更為明確。
這也是引入「指針」概念的一個重要原因。
H. 怎麼理解C語言里的指針
指針就是內存的地址。
內存懂吧,就是放數據的地方,數據就像一個人的家,懂吧,一棟樓里,肯定住了不止一家人吧,那麼確定每家的地址,就需要幾樓幾零幾這樣設置地址吧。內存也是一樣的,內存是按一個位元組的大小來安排地址的。
比如int a;我們申請了一個int型,整形的變數,int是四個位元組的數據類型,所以變數a在內存上會有一個地址,地址是按第一個數字為準的。假設內存上沒有任何數據,都是空的,那麼內存就會按順序來放地址,假設內存的第一個地址是0,以此類推,那麼當我們int a變數的時候,內存就會把0-3地址的空間分配給變數a,因為a佔四個單元內存,那麼怎麼確定變數a的地址呢?計算機是按這個內存地址上的最開始那個算的,即變數a的地址是0。
當我們在聲明了int a變數之後,再聲明一個char b變數。如下:
int a;
char b;
這個時候,int a先被聲明了,假設內存是空的,那麼變數a就會被安排0-3的地址。第二個聲明char b;就會接在變數a之後,因為char是一個位元組的數據,所以內存只會分配一個4號內存給變數b,變數b的地址就是4。以此類推,其他類型是一樣的。
指針就是用來存放內存地址的地方。指針變數一般也會單獨存放。
比如:
int a; //內存分配編號為0-3的內存空間給變數a;變數a的地址就是最開頭的那個編號即變數a的地址是0;
char b; //內存緊接著分配編號為4的內存空間給變數b,因為char是一個位元組的,所以變數b的地址唯一,就是4。
隨後,我們申請指針。
int * p;
char * t;
我們申請了兩個指針, *是指針的標志,有*的變數是指針,沒有*的是一般變數,*只是用來區別變數是int型數據還是指針。
當變數是指針的時候,意味著這個變數只能存放內存地址,而不能存放任何自然數。
即指針p,只能用p=&a; 變數a在C語言中,單用的時候,使用變數a裡面存放的值,而不是他的地址,比如 我們再聲明一個變數 int g; g=a;這個例子里,我們聲明了一個int型變數g,並用g=a來初始化g,g=a的意思是,用a里存放的數,即讀取出a裡面存的數,然後把這個數給g,並不是把a的地址給g。所以C語言里規定了符號&為取地址操作符,p=&a;的意思就是取出a的地址,給p,這個時候是可以的,因為p是指針,並且p指針指向的類型是int。
在C語言中,給指針賦地址,要檢查變數的類型的,比如int *p;這個指針p,p前面的*表示他是指針,說明他只能存放地址,*號前面的類型說明符,進一步說明,p這個指針只能存int型變數的地址,即如果p=&b;是不會成立的,並且會報錯,因為p是一個存放int型變數的指針,而變數b是一個char型變數,在C語言里,指針和對應的變數的類型要一致。不能夠混用。
不能混用的原因在於,到時候解引用的時候會出錯,即如果 p=&b,成立的話,那麼到時候使用 a=*p;的時候會出現嚴重錯誤,因為p=&b,是把char型變數的地址給int型指針,當我們在使用解引用符號*的時候,就會錯誤,a=*p;的意思是,用p里存放的地址,找到內存上的數據,並且給變數a,編譯器會檢查,得知p是int型變數指針,所以需要按照這個地址取出的數據是四個位元組的數據,所以程序會把b的地址4按照int型的數據變數地址來使用,會調取內存上編號為4,5,6,7號位的數據,然而編號為4的內存上放的是char 型變數b的數據,5,6,7號內存上,根本沒有數據,從而出錯。所以C語言嚴格要求,指針的類型和變數類型要一致,即int *的指針只能存放int型變數的地址,不可混用。
最後一個疑問點在於*符號,在C語言里是復用的,即有三種使用方法,這里給你區別一樣,要不然你會有疑問,* 這個符號,在C語言有三種意思,一種是乘法,即 a=5*3里,這個時候這個符號*是乘法的意思,認出他很簡單,因為乘法必須要有乘數,被乘數,即符號*左右兩邊都要有實數或者變數,即使是c=a*b;的表達也不會錯,a,b是變數的話,符號*是乘號用法。
第二種用法就是我們看到的 int *p;這裡面符號*是指針的標志,只是用來說明p是一個指針,假設一個int p,那請問怎麼區別p是指針還是變數,所以就是通過添加符號*來區別變數和指針的,而且指針和變數一樣,都需要int,char,double等類型說明,所以只有在聲明變數的時候,才使用。
第三中用法就是和符號&的操作相反的操作,符號&在C語言里,只有一個用法,就是表明,這個運算符是取出後面的地址,即&a,就是取出變數a的地址,即指針,符號&左邊沒有任何變數,只有右邊有變數,而符號*則是相反操作,意思是取出符號*右邊的指針里的地址,並取出這個地址里存放的數,所以*P,就是取出指針p里的地址,然後取出這個地址里存放的數。符號*也是右邊有變數,而左邊沒有任何變數的操作,他們都是單操作符。
第二種和第三種用法要怎麼區別,就是第三種一定是a=*p這樣使用的,符號*的左邊一定沒有任何類型說明符,而如果是第二種用法,那麼符號*的左邊一定有類型說明符,即第二種一定是int *p; 即 類型說明符 + * +變數名的形式,而且只用在聲明指針變數的時候。
I. 在c語言中指針的指針是什麼意思
我們知道變數在計算機內是佔有一塊存貯區域的,變數的值就存放在這塊區域之中,
在計算機內部,
通過訪問或修改這塊區域的內容來訪問或修改相應的變數。turbo
c語言中,
對於變數的訪問形式之一,就是先求出變數的地址,然後再通過地址對它進行訪問,這就是這里所要論述的指針及其指針變數。
所謂變數的指針,
實際上指變數的地址。變數的地址雖然在形式上好象類似於整數,
但在概念上不同於以前介紹過的整數,
它屬於一種新的數據類型,
即指針類型。turbo
c中,
一般用指針來指明這樣一個表達式&x的類型,而用地址作為它的值,也就是說,
若x為一整型變數,
則表達式&x的類型是指向整數的指針,而它的值是變數x的地址。同樣,
若double
d;則&d的類型是指向以精度數d的指針,而&d的值是雙精度變數d的地址。所以,
指針和地址是用來敘述一個對象的兩個方面。雖然&x、&d的值分別是整型變數x和雙精度變數d的地址,
但&x、&d的類型是不同的,
一個是指向整型變數x的指針,
而另一個則是指向雙精度變數d的指針。在習慣上,很多情況下指針和地址這兩個術語混用了。
我們可以用下述方法來定義一個指針類型的變數。
int
*ip;
首先說明了它是一指針類型的變數,注意在定義中不要漏寫符號*,否則它為一般的整型變數了。另外,在定義中的int
表示該指針變數為指向整型數的指針類型的變數,
有時也可稱ip為指向整數的指針。ip是一個變數,
它專門存放整型變數的地址。
指針變數的一般定義為:
類型標識符
*標識符;
其中標識符是指針變數的名字,
標識符前加了*號,表示該變數是指針變數,
而最前面的類型標識符表示該指針變數所指向的變數的類型。一個指針變數只能指向同一種類型的變數,
也就是講,
我們不能定義一個指針變數,
既能指向一整型變數又能指向雙精度變數。
指針變數在定義中允許帶初始化項。如:
int
i,
*ip=&i;
注意,
這里是用&i對ip初始化,
而不是對*ip初始化。和一般變數一樣,對於外部或靜態指針變數在定義中若不帶初始化項,
指針變數被初始化為null,
它的值為0。turbo
c中規定,
當指針值為零時,
指針不指向任何有效數據,
有時也稱指針為空指針。因此,
當調用一個要返回指針的函數時(以後會講到),
常使用返回值為null來指示函數調用中某些錯誤情況的發生。