欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言指針變量作為函數(shù)參數(shù)的實(shí)現(xiàn)步驟詳解

 更新時(shí)間:2023年02月11日 09:58:47   作者:Elanie1024  
這篇文章主要介紹了C語言指針變量作為函數(shù)參數(shù)的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧

函數(shù)參數(shù)

在C語言中,函數(shù)的參數(shù)不僅可以是整數(shù)、小數(shù)、字符等具體的數(shù)據(jù),還可以是指向它們的指針。用指針變量作函數(shù)參數(shù)可以將函數(shù)外部的地址傳遞到函數(shù)內(nèi)部,使得在函數(shù)內(nèi)部可以操作函數(shù)外部的數(shù)據(jù),并且這些數(shù)據(jù)不會隨著函數(shù)的結(jié)束而被銷毀。

像數(shù)組、字符串、動態(tài)分配的內(nèi)存等都是一系列數(shù)據(jù)的集合,沒有辦法通過一個(gè)參數(shù)全部傳入函數(shù)內(nèi)部,只能傳遞它們的指針,在函數(shù)內(nèi)部通過指針來影響這些數(shù)據(jù)集合。

有的時(shí)候,對于整數(shù)、小數(shù)、字符等基本類型數(shù)據(jù)的操作也必須要借助指針,一個(gè)典型的例子就是交換兩個(gè)變量的值。

有些初學(xué)者可能會使用下面的方法來交換兩個(gè)變量的值:

#include<stdio.h>
voidswap(int a,int b){
int temp;//臨時(shí)變量
    temp = a;
    a = b;
    b = temp;
}
intmain(){
int a =66, b =99;
swap(a, b);
printf("a = %d, b = %d\n", a, b);
return0;
}

運(yùn)行結(jié)果:

a = 66, b = 99

從結(jié)果可以看出,a、b 的值并沒有發(fā)生改變,交換失敗。這是因?yàn)?swap() 函數(shù)內(nèi)部的 a、b 和 main() 函數(shù)內(nèi)部的 a、b 是不同的變量,占用不同的內(nèi)存,它們除了名字一樣,沒有其他任何關(guān)系,swap() 交換的是它內(nèi)部 a、b 的值,不會影響它外部(main() 內(nèi)部) a、b 的值。

改用指針變量作參數(shù)后就很容易解決上面的問題:

#include<stdio.h>
voidswap(int*p1,int*p2){
int temp;//臨時(shí)變量
    temp =*p1;
*p1 =*p2;
*p2 = temp;
}
intmain(){
int a =66, b =99;
swap(&a,&b);
printf("a = %d, b = %d\n", a, b);
return0;
}

運(yùn)行結(jié)果:

a = 99, b = 66

調(diào)用 swap() 函數(shù)時(shí),將變量 a、b 的地址分別賦值給 p1、p2,這樣 *p1、*p2 代表的就是變量 a、b 本身,交換 *p1、*p2 的值也就是交換 a、b 的值。函數(shù)運(yùn)行結(jié)束后雖然會將 p1、p2 銷毀,但它對外部 a、b 造成的影響是“持久化”的,不會隨著函數(shù)的結(jié)束而“恢復(fù)原樣”。

需要注意的是臨時(shí)變量 temp,它的作用特別重要,因?yàn)閳?zhí)行*p1 = *p2;語句后 a 的值會被 b 的值覆蓋,如果不先將 a 的值保存起來以后就找不到了。

這就好比拿來一瓶可樂和一瓶雪碧,要想把可樂倒進(jìn)雪碧瓶、把雪碧倒進(jìn)可樂瓶里面,就必須先找一個(gè)杯子,將兩者之一先倒進(jìn)杯子里面,再從杯子倒進(jìn)瓶子里面。這里的杯子,就是一個(gè)“臨時(shí)變量”,雖然只是倒倒手,但是也不可或缺。

用數(shù)組作函數(shù)參數(shù)

數(shù)組是一系列數(shù)據(jù)的集合,無法通過參數(shù)將它們一次性傳遞到函數(shù)內(nèi)部,如果希望在函數(shù)內(nèi)部操作數(shù)組,必須傳遞數(shù)組指針。下面的例子定義了一個(gè)函數(shù) max(),用來查找數(shù)組中值最大的元素:

#include<stdio.h>
intmax(int*intArr,int len){
int i, maxValue = intArr[0];//假設(shè)第0個(gè)元素是最大值
for(i=1; i<len; i++){
if(maxValue < intArr[i]){
            maxValue = intArr[i];
}
}
return maxValue;
}
intmain(){
int nums[6], i;
int len =sizeof(nums)/sizeof(int);
//讀取用戶輸入的數(shù)據(jù)并賦值給數(shù)組元素
for(i=0; i<len; i++){
scanf("%d", nums+i);
}
printf("Max value is %d!\n",max(nums, len));
return0;
}

運(yùn)行結(jié)果:

12 55 30 8 93 27↙

Max value is 93!

參數(shù) intArr 僅僅是一個(gè)數(shù)組指針,在函數(shù)內(nèi)部無法通過這個(gè)指針獲得數(shù)組長度,必須將數(shù)組長度作為函數(shù)參數(shù)傳遞到函數(shù)內(nèi)部。數(shù)組 nums 的每個(gè)元素都是整數(shù),scanf() 在讀取用戶輸入的整數(shù)時(shí),要求給出存儲它的內(nèi)存的地址,nums+i就是第 i 個(gè)數(shù)組元素的地址。

用數(shù)組做函數(shù)參數(shù)時(shí),參數(shù)也能夠以“真正”的數(shù)組形式給出。例如對于上面的 max() 函數(shù),它的參數(shù)可以寫成下面的形式:

intmax(int intArr[6],int len){
int i, maxValue = intArr[0];//假設(shè)第0個(gè)元素是最大值
for(i=1; i<len; i++){
if(maxValue < intArr[i]){
            maxValue = intArr[i];
}
}
return maxValue;
}

int intArr[6]好像定義了一個(gè)擁有 6 個(gè)元素的數(shù)組,調(diào)用 max() 時(shí)可以將數(shù)組的所有元素“一股腦”傳遞進(jìn)來。

讀者也可以省略數(shù)組長度,把形參簡寫為下面的形式:

intmax(int intArr[],int len){
int i, maxValue = intArr[0];//假設(shè)第0個(gè)元素是最大值
for(i=1; i<len; i++){
if(maxValue < intArr[i]){
            maxValue = intArr[i];
}
}
return maxValue;
}

int intArr[]雖然定義了一個(gè)數(shù)組,但沒有指定數(shù)組長度,好像可以接受任意長度的數(shù)組。

實(shí)際上這兩種形式的數(shù)組定義都是假象,不管是int intArr[6]還是int intArr[]都不會創(chuàng)建一個(gè)數(shù)組出來,編譯器也不會為它們分配內(nèi)存,實(shí)際的數(shù)組是不存在的,它們最終還是會轉(zhuǎn)換為int *intArr這樣的指針。這就意味著,兩種形式都不能將數(shù)組的所有元素“一股腦”傳遞進(jìn)來,大家還得規(guī)規(guī)矩矩使用數(shù)組指針。

int intArr[6]這種形式只能說明函數(shù)期望用戶傳遞的數(shù)組有 6 個(gè)元素,并不意味著數(shù)組只能有 6 個(gè)元素,真正傳遞的數(shù)組可以有少于或多于 6 個(gè)的元素。

需要強(qiáng)調(diào)的是,不管使用哪種方式傳遞數(shù)組,都不能在函數(shù)內(nèi)部求得數(shù)組長度,因?yàn)?intArr 僅僅是一個(gè)指針,而不是真正的數(shù)組,所以必須要額外增加一個(gè)參數(shù)來傳遞數(shù)組長度。

C語言為什么不允許直接傳遞數(shù)組的所有元素,而必須傳遞數(shù)組指針呢?

參數(shù)的傳遞本質(zhì)上是一次賦值的過程,賦值就是對內(nèi)存進(jìn)行拷貝。所謂內(nèi)存拷貝,是指將一塊內(nèi)存上的數(shù)據(jù)復(fù)制到另一塊內(nèi)存上。

對于像 int、float、char 等基本類型的數(shù)據(jù),它們占用的內(nèi)存往往只有幾個(gè)字節(jié),對它們進(jìn)行內(nèi)存拷貝非??焖?。而數(shù)組是一系列數(shù)據(jù)的集合,數(shù)據(jù)的數(shù)量沒有限制,可能很少,也可能成千上萬,對它們進(jìn)行內(nèi)存拷貝有可能是一個(gè)漫長的過程,會嚴(yán)重拖慢程序的效率,為了防止技藝不佳的程序員寫出低效的代碼,C語言沒有從語法上支持?jǐn)?shù)據(jù)集合的直接賦值。

除了C語言,C++、Java、Python 等其它語言也禁止對大塊內(nèi)存進(jìn)行拷貝,在底層都使用類似指針的方式來實(shí)現(xiàn)。

到此這篇關(guān)于C語言指針變量作為函數(shù)參數(shù)的實(shí)現(xiàn)步驟詳解的文章就介紹到這了,更多相關(guān)C語言指針變量作為函數(shù)參數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++結(jié)構(gòu)體字節(jié)對齊和共用體大小

    C++結(jié)構(gòu)體字節(jié)對齊和共用體大小

    這篇文章主要介紹了C++結(jié)構(gòu)體字節(jié)對齊和共用體大小,結(jié)構(gòu)體內(nèi)存對齊在筆試和面試中經(jīng)常被問到,所以這篇文章做個(gè)總結(jié),首先通過代碼驗(yàn)證不同結(jié)構(gòu)體的內(nèi)存大小,需要的朋友可以參考下
    2021-11-11
  • 基于C++實(shí)現(xiàn)Socket交互式服務(wù)端

    基于C++實(shí)現(xiàn)Socket交互式服務(wù)端

    在?Windows?操作系統(tǒng)中,原生提供了強(qiáng)大的網(wǎng)絡(luò)編程支持,允許開發(fā)者使用?Socket?API?進(jìn)行網(wǎng)絡(luò)通信,本文將深入探討如何通過調(diào)用原生網(wǎng)絡(luò)?API?實(shí)現(xiàn)同步遠(yuǎn)程通信,并介紹了一個(gè)交互式?Socket?類的封裝,需要的可以參考下
    2024-02-02
  • C語言數(shù)據(jù)結(jié)構(gòu)算法基礎(chǔ)之循環(huán)隊(duì)列示例

    C語言數(shù)據(jù)結(jié)構(gòu)算法基礎(chǔ)之循環(huán)隊(duì)列示例

    這篇文章主要為大家介紹了C語言數(shù)據(jù)結(jié)構(gòu)算法基礎(chǔ)之循環(huán)隊(duì)列,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • C++ OpenCV實(shí)戰(zhàn)之標(biāo)記點(diǎn)檢測的實(shí)現(xiàn)

    C++ OpenCV實(shí)戰(zhàn)之標(biāo)記點(diǎn)檢測的實(shí)現(xiàn)

    這篇文章主要介紹了如何利用C++ OpenCV實(shí)現(xiàn)關(guān)鍵點(diǎn)的檢測,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)OpenCV有一定幫助,感興趣的小伙伴可以了解一下
    2022-03-03
  • wchar_t,char,string,wstring之間的相互轉(zhuǎn)換

    wchar_t,char,string,wstring之間的相互轉(zhuǎn)換

    以下是對wchar_t,char,string,wstring之間的相互轉(zhuǎn)換進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2013-09-09
  • C語言字符串函數(shù)介紹與模擬實(shí)現(xiàn)詳解

    C語言字符串函數(shù)介紹與模擬實(shí)現(xiàn)詳解

    字符串函數(shù)(String?processing?function)也叫字符串處理函數(shù),指的是編程語言中用來進(jìn)行字符串處理的函數(shù),如C,pascal,Visual以及LotusScript中進(jìn)行字符串拷貝,計(jì)算長度,字符查找等的函數(shù)
    2022-02-02
  • C語言 文件操作解析詳解及實(shí)例代碼

    C語言 文件操作解析詳解及實(shí)例代碼

    這篇文章主要介紹了C語言 文件操作解析詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2016-11-11
  • C/C++函數(shù)的調(diào)用約定的使用

    C/C++函數(shù)的調(diào)用約定的使用

    本文主要介紹了C/C++函數(shù)的調(diào)用約定的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • C++中vector和數(shù)組之間的轉(zhuǎn)換及其效率問題詳解

    C++中vector和數(shù)組之間的轉(zhuǎn)換及其效率問題詳解

    c++?vector轉(zhuǎn)數(shù)組是一種將vector容器的元素轉(zhuǎn)換為數(shù)組的方法,主要能幫助提高程序的性能和效率,下面這篇文章主要給大家介紹了關(guān)于C++中vector和數(shù)組之間的轉(zhuǎn)換及其效率問題的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • 詳解C++17中if和switch語句的新特性

    詳解C++17中if和switch語句的新特性

    這篇文章主要為大家詳細(xì)介紹了C++17中if和switch語句的新特性的相關(guān)知識,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12

最新評論