码迷,mamicode.com
首页 > 其他好文 > 详细

面向对象

时间:2015-07-23 21:44:30      阅读:127      评论:0      收藏:0      [点我收藏+]

标签:

如何理解面向对象?

面向过程:强调的是功能行为。

面向对象:将功能封装进对象,情调对象说具备的功能。

面向对象是基于面向过程的。

类和对象的关系

现实生活中的对象:张三 李四

想要描述: 提取对象中共性内容,对具体的抽象。

描述时:这些对象的共性有:姓名,年龄,性别,学习java功能。 映射到java中,描述就是class定义的类,具体对象就是堆内存中用new建立的实体。

类:对现实生活中事物的描述。

对象:实实在在存在的类的个体。

匿名对象:

匿名对象使用方法一:当对对象方法只调用一次时,可以用匿名对象来完成,这样比较简化。

匿名对象使用方法二:可以将匿名对象作为实际参数进行传递。

面向对象三大特征:封装,继承,多态

 封装:是指隐藏对象的属性和实现细节,仅对外提供公共访问方式。

 一:好处:

将变化隔离

便于使用

提高重用性

提高安全性

二:封装原则:

将不需要对外提供的内容都隐藏起来

把属性都隐藏,提供公共方法对其访问

继承:1. 提高代码的复用性;2. 让类与类之间产生了关系,有了这个关系,才有了多态的特征。

注意:千万不要为了获取其他类的功能,简化代码而继承,必须是类与类之间有所属关系才可以继承。

 在Java中: 

 java只支持单继承,不支持多继承。

 因为多继承容易带来安全隐患:当多个父类中定义了相同功能,当功能内容不同时,子类对象不确定运行哪一个。但是java保留这种机制,并用另一种体现形式来完成表示:多实现

 java支持多层继承,也就是一个继承体系。但是如何使用一个继承体系中的功能呢?

想要使用体系,先查阅体系中父类的描述。因为父类中定义的是该体系中的共性功能,通过了解共性功能,就可以知道该体系的基本功能,那么这个体系已经可以基本使用了。

那么在具体调用时,要创建最子类的对象,为什么?

一是因为有可能父类不能创建对象;二是最子类实现的功能最多。

由于继承的出现,也就有了子父类,下面我们就探讨一下子父类中类成员的特点。

类成员:

一:变量

1.如果子类中出现非私有的同名变量时,子类要访问本类中的变量,用this

2.子类要访问父类中的同名变量,用super

二:函数

1.当子类出现和父类一模一样的函数时,当子类对象调用该函数,会运行子类函数的内容,如同父类的函数被覆盖一样,这种情况是函数的一个特征:重写(覆盖)。

2.当子类继承父类,沿袭了父类的功能到子类中,但是子类虽具备该功能,但是功能的内容却和父类不一致,这时,没必要定义新功能,二是使用覆盖方法,保留父类的功能定义,并重写功能内容。

3.写覆盖需要注意点:

子类覆盖父类,必须保证子类权限大于等于父类权限,才可以覆盖

静态只能覆盖静态

重载:只看同名函数的参数列表

重写:子父类方法要一模一样

三:构造函数:

在对子类对象进行初始化,父类的构造函数也会运行,那是因为子类的构造函数默认第一行有一条隐式的语句super();,super();会访问父类空参数的构造函数,而且子类中所有的构造函数默认第一行都是super();

为什么子类一定要访问父类中的构造函数?  因为父类中的数据子类可以直接获取,所以子类对象在建立时,需要先查看父类是如何对这些数据进行初始化的。所以子类在对象初始化时,要先访问父类中的构造函数。如果要访问父类中指定的构造函数,可以通过手动定义super语句的方式来指定   注意: super语句一定定义在子类构造函数的第一行。   子类的实例化过程。  结论:  子类的所有的构造函数,默认都会访问父类中空参数的构造函数。因为子类每一个构造函数内的第一行都有一句隐式super();当父类中没有空参数的构造函数时,子类必须手动通过super或者this语句形式来指定要访问的构造函数。当然,子类的构造函数第一行也可以手动指定this语句来访问本类中的构造函数,子类中至少会有一个构造函数会访问父类中的构造函数。

多态:可以理解为事物存在的多种体现形式。

一:多态的体现

 1.父类的引用指向了子类对象

 2.父类的引用也可以接受子类对象

二:多态的前提

 1.必须是类与类之间有关系,要么继承,要么实现

 2.通常还有一个前提:存在覆盖

三:多态的好处

    多态的出现大大的提高了程序的扩展性

四:多态的应用

     提高了扩展性,但是只能使用父类的引用访问父类中的成员

 

多态的出现代码中的特点(多态使用的注意事项)

在多态中,成员函数的特点:

在编译期间:参阅引用型变量所属的类中是否有调用的方法。如果有,编译通过,如果没有编译失败。

在运行时期:参阅对象所属的类中是否有调用的方法。

简单总结就是:成员函数在多态调用时,编译看左边,运行看右边。

在多态中,成员变量的特点:

无论编译和运行,都参考左边(引用型变量所属的类)

在多态中,静态成员函数的特点:

 

无论编译和运行,都参考左边(引用型变量所属的类)

 

成员变量和局部变量

一:作用范围:

  1.成员变量作用于整个类中。

  2.局部变量作用于函数中,或语句中。

二:在内存中的位置:

  1.成员变量在堆内存中,因为对象的存在,才在内存中存在。

  2.局部变量存在栈内存中。  

面向对象

标签:

原文地址:http://www.cnblogs.com/huihui10/p/4671573.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!