【C语言】以指针作为实参的问题

以指针作为实参时,实参p传递给形参p1的其实是p的拷贝,所以在局部函数中改变形参p1的指向对身处主函数的p是无影响的,但是因为p1是p的拷贝。

所以他们的指向是相同的,所以可以通过p1修改了那块内存的值。如果实参p的指向为空,也就是说p是一个空指针的话,那么它就没有指向某块内存。

形参也就无法操作p所指向的内存了(因为p本就没有指向任何一块内存),即使p1在局部函数中指向了一个malloc的空间。

这其实是改变了p1的指向(从NULL到指向malloc的空间),但是如前所述,p1只是p的拷贝,改变副本的指向对本尊是没有任何影响的。

所以对p没有影响,p还是为空。但是因为p1的生存周期是在局部函数范围内,所以一旦函数执行结束,p1这个变量就会被销毁释放。

但是那块malloc的空间却不会被释放,那就会成为空间碎片。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在C语言中,没有像其他语言一样支持匿名函数的语法。但是可以通过函数指针和函数指针类型来模拟匿名函数的现,然后将其作为传入。 例如,我们可能有一个函数,该函数需要接受一个函数指针作为数,并且该函数指针指向一个接受两个整数数并返回一个整数的函数。我们可以使用typedef来定义一个函数指针类型,然后将该类型作为数类型传递给函数。 ```c typedef int (*func_ptr)(int, int); int add(int x, int y) { return x + y; } void do_operation(int x, int y, func_ptr operation) { int result = operation(x, y); printf("The result is: %d\n", result); } int main() { // pass a named function as argument do_operation(10, 20, add); // pass an anonymous function as argument do_operation(20, 30, (func_ptr) (int[]){20, 30} ) { return args[0] * args[1]; }); return 0; } ``` 在上面的代码中,我们首先定义了一个函数指针类型`func_ptr`,该类型指向一个接受两个整数数并返回一个整数的函数。然后,我们定义了一个`add`函数,该函数接受两个整数数并返回它们的和。 接下来,我们定义了一个`do_operation`函数,该函数接受三个数:两个整数和一个函数指针。该函数指针指向一个接受两个整数数并返回一个整数的函数。 最后,在`main`函数中,我们首先将一个命名函数`add`作为数传递给`do_operation`函数,然后我们将一个匿名函数作为数传递给该函数。注意,我们在传递匿名函数时使用了一个类型转换,将匿名函数转换为函数指针类型`func_ptr`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值