在C/C++中,函数func(int* num)的实现可以修改指针所指向的值,但不能安全地修改指针本身的指向(除非传递的是指针的指针)。以下是具体分析:
1.修改指针指向的值(合法)
【c】
void func(int* num) {
*num = 2; // 合法:修改指针指向的值为2
}
• 作用:将指针num所指向的内存地址中的值修改为2。
• 调用示例:
【c】
int x = 0;
func(&x); // 调用后,x的值变为2
2.修改指针本身的指向(不安全)
【c】
void func(int* num) {
int a = 3;
num = &a; // 语法正确,但调用后外部指针未改变
}
• 问题:
• 这里修改的是函数内部num参数的副本(指针按值传递),不会影响调用者传入的指针。
• 指针a是局部变量,函数返回后&a成为悬空指针(指向无效内存),访问它会导致未定义行为。
• 无效示例:
【c】
int* ptr = NULL;
func(ptr); // 调用后,ptr仍然是NULL,未被修改
3.如何真正修改指针指向?
如果需要修改指针本身的指向(例如动态分配内存),需传递指针的指针(int**):
【c】
void func(int** num) {
*num = malloc(sizeof(int)); // 动态分配内存
**num = 3; // 修改新分配的内存
}
• 调用示例:
【c】
int* ptr = NULL;
func(&ptr); // 调用后,ptr指向新分配的内存,值为3
总结
• *num = 2:合法且安全,修改指针指向的值。
• num = &a:语法正确但无实际意义(除非通过二级指针传递)。
• 关键点:C/C++中函数参数是按值传递的,包括指针。若需修改指针本身,需传递指针的地址(即二级指针)。
建议根据实际需求选择实现方式,并避免返回或保留局部变量的地址。