日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

C++Primer:函数(参数传递-非引用形参)

發布時間:2025/3/15 c/c++ 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C++Primer:函数(参数传递-非引用形参) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.參數傳遞

每次調用函數時,都會重新創建該函數所有的形參,此時所傳遞的實參將會初始化對應的形參。 形參的初始化與變量的初始化一樣;如果形參具有非引用類型,則復制實參的值,如果形參為引用類型,則他只是實參的別名。

2.非引用形參

普通的非引用類型的參數通過復制對應的實參實現初始化。當用實參副本初始化形參時,函數并沒有訪問調用所傳遞的實參本身,因此不會修改實參的值 非引用形參表示對應實參的局部副本。對這類形參的修改僅僅改變了局部副本的值。一旦函數執行結束,這些局部變量的值也就沒有了。

2.1 指針形參

函數的形參可以是指針,此時將復制實參指針。與其他非引用類型的形參一樣,該類形參的任何改變也僅作用于局部副本。如果函數將新指針賦給形參,主調函數使用的實參指針的值沒有改變。 事實上,被復制的指針只影響對指針的賦值。如果函數形參是非const類型的指針,則函數可通過指針實現賦值,修改指針所指向對象的值。 <span style="font-size:18px;">#include <iostream> using std::cout; using std::endl; void Reset(int* ip);int main() {int i = 100;int* p = &i;cout<<"Befor"<< *p<<endl;Reset(p);cout<<"After"<<*p<<endl;return 0; } void Reset( int* ip) {*ip = 0;ip = 0; }</span>上述程序運行結果為 100,0;
解釋調用reset后,實參依然保持原來的值(指的是指針的名字,而非指針指向的內容),但是它所指向的對象的值將變為零。 如果保護指針指向的值,則形參需定義為指向const對象的指針 #include <iostream> using std::cout; using std::endl; void Reset(const int* ip);int main() {int i = 100;int* p = &i;cout<<"Befor"<< *p<<endl;Reset(p);cout<<"After"<<*p<<endl;return 0; } void Reset(<strong><span style="color:#3333ff;">const</span></strong> int* ip) {<span style="color:#ff6666;"><strong>*ip = 0;</strong></span> //error:不能給指向const int類型的指針賦值ip = 0; }指針形參是指向const類型還是非const類型,將影響函數調用所使用的實參。我們既可以用int*也可以用const int*類型的實參調用Reset()函數;但僅能將int*類型的實參傳遞給Reset函數。這個差別來源于指針的初始化規則: 可以將指向const對象的指針初始化為指向非const對象 <p><span style="font-family: Arial, Helvetica, sans-serif;">i = 100;</span></p>const int* cip = &i; //OK:This is Right但不可以讓指向非const 對象的指針指向const對象; const int i = 100; int* ip = &i; //error C2440: “初始化”: 無法從“const int *”轉換為“int *”

2.2 const形參

在調用函數時,如果該函數使用非引用的非const形參,則既可以給該函數傳遞const實參,也可以傳遞非const 的實參。例如: int gcd(int v1, int v2) // 求最大公約數 {while(v2){int temp = v2;v2 = v1 % v2;v1 = temp;}return v1; }int main() {const int i = 3, j = 6;int k = gcd(3,6); //OK,k initialized to 3 } 這種行為源于const對象的標準初始化規則。因為初始化復制了初始化式的值,所以可用const對象初始化非const對象,反之亦然。 如果將形參定義為非引用的const類型: void fcn(const int i) { /* fcn can read but <strong><span style="color:#ff0000;">not write to i</span></strong> */ } 則在函數中,不可以改變實參的局部副本。由于實參仍然是以副本的形式傳,因此傳遞給 fcn 的既可以是 const 對象也可以是非 const 對象

3. 復制實參的局限性

復制實參并不是在所有的情況下都合適,不適宜復制實參的情況包括: 1.當需要在函數中修改實參的值時; 2.當需要以大型對象作為實參傳遞時。對實際的應用而言,復制對象所付出的時間和存儲空間代價往往過大; 3.沒有辦法實現對象的復制時。 對于上述幾種情況,有效的解決辦法是將形參定義為引用或指針類型 與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的C++Primer:函数(参数传递-非引用形参)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。