内存。封装OOP与oop的继承

这次的整理还是OOP(毕竟是个难点,重点)

讲到OOP肯定要提内存

虚拟内存总体划分为五大区域,栈区(堆栈),堆区(托管堆),常量,静态(静态为初始化区和静态初始化区),其他区域。

栈区:由计算机虚拟内存自动进行释放管理,栈区的存储方式为先进后出,用于分配值类型,栈由操作系统进行管理,不受GC(垃圾回收机制)管理,当值类型不在其作用域,其所占的内存空间自动释放。栈的执行效率为最高的。

堆区:用于分配小对象实例(<85000),所谓小对象就是小于85000字节的实例对象,GC堆分三代垃圾进行管理,当GC操作时(垃圾回收时),垃圾收集器会对GC进行压缩回收,原理有点类似ios种的autorelease(自动释放池)

大对象堆(large object heap):大对象就是指大小超过85000字节的实例对象,大对象分配在LOh上不受GC管理的,不会被压缩,只有在完全GC回收时才会被回收

ps:栈的分配是高位-->低位进行扩展

堆的分配是低位-->高位进行扩展

值类型参数与引用参数的本质,值参数是对栈种数据进行拷贝,拷贝出来的数据相当于之前数据的副本。

引用类型是对栈中数据地址的引用,当值参数为某对象引用时,可以改变该对象的某些值,但是不能将值变成新对象的地址。

将类封装也是一大重点

封装特性:

为什么要封装?

属性存在的目的:其实就是巍峨保护类的内部结构不被破坏,达到封装性。

属性的语法格式:

访问修饰符public(必须) +对应字段的数据类型+字段名称(首字母必须大写)

{

}

属性本身就是一种特殊的方法,他没有返回值,是因为属性内部提供了可以访问该属性的

ref参数:将值类型引用改变为地址引用

值类型作为参数传递的时候,传递不是本身,而是副本。此时要想修改本身的值,要将值类型变为引用类型传递才可以

string虽然本身是引用类型,但是作为参数传递的时候,默认的是值传递,而不是引用传递。这就需要我们

如果想改变原来的字符串,这个时候就要将值传递改为引用传递,加上ref关键字。

如果你不想改变原来的字符串,就直接传递字符串就好。

object本身为引用类型,他和字符串不一样,默认就为引用类型,也就是传递地址。

数组作为参数进行传递,也是引用传递.

out参数:输出到其实就是保存到一个数值在其中

类使用经常会有部分字段重复这就要用到类的继承

继承:

继承使用条件:当你在设计类的时候,发现有字段重复。

具有相同特征不同行为的可以抽取踹,单独称为一个类,这个类供派生类使用。

简称:基类。

在我们的程序中使用关键符号:表示继承

格式:(:+类)

这个类是指继承的类

继承关系中的特点

1.子类可以继承父类中的共有字段

2.子类可以继承父类中的公开属性

3.子类可以继承父类中的公开方法

4.(继承中)父类不能拥有子类的字段/方法/属性/索引器

5.在c#中不支持多重继承,也就是说一个类只能继承一个类,如果你想支持多继承,那么请使用Iterface

继承关系中的构造函数(重点)

1.在继承关系种,首先会调用父类的构造函数,然后在调用子类的构造函数

2.在继承关系中,子类初始化对象的时候,先调用父类的构造函数,然后再看子类构造函数有没有显式

通知编译器指定调用父类的哪个构造函数,如果没有,那么默认去调用父类的无参数构造函数。

此时如果父类重写了带有参数的构造函数,程序编译不通过,那么解决办法就是给父类添加无参构造函数

或则在子类构造函数中声明指定调用父类的哪个构造函数。

你可能感兴趣的:(内存。封装OOP与oop的继承)