首先,這個不是指針函數(shù) ,void *ptr(int * x,int * y ,int * z);才是指針函數(shù)。指針函數(shù)是函數(shù),只是函數(shù)返回的是個指針(地址)。
我們提供的服務(wù)有:成都做網(wǎng)站、成都網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、岳池ssl等。為千余家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的岳池網(wǎng)站制作公司
void swap(int p1,int p2){int p;p=p1;p1=p2;p2=p;} 只是交換了值而已。。同你的那個,只是交換了pp2所代表的地址而已,真正的地址不會因此交換的。正道還是以改變實參指針變量所指變量的值 。沒辦法。
C所有的函數(shù)調(diào)用都是將實參的值“拷貝”給形參,所以指針也不例外。函數(shù)中改變形參指針的值改變的只是形參指針的指向,函數(shù)退出后都銷聲匿跡了,與實參指針無關(guān)。
4 所以,通常意義上函數(shù)內(nèi)部無法改變實參的指針。但是有一些技巧可以曲線完成你要的效果,例如實參是指針,其值是自身的地址。那么相當(dāng)與一個二級指針的訪問。這樣就可以通過這種方式修改實參的指針。
就是在調(diào)用函數(shù)的時候,如果在被調(diào)用的函數(shù)里面,只改變的是形參的值,是不會影響實參的。
因為指針是作為參數(shù)傳遞給函數(shù)的,傳遞的是指針指向的值。其本身并沒有傳遞給函數(shù)。
定義const 變量,這個可能會有問題。。在vc下被編譯器報error 了。
是的,如果一個指針指向一個變量的地址,那么它們是在同一個內(nèi)存地址的,操作指針所在的值就是操作變量的值,參數(shù)為指針就是指向你填入?yún)?shù)的地址,操作的是同一個東西。
但,如果參數(shù)類型是指針類型,則可以通過對指針變量所指向的地址中的數(shù)據(jù)進行修改,達到改變實參地址中的數(shù)據(jù)目的。
可以,但int *p;*p=7;這樣不行。因為“能直接給指針指向的數(shù)據(jù)”賦值,而這里的p還沒有指向,所以不能賦值,這種指針有個名字叫“懸浮指針”,是不能給它賦值的。
pa=句是將指針*pa指向變量a。pa存放的是a的地址,*pa其實就是a,可以理解為把a換了一個名字表示。*pa=20就是對a進行賦值操作,等于a=20;a的值當(dāng)然改變了。
void main(void){ const int a=5; //在之前a并沒有分配內(nèi)存,而是將其值放入了常量表中,并建立了對應(yīng)關(guān)系,以后用到a的時候直接去常量表中查詢。const變量應(yīng)該跟一般變量是分開放的。
如果函數(shù)參數(shù)直接傳遞的是指針類型,那么在函數(shù)內(nèi)改變指針指向,并不能影響函數(shù)外的指針實例。只有傳入指針的指針,才能改變指針的指向。函數(shù)里的形參是一般變量,在函數(shù)里面改變變量的值,不會改變主函數(shù)里實參的值。
聲明一個指向具有5個元素的數(shù)組的指針,即int (*p)[5];,然后寫p=a;,那么第5行第4列的元素就是(p+4)[3],如果寫(p+4)[3]=20;,就把原來的4改寫成20了(若寫p+=4;p[3]=20;效果也一樣)。
pa=句是將指針*pa指向變量a。pa存放的是a的地址,*pa其實就是a,可以理解為把a換了一個名字表示。*pa=20就是對a進行賦值操作,等于a=20;a的值當(dāng)然改變了。
參數(shù)必須是指針類型,指向待交換的數(shù)據(jù) 交換時,必須交換地址中的數(shù)據(jù),而不是交換地址本身。
初始值為10int *p = // 定義一個指針p,并讓這個指針指向變量x*p = 100; //通過指針p,對x進行賦值。