1. 我們都知道,普通的傳值參數是由行參傳給實參;
編譯器在函數內部為每一個參數產生一個臨時變量,將每一個參數壓入棧(stack)中,將實參的數值保存到臨時變量中。
所以才有在低端8位機中,對參數的數量有比較嚴格的限制,因為棧的深度非常有限;當然,在通用機上也有同樣的問題,參數過多不合適,但通用機的棧的深度比低端機大多了;
2. 引用做參數傳遞的是變量的地址;
實質上傳遞的是變量的指針;
引用作為參數的好處是減少了臨時變量對內存的開銷,因此常用於對大對象的操作;
而常引用做參數就是保護參數不被修改;
附:堆和棧的知識
一個由c/C++編譯的程序占用的內存分為以下幾個部分
1、棧區(stack)― 由編譯器自動分配釋放 ,存放函數的參數值,局部變量的值等。其操作方式類似於數據結構中的棧。
2、堆區(heap) ― 一般由程序員分配釋放, 若程序員不釋放,程序結束時可能由OS回收 。注意它與數據結構中的堆是兩回事,分配方式倒是類似於鏈表,呵呵。
3、全局區(靜態區)(static)―,全局變量和靜態變量的存儲是放在一塊的,初始化的全局變量和靜態變量在一塊區域, 未初始化的全局變量和未初始化的靜態變量在相鄰的另一塊區域。 - 程序結束後有系統釋放
4、文字常量區 ―常量字符串就是放在這裡的。 程序結束後由系統釋放
5、程序代碼區―存放函數體的二進制代碼。