C 函數參數傳遞方式有兩種:按值傳遞和按引用傳遞。按值傳遞建立參數副本,修改副本不影響原始變數。按引用傳遞傳遞參數位址,修改引用物件直接影響原始變數。常見的陷阱包括:不正確傳遞引用參數導致按值傳遞,修改按值傳遞的參數不影響原始變量,引用未初始化和懸空引用。字串處理時,按引用傳遞字串可以避免因按值傳遞而導致的修改而遺失。
#在C 中傳遞函數參數時,有兩種主要方式:按值傳遞和按引用傳遞。了解這兩種方式的細微差別至關重要,以避免常見的陷阱和誤解。
按值傳遞建立參數的副本,並將副本傳遞給函數。對函數中副本的任何修改都不可見。
void print_double(int x) { x *= 2; std::cout << x << std::endl; } int main() { int a = 5; print_double(a); // 输出:10 std::cout << a << std::endl; // 输出:5 }
按引用傳遞將參數的位址傳遞到函數。對函數中引用物件的任何修改都會直接影響原始物件。
void swap(int& a, int& b) { int temp = a; a = b; b = temp; } int main() { int x = 5, y = 10; swap(x, y); std::cout << x << " " << y << std::endl; // 输出:10 5 }
陷阱1:不正確地傳遞引用參數
傳遞普通變數而不是引用變數將導致按值傳遞,即使函數參數宣告為引用。
陷阱 2:嘗試修改按值傳遞的參數
對按值傳遞的參數進行修改將不會反映在原始變數中。
陷阱 3:引用未初始化的變數
在傳遞參考參數之前,請確保變數已初始化。
陷阱 4:懸空引用
當引用物件不再存在時,引用指向無效記憶體。避免讓引用指向臨時物件或超出作用域的物件。
實戰案例:字串處理
考慮一個取得字串的第一個字元的函數:
char get_first_char(std::string str) { return str[0]; }
使用按值傳遞,當函數傳回時,所做的任何修改都會遺失。要解決此問題,我們應該按引用傳遞字串:
char get_first_char(std::string& str) { return str[0]; }
這確保了對字串的任何修改都反映在函數外部。
以上是C++ 函式參數傳遞方式的陷阱與誤區的詳細內容。更多資訊請關注PHP中文網其他相關文章!