我们创建一个结构体,再创建一个函数为它赋值,按照下面的代码,最后没有输出结果,这是为什么?

原因是,我们传给函数的时候是值传递,而值传递的时候形参是实参的一份临时拷贝,也就是说我们又创建了一个新的‘s’,和主函数中的‘s’没有任何关系。当我们在函数中赋值的时候,其实是给新的‘s’进行赋值,所以我们会打印不出结果,而当我们在函数中打印的话,就可以打印出结果了

那我们该如何进行传参呢?这里可以使用指针,将‘s’的地址传过去,再通过地址找到原来的值就可以了,而用指针的时候,我们就需要把形参改成struct stu *,里面也要改成->来找到原来的值

那么我们什么时候用'->',什么时候用'.'来进行打印或修改呢,其实很简单,当我们用的是指针时,就用‘->’,而没有结构体的指针时,我们就用‘.’。
对于这类传参,不管是值传递还是地址传递,函数也是一样的道理
本文探讨了在C语言中,结构体作为参数传递时遇到的问题。由于值传递会创建实参的副本,导致函数内部的修改无法反映到外部。解决办法是使用指针,通过'->'操作符修改结构体成员。总结了何时使用'.'和'->',并强调了在函数传参中指针的应用,以确保对原始数据的正确修改。

919

被折叠的 条评论
为什么被折叠?



