继承

1、继承使用原因:

1、提高了代码的复用性

2、让类与类之间产生了关系,有了这个关系,才有了多态的特性

2、继承注意事项:

千万不要为了获取其他类的功能,简化代码而继承。

必须是类与类之间有所属关系才可以继承,所属关系 is a。

类的继承是不断抽象出来的,不能继承不该继承的东西,例如:人不能继承毛

  1. class C
  2. {
  3. void demo1(){}
  4. }
  5. class A extend C
  6. {
  7. //void demo1(){}
  8. void demo2(){}
  9. }
  10.  
  11. class B extends c
  12. {
  13. //void demo1(){}
  14. void dmeo3(){}
  15. }

3、Java只支持单继承原因:

java语言中:java只支持单继承,不支持多继承

因为多继承容易带来安全隐患,当父类中定义了相同功能,但功能内容不同时,子类对象不确定要运行哪一个。

但是java保存了这种机制,并利用另一种体现形式来完成表示,多实现(实现多个接口)。

4、java支持多层继承:

java支持多层继承。也就是一个继承体系。

如何使用一个继承体系中的功能?

想要使用体系,先查阅体系中父类的描述,因为父类中定义的是该体系中的共性功能。

通过了解共性功能,就可以知道该体系的基本功能。

这个体系已经基本可以使用了。

那么在具体调用时要创建最子类的对象。

为什么创建最子类对象?

一是因为有可能父类不能创建对象;

二是因为创建子类对象可以使用更多的功能,包括基本的,也包括特有的。

简单一句话就是查阅父类功能,创建子类对象的功能。

5、聚集:has a

按事物紧密联系程度划分为两种:聚合、组合。

6、子父类出现后,类中成员的变化【3种】

类中成员:

1、变量

2、函数

3、构造函数

1、变量

如果子父类中出现了非私有的同名成员变量时

子类要访问本类中的变量时,用this

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

super的使用和this的使用基本一致

this代表的是本类对象的引用

super代表的是父类对象的引用

  1. class Fu
  2. {
  3. int num=4;
  4. public void setNum(int num)]
  5. {
  6. this.num=num;
  7. }
  8. public int getNum()
  9. {
  10. return this.num;
  11. }
  12. public void show()
  13. {
  14. System.out.println("fu show");
  15. }
  16. }
  17.  
  18. class Zi extents Fu
  19. {
  20. //int num=5;
  21. void show()
  22. {
  23. //System.out.println(super.num);//打印父类的num
  24. System.out.println("zi show");//子类中的num
  25. }
  26. }
  27. class
  28. {
  29. public static void main(String[] args)
  30. {
  31. Zi z=new Zi;
  32. //System.out.println(z.num);
  33. z.show();
  34.  
  35. }
  36. }

2、子类中的函数

当子类中出现和父类一模一样的函数时,当子类对象调用该函数,会运行子类的内容,如同父类函数被覆盖一样。

这种情况是函数的里一个特性:重写(覆盖)

当子类继承了父类,沿袭了父类的功能到子类中,

但子类虽具备该功能,但子类的功能的内容却和父类不一致

这时,没有必要定义新功能,而是使用覆盖特性,保留父类的功能定义并保留父类内容

覆盖注意事项:

1、子类覆盖父类,必须保证子类权限大于等于父类权限,才可以覆盖,否则编译失败

2、静态只能覆盖静态

3、如果父类中是private的方法,子类中是public的同名方法,不能称作覆盖,因为父都看不到父类,怎么可能称作覆盖。

注意:

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

重写:子父类方法一模一样,包括返回值,编译报错

  1. class Fu
  2. {
  3. int num=4;
  4. public void setNum(int num)
  5. {
  6. this.num=num;
  7. }
  8. public int getNum()
  9. {
  10. return this.num;
  11. }
  12. public void show()
  13. {
  14. System.out.println("fu show");
  15. }
  16. void speak()
  17. {
  18. System.out.println("VB");
  19. }
  20. }
  21.  
  22. class Zi extends Fu
  23. {
  24. //int num=5;
  25. void speak()
  26. {
  27. System.out.println("java");
  28. }
  29. public void show()
  30. {
  31. //System.out.println(super.num);//打印父类的num
  32. System.out.println("zi show");//子类中的num
  33. }
  34. }
  35. class ExtendsDemo3
  36. {
  37. public static void main(String[] args)
  38. {
  39. Zi z=new Zi();
  40. //System.out.println(z.num);
  41. //z.show();
  42. z.speak();
  43. }
  44. }
  45.  
  46. class Tel
  47. {
  48. void show()
  49. {
  50. System.out.println("number");
  51. }
  52. }
  53. class NewTel extends Tel
  54. {
  55. void show()
  56. {
  57. super.show();//System.out.println("number");
  58. System.out.println("name");
  59. System.out.println("picture");
  60.  
  61. }
  62. }

3、子类中的构造函数

在对子类对象进行初始化时,父类的构造函数也会运行,

那是因为子类的构造函数默认第一行有一条隐式的语句super();

super();会访问到父类中空参数的构造函数,而且子类中所有的构造函数默认的第一行都是super();

为什么一定要访问父类中的构造函数?

因为父类中的数据子类可以直接获取,所以子类对象在建立时需要查看父类是如何对这些数据进行初始化的,

所以子类在对这些对象进行初始化时,要先访问以下父类中的构造函数

如果要访问父类指定的构造函数,可以通过手动的定义super语句的方式来指定

注意:super语句一定要定义在构造函数的第一行

结论:

子类所有的构造函数默认都会访问父类中空参数的构造函数

因为子类每一个构造函数内的第一行都有一句隐式的super()

当父类中没有空参数的构造函数时,子类必须手动通过super()语句形式来指定要访问的父类中的构造函数

当然:子类的构造函数第一行也可以手动指定this语句来访问本类中的构造函数

这样的话,子类中也至少会有一个构造函数会访问父类中的构造函数。

  1. class Fu //extends Object
  2. {
  3.  
  4. int num=2;
  5. Fu()
  6. { //super();
  7. System.out.println("fu run");
  8. }
  9. Fu(int s )
  10. {
  11. System.out.println("fu..."+s);
  12. }
  13. }
  14.  
  15. class Zi extends Fu
  16. {
  17. Zi()
  18. {
  19. //super();//这里面相当于省略了super();
  20. super(4); //如果父类中定义了非空参数的构造函数,那么这里面就不能隐式,必须写出与之对应的调用
  21. System.out.println("zi run");
  22. }
  23. Zi(int x)
  24. {
  25. this();//如果有this()语句那么就没super()了,通过其他构造函数访问
  26. //super();
  27. //super(4);
  28. System.out.println("zi..."+x);
  29. }
  30. }
  31. class ExtendsDemo4
  32. {
  33. public static void main(String[] args)
  34. {
  35. Zi z=new Zi();
  36. System.out.println(z.num);
  37. }
  38. }
  39.  
  40. /*
  41. class Person
  42. {
  43. private String name;
  44. Person(String name)
  45. {
  46. this.name=name;
  47. }
  48. }
  49. class Student extends Person
  50. {
  51. Student(string name);
  52. {
  53. super(name);
  54. }
  55. void method()
  56. {
  57. super.show();
  58. }
  59. }
  60. */

7、this,super具体用法区分

this.name=name;表示把函数参数name赋值给当前对象的属性name;

this.print();调用当前对象的打印方法,this可省略。

this(name);表示调用本类的含一个参数的构造函数。

super(name):调用父类的构造函数

super.print();调用父类的打印方法

继承、多态——成员变量、成员函数、构造函数(this、super)的更多相关文章

  1. C++构造函数和析构函数,以及构造函数特殊成员变量和函数的初始化

    body, table{font-family: 微软雅黑; font-size: 10pt} table{border-collapse: collapse; border: solid gray; ...

  2. C++成员变量与函数内存分配

    关于结构体和C++类的内存地址问题 C++类是由结构体发展得来的,所以他们的成员变量(C语言的结构体只有成员变量)的内存分配机制是一样的.下面我们以类来说明问题,如果类的问题通了,结构体也也就没问题啦 ...

  3. c++ string类型成员变量在调用构造函数后未能正确赋值

    struct RelItem{ string segName; Elf32_Rel* rel; string relName; RelItem(string seg, int addr, string ...

  4. java中static修改成员变量和函数和其他使用

    一.通过static修饰的成员变量初始化只会初始化一次 //静态变量初始化只会初始化一次 public class zuishuai { public static void main(String[ ...

  5. Android-Java-静态成员变量&成员变量&局部变量(内存图&回收机制)

    静态成员变量(回收机制) StaticDemo 和 MyDemo package android.java.oop13; class MyDemo { /** * 定义一个静态变量 */ public ...

  6. var声明的成员变量和函数内声明的变量区别

    1.函数内部,有var声明的是局部变量,没var的,声明的全局变量. 2.在全局作用域内声明变量时,有var 和没var声明的都是全局变量,是window的属性.通过变量var声明全局对象的属性无法通 ...

  7. linux C++类中成员变量和函数的使用

    1.undefined reference to XXX 问题原因 1)XXX所在的so库等未指定 2)XXX在类中实现的时候没有加上类::函数的格式 2. was not declared in t ...

  8. Java:【面向对象:类的定义,静态变量,成员变量,构造函数,封装与私有,this】

    本文内容: 什么是面对对象 类的定义与对象实例化 成员变量 成员变量的有效范围 成员变量的赋值 静态变量.方法与实例变量.方法 构造函数 封装与私有 this关键字 注:函数和方法是一样东西.[由于我 ...

  9. C++ 类 & 对象-类成员函数-类访问修饰符-C++ 友元函数-构造函数 & 析构函数-C++ 拷贝构造函数

    C++ 类成员函数 成员函数可以定义在类定义内部,或者单独使用范围解析运算符 :: 来定义. 需要强调一点,在 :: 运算符之前必须使用类名.调用成员函数是在对象上使用点运算符(.),这样它就能操作与 ...

  10. static 成员变量、static 成员函数、类/对象的大小

    一.static 成员变量 对于特定类型的全体对象而言,有时候可能需要访问一个全局的变量.比如说统计某种类型对象已创建的数量. 如果我们用全局变量会破坏数据的封装,一般的用户代码都可以修改这个全局变量 ...

随机推荐

  1. jquery插件:aotocomplete

    aotocomplete.js http://blog.csdn.net/smeyou/article/details/7980273?_t_t_t=0.3565731019350138 $(func ...

  2. cmd命令速查手册

    CMD命令速查手册ASSOC显示或修改文件扩展名关联AT 计划在计算机上运行的命令和程序ATTRIB 显示或更改文件属性BREAK 设置或清除扩展式 CTRL+C检查CACLS显示或修改文件的访问控制 ...

  3. Hibernate学习之类级别注解

    © 版权声明:本文为博主原创文章,转载请注明出处 类级别注解: 1. @Entity 实体:表示映射实体类,使用@Entity时必须指定实体类的主键属性 @Entity(name="&quo ...

  4. 华为nova3发布,将支持华为AI旅行助手

    ​​​华为nova3于7月18日18:00在深圳大运中心体育馆举行华为nova 3的发布会,从本次华为nova3选择的代言人-易烊千玺,不难看出新机依然延续nova系列的年轻属性,主打 “高颜值 爱自 ...

  5. PYTHON流向下载

    #-*- coding:utf-8 -*- import gzip import re import http.cookiejar import urllib.request import urlli ...

  6. JavaWeb知识点总结一

    JavaWeb知识点总结一 常见的状态码以及其含义 一些常见HTTP状态码为: -- 服务器成功返回网页 -- 服务器不理解请求的语法 -- 请求的网页不存在 -- 服务不可用 常见HTTP状态码大全 ...

  7. 浏览器登录cookie

     <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.o ...

  8. cobbler pxe-menu

    对应的文件在 /var/lib/tftpboot/pxelinux.cfg下 如果profile的pxe-menu设置为1的话,就可以默认显示在menu上了.可以手动选择要下发哪一个profile. ...

  9. json格式转数组注意事项

    今天遇到一个特别奇葩的问题,json格式明明是正确的,转数组时却就是出不来,后来才发现是文件的编码问题,文件的编码一定要是utf-8无BOM格式,这点一定要切记!切记! 如果想确认json是否正确:h ...

  10. sudo npm install -g cnpm --registry=https://registry.npm.taobao.org