萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> 編程語言綜合 >> 引用參數和傳值參數的區別深入解析

引用參數和傳值參數的區別深入解析

以下是對引用參數和傳值參數的區別進行了詳細的分析介紹,需要的朋友可以過來參考下  

1. 我們都知道,普通的傳值參數是由行參傳給實參;

編譯器在函數內部為每一個參數產生一個臨時變量,將每一個參數壓入棧(stack)中,將實參的數值保存到臨時變量中。

所以才有在低端8位機中,對參數的數量有比較嚴格的限制,因為棧的深度非常有限;當然,在通用機上也有同樣的問題,參數過多不合適,但通用機的棧的深度比低端機大多了;

2. 引用做參數傳遞的是變量的地址;

實質上傳遞的是變量的指針;

引用作為參數的好處是減少了臨時變量對內存的開銷,因此常用於對大對象的操作;

而常引用做參數就是保護參數不被修改;

附:堆和棧的知識
一個由c/C++編譯的程序占用的內存分為以下幾個部分

1、棧區(stack)―   由編譯器自動分配釋放 ,存放函數的參數值,局部變量的值等。其操作方式類似於數據結構中的棧。

2、堆區(heap) ―   一般由程序員分配釋放, 若程序員不釋放,程序結束時可能由OS回收 。注意它與數據結構中的堆是兩回事,分配方式倒是類似於鏈表,呵呵。

3、全局區(靜態區)(static)―,全局變量和靜態變量的存儲是放在一塊的,初始化的全局變量和靜態變量在一塊區域, 未初始化的全局變量和未初始化的靜態變量在相鄰的另一塊區域。 - 程序結束後有系統釋放

4、文字常量區  ―常量字符串就是放在這裡的。 程序結束後由系統釋放

5、程序代碼區―存放函數體的二進制代碼。

copyright © 萬盛學電腦網 all rights reserved