我想知道为什么当我们有p = new Person(“TOM”,999);通过调用fred.PrintInfo();
它不会将p改为TOM和999,而是使用p.age = 99;我们可以很好地改变fred的年龄,构造函数和属性都是公共的,那么我在这里缺少什么?我不想对这段代码做任何事我只想要原因.
它不会将p改为TOM和999,而是使用p.age = 99;我们可以很好地改变fred的年龄,构造函数和属性都是公共的,那么我在这里缺少什么?我不想对这段代码做任何事我只想要原因.
using System; class Person { public string fullName; public int age; public Person(string n,int a) { fullName = n; age = a; } public void PrintInfo() { Console.WriteLine("{0} is {1} years old",fullName,age); } } class MainClass { public static void SendAPersonByValue(Person p) { p.age = 99; p = new Person("TOM",999); } public static void Main() { Person fred = new Person("Fred",12); fred.PrintInfo(); SendAPersonByValue(fred); fred.PrintInfo(); } }
解决方法
fred指向内存中的某个特定位置:
+------------+ fred ----> | Fred 12 | +------------+
在调用SendAPersonByValue时,p指向同一位置:
+------------+ fred ----> | Fred 12 | +------------+ ^ p ---------+
p.age = 99;现在更改内存中的值:
+------------+ fred ----> | Fred 99 | +------------+ ^ p ---------+
而新人(“TOM”,999);在内存中创建一个新的Person,并且p = …使p指向它:
+------------+ fred ----> | Fred 99 | +------------+ +------------+ p ----> | TOM 999 | +------------+
而这正是弗雷德仍然包含弗雷德,99的原因.
现在,如果你将fred作为ref
parameter传递,p将成为fred的别名:
+------------+ fred/p ----> | Fred 12 | +------------+
在p.age = 99之后:
+------------+ fred/p ----> | Fred 99 | +------------+
在p = new Person(“TOM”,999)之后;:
+------------+ | Fred 99 | (will be garbage collected eventually) +------------+ +------------+ fred/p ----> | TOM 999 | +------------+
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。