-
对象和类的关系
查看全部 -
1、封装
2、继承
3、多态
查看全部 -
在同一个类中,多个方法,名字相同,但参数不同,叫做方法的重载,
查看全部 -
对私有属性private进行封装
查看全部 -
封装的快捷键 Ctrl+R+E
选中需要封装的对象选中按快捷键。
查看全部 -
封装 CTRL+R+E
查看全部 -
封装的概念:隐藏对象的信息,留出访问的接口
关于封装:
类和对象;把字段封装成属性;方法;构造方法;值类型与引用类型
引用:结构 枚举 out ref
查看全部 -
ref起到传参作用:
out是获取结果且可以返回多个值;return返回一个值。
使用Out 修饰形参必须得给形参赋值
查看全部 -
使用ref关键字可以使用值类型变量的引用,相当于C语言中的&(取地址)。
ref需要在形参前面使用,包括调用的时候;另外属性不能作为实参使用。
查看全部 -
//按引用传递参数,方法修改形参,通常实参也会被修改
//按值传递参数,方法修改形参,实参不会被修改查看全部 -
枚举:
1、值类型
2、不能定义字段属性和方法
3、枚举值是从0递增的整数
例子:enum Gender
{
男,女
}
男等同整型的0,女等同整型的1
查看全部 -
简单来说,struct是值类型,创建一个struct类型的实例被分配在栈上。class是引用类型,创建一个class类型实例被分配在托管堆上。但struct和class的区别远不止这么简单。 概括来讲,struct和class的不同体现在: ● 类是引用类型,struct是值类型 ● 在托管堆上创建类的实例,在栈上创建struct实例 ● 类实例的赋值,赋的是引用地址,struct实例的赋值,赋的是值 ● 类作为参数类型传递,传递的是引用地址,struct作为参数类型传递,传递的是值 ● 类没有默认无参构造函数,struct有默认无参构造函数 ● 类支持继承,struct不支持继承 ● 类偏向于"面向对象",用于复杂、大型数据,struct偏向于"简单值",比如小于16字节,结构简单 ● 类的成员很容易赋初值,很难给struct类型成员赋初值 ● 类的实例只能通过new someclass()来创建,struct类型的实例既可以通过new somestruct()来创建,也可以通过somestruct mystruct;来创建 一、从赋值的角度体验struct和class的不同 引用类型赋值,是把地址赋值给了变量 class program { static void main(string[] args) { sizeclass sizeclass = new sizeclass(){width = 10, length = 10}; console.writeline("赋值前:width={0},length={1}", sizeclass.width, sizeclass.length); var copyofsizeclass = sizeclass; copyofsizeclass.length = 5; copyofsizeclass.width = 5; console.writeline("赋值后:width={0},length={1}",sizeclass.width, sizeclass.length); console.readkey(); } } public class sizeclass { public int width { get; set; } public int length { get; set; } } public struct sizestruct { public int width { get; set; } public int length { get; set; } } 运行结果如下图所示:以上,当把sizeclass赋值给copyofsize变量的时候,是把sizeclass所指向的地址赋值给了copyofsize变量,2个变量同时指向同一个地址。所以,当改变copyofsizeclass变量的值,也相当于改变了sizeclass的值。 struct类型赋值,是完全拷贝,在栈上多了一个完全一样的变量 class program { static void main(string[] args) { sizestruct sizestruct = new sizestruct(){length = 10, width = 10}; console.writeline("赋值前:width={0},length={1}", sizestruct.width, sizestruct.length); var copyofsizestruct = sizestruct; copyofsizestruct.length = 5; copyofsizestruct.width = 5; console.writeline("赋值后:width={0},length={1}", sizestruct.width, sizestruct.length); console.readkey(); } } 程序运行结果如下图所示:以上,当把sizestruct赋值给copyofsizestruct变量的时候,是完全拷贝,改变copyofsizestruct的值不会影响到sizestruct。 二、从参数传值角度体验struct和class的不同 引用类型参数传递的是地址 class program { static void main(string[] args) { listtemp = new list(){"my","god"}; temp.foreach(t => console.write(t + " ")); console.readkey(); } public static void changereferencetype(listlist) { list = new list(){"hello", "world"}; } } 运行结果:my god 为什么不是hello world? →栈上的temp指向托管堆上的一个集合实例 →当temp放到changereferencetype(temp)方法中,本质是把temp指向的地址赋值给了变量list →在changereferencetype(listlist)方法内部,又把变量list的指向了另外一个集合实例地址 →但temp的指向地址一直没有改变 我们再来改变changereferencetype(listlist)内部实现方式,其它不变。 class program { static void main(string[] args) { listtemp = new list(){"my","god"}; changereferencetype(temp); temp.foreach(t => console.write(t + " ")); console.readkey(); } public static void changereferencetype(listlist) { list.clear(); list.add("hello"); list.add("world"); } } 运行结果:hello world 为什么不是my god? →栈上的temp指向托管堆上的一个集合实例 →当temp放到changereferencetype(temp)方法中,本质是把temp指向的地址赋值给了变量list →在changereferencetype(listlist)方法内部,把temp和list共同指向的实例清空,又添加"hello"和"world"2个元素 →由于list和temp指向的实例是一样的,所以改变list指向的实例就等同于改变temp指向的实例 以上,很好地说明了:引用类型参数传递的是地址。 值类型struct参数传递的是值 class program { static void main(string[] args) { size s = new size(){length = 10, width = 10}; changestructtype(s); console.write("length={0},width={1}", s.length,s.width); console.readkey(); } public static void changestructtype(size size) { size.length = 0; size.width = 0; } } public struct size { public int length { get; set; } public int width { get; set; } }
查看全部 -
值类型:int/double/char/bool;
引用类型:类/引用/接口,string属于类,所以也是引用类型,引用类型new的时候慧创建新的对象,=赋值仅仅是地址的副本。
值类型赋值慧创建值的副本(开辟新的内存空间),修改某个副本,并不会影响其他副本的值;
而引用类型赋值创建的是内存地址的副本(仅仅存储地址而没有开辟内训空间),修改任何一个副本,也同时修改其他的副本。
查看全部 -
对象初始化器
查看全部 -
构造方法的重载
查看全部
举报