一、值类型的一些特征
问题一:什么是按值传递引用类型?
可以这么理解:引用类型的变量作为方法的参数参与到方法中进行运算,这种方式的传递即为按值传递引用类型;代码如下:
测试结果:
调用Method方法前:返回结果为Dream:19
调用Method方法后:返回结果为Dream:25
结果分析:由于Method方法中的p是局部变量,所以调用方法时传递给方法的是对象的一个副本(实际就一个地址的副本,该地址指向了存储该对象的内存空间),方法调用完后,局部变量会被销毁,所以Main方法中的p变量并不会改变指向去指向在Method方法中创建的新的对象
问题二:什么是按引用传递引用对象?
可以这么理解:传递给方法的参数即引用类型本身而非其副本,传递参数时必须必须用ref修饰该参数,这种方式的传递即为按引用传递引用类型;代码如下:
测试结果:
调用Method方法前:返回结果为Dream:19
调用Method方法后:返回结果为ForverRs:22
结果分析:由于Method方法中p参数由ref修饰,此时在Main方法中调用Method传入的p相当于p本身(这里由于我对ref的内部实现还不是很清楚,所以这里的分析只是可以这么去理解,如果有明白的,请不吝赐教啦~),不再是以p副本的形式调用,所以在Method方法中可以改变p的指向。
- 值类型的内存空间分配在栈上
- 继承自System.ValueType;而System.ValueType又继承自object类
- 密封类,不能被继承!!!
- 有默认的构造函数,但如果存在自定义构造函数的话,构造函数中必须给值类型对象中的每一个字段/属性都复制
- 值类型的默认值为0
- 引用类型的内存空间分配在托管堆上
- 所有的引用类型都继承自object类
- 当引用类型超出其作用域时,垃圾回收器会将引用类型在托管堆中占用的内存回收,但回收的时间是不确定的!!!
- 值类型的默认值为null
问题一:什么是按值传递引用类型?
可以这么理解:引用类型的变量作为方法的参数参与到方法中进行运算,这种方式的传递即为按值传递引用类型;代码如下:
class Person
{
public string name;
public int age;
public Person(string n, int a)
{
this.name = n;
this.age = a;
}
public override string ToString()
{
return this.name + ":" + this.age;
}
}
static void Main(string[] args)
{
//调用Method前
Person p = new Person("Dream",19);
Console.WriteLine(p);
//调用Method后
Method(p);
Console.WriteLine(p);
Console.ReadLine();
}
public static void Method(Person p)
{
//改变传入p变量中age的值
p.age = 25;
//创建一个新的Person对象,赋值给p
p = new Person("ForeveRs",22);
}
测试结果:
调用Method方法前:返回结果为Dream:19
调用Method方法后:返回结果为Dream:25
结果分析:由于Method方法中的p是局部变量,所以调用方法时传递给方法的是对象的一个副本(实际就一个地址的副本,该地址指向了存储该对象的内存空间),方法调用完后,局部变量会被销毁,所以Main方法中的p变量并不会改变指向去指向在Method方法中创建的新的对象
问题二:什么是按引用传递引用对象?
可以这么理解:传递给方法的参数即引用类型本身而非其副本,传递参数时必须必须用ref修饰该参数,这种方式的传递即为按引用传递引用类型;代码如下:
static void Main(string[] args)
{
//调用Method前
Person p = new Person("Dream",19);
Console.WriteLine(p);
//调用Method后
Method(ref p);
Console.WriteLine(p);
Console.ReadLine();
}
public static void Method(ref Person p)
{
//改变传入p变量中age的值
p.age = 25;
//创建一个新的Person对象,赋值给p
p = new Person("ForeveRs",22);
}
测试结果:
调用Method方法前:返回结果为Dream:19
调用Method方法后:返回结果为ForverRs:22
结果分析:由于Method方法中p参数由ref修饰,此时在Main方法中调用Method传入的p相当于p本身(这里由于我对ref的内部实现还不是很清楚,所以这里的分析只是可以这么去理解,如果有明白的,请不吝赐教啦~),不再是以p副本的形式调用,所以在Method方法中可以改变p的指向。