C++ 函数参数详解:不同指针类型的传参方式对比
c++++ 中指针参数的传参方式有三种:传值、传引用和传地址。传值复制指针,不影响原始指针;传引用允许函数修改原始指针;传地址允许函数修改指针指向的值。根据需要选择合适的传参方式。
C++ 函数参数详解:不同指针类型的传参方式对比
函数参数传递是 C++ 中一种至关重要的编程概念,它允许在函数调用时传递值或地址。对于指针类型,C++ 提供了几种不同的传参方式,本文将通过实战案例详细比较这些方式。
1. 指针传值
传递指针值的语法为 ,它有效地将指针的副本传递给函数。对函数内的副本进行修改不会影响原始指针。
#include <iostream>
void foo(int* ptr) {
std::cout << *ptr << std::endl; // 输出:5
*ptr = 10; // 仅修改函数内的副本
}
int main() {
int num = 5;
foo(&num); // 传递指针值
std::cout << num << std::endl; // 输出:5,原始指针未修改
return 0;
}
2. 指针传引用
传递指针引用的语法为 ,它将指针的引用传递给函数。对函数内引用的修改将影响原始指针。
#include <iostream>
void foo(int*& ptr) {
std::cout << *ptr << std::endl; // 输出:5
*ptr = 10; // 修改原始指针
}
int main() {
int num = 5;
foo(&num); // 传递指针引用
std::cout << num << std::endl; // 输出:10,原始指针已修改
return 0;
}
3. 指针传地址
传递指针地址的语法为 ,它将指针的地址传递给函数。函数内只能访问指针,无法直接访问其指向的值。
#include <iostream>
void foo(int** ptr) {
std::cout << *(*ptr) << std::endl; // 输出:5
*(*ptr) = 10; // 修改指针指向的值
*ptr = nullptr; // 指向另一个值
}
int main() {
int num = 5;
foo(&num); // 传递指针地址
std::cout << num << std::endl; // 输出:10,指针指向的值已修改
std::cout << *foo(&num) << std::endl; // 输出:0,指针指向另一个值
return 0;
}
指针传值复制指针,不影响原始指针。指针传引用使函数能够修改原始指针,而指针传地址则允许函数修改指针指向的值。根据具体需要选择合适的传参方式至关重要。
相关推荐
-
golang函数性能优化与重构
go 函数性能优化建议:1. 优化内存分配(使用切片、缓冲通道、重用结构体指针);2. 使用 goroutine 并行(充分利用多核 cpu);3. 选择合适的数据结构(映射、切片、堆栈);4. 内联
-
golang自定义函数实现的性能基准测试
在 go 中创建自定义函数基准测试性能基准测试:使用 testing 包提供的 b 类型创建自定义函数。在函数中使用 b 类型的 record 方法度量执行时间。使用 go test -bench .
-
golang函数最佳实践详解
遵循 go 函数最佳实践可以编写高效、可维护的函数,具体包括:1. 保持函数简洁;2. 使用命名参数;3. 返回多个值;4. 处理错误;5. 使用文档注释。Go 函数最佳实践详解在 Go 中编写高效、
-
单元测试与集成测试在golang函数测试中的区别?
单元测试和集成测试是两种不同的 go 函数测试类型,分别用于验证单个函数或多个函数的交互和集成。单元测试只测试特定函数的基本功能,集成测试测试多个函数之间的交互和与应用程序其他部分的集成。单元测试与集
-
如何在 C++ 函数中实现线程安全的数据结构?
如何在 c++++ 函数中实现线程安全的数据结构?使用互斥锁保护临界区(共享数据)。线程安全的动态数组示例:使用互斥锁保护 std::vector 中的数据。实战案例:线程安全的队列,使用互斥锁和条件