博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
day5 面向对象
阅读量:4322 次
发布时间:2019-06-06

本文共 7271 字,大约阅读时间需要 24 分钟。

面向对象的特征

 封装(encapsulation)

继承(inheritance)

多态(polymorphism)

开发的过程:其实就是不断的创建对象,使用对象,指挥对象做事情。

设计的过程:其实就是在管理和维护对象之间的关系.

匿名对象

匿名对象:没有名字的实体,也就是该实体没有对应的变量名引用。

2.2匿名对象的用途  

1,当对象对方法进行一次调用的时候,可以使用匿名对象对代码进行简化。

   为什么只对方法,而不调用属性呢?因为匿名对象调用属性没意义。

   如果对象要多成员进行多次调用,必须给对象起个名字。不能在使用匿名         对象。

2,匿名对象可以实际参数进行传递。

    2:匿名对象的简单演示

        1:new Car().run();

3:内存结构图

        1:new Car().num=5;

        2:new Car().clor="blue";

        两个new 是两个不同的对象,在堆内存中有不同的空间,相互不相互干扰。

4:匿名对象的使用

        1:当只使用一次时可以使用匿名对象。执行完毕到;后该对象就变成了垃圾。

       new Car().run();

      2:执行方法时,可以将匿名对象作为实际参数,传递进去。

封装

       我们日常使用的电脑主机,把cpu、内存、主板等等都封装到机箱里面去。假如没有机箱的话的出现什么问题,主机、主板全部都散落在一处,然后开机没有开机按钮,那么需要我们直接操作接跳线才能把电脑开启。这样子的话假如操作不慎的话,会让机器损坏危险,那么假如用机箱封装起来的话,那么就不需要这样子做了。体现了封装的---安全特性。

你拿电脑去加内存,可以直接给电脑给维修的人,等他加好内存了之后。你拿到的还是那个机箱,里面发生了怎样子的变化你并不知道。封装的第二个好处-将变化隔离。

 

在机箱里面提供一个开机按钮,而不需要你直接使用跳线开机的话,体现了封装的—便于使用的特性。

 

只要机箱提供了一个开机的功能,然后无论这个机箱拿到哪里去,都可以使用这个开机的功能.体现了封装的---提供重复性的特性。

1、  没有封装

模拟问题

  1. 描述Employee类。定义姓名,工号,性别的成员变量,和工作的方法。成员使用public修饰。
  2. 创建Employee对象,对象.成员的方式进行赋值。最后该对象调用工作方法。
  3. 总结:如果不使用封装,很容易赋值错误,并且任何人都可以更改,造成信息的        不安全。
  4. 问题解决:使用封装

封装的实现

    1:设置类的属性为private(关键字),不能使用对象名.属性名的方式直接访问对象的属性。

封装的好处

    1:隐藏了类的具体实现

    2:操作简单

    3:提高对象数据的安全性

构造方法

       1.我们人出生的时候,有些人一出生之后再起名字的,但是有些人一旦出生就已经起好名字的。那么我们在java里面怎么在对象一旦创建就赋值呢?

构造方法的作用:对对象进行初始化

构造函数与普通的函数的区别

  1. 一般函数是用于定义对象应该具备的功能。而构造函数定义的是,对象在调用功能之前,在建立时,应该具备的一些内容。也就是对象的初始化内容。
  2. 构造函数是在对象建立时由jvm调用, 给对象初始化。一般函数是对象建立后,当对象调用该功能时才会执行。
  3. 普通函数可以使用对象多次调用,构造函数就在创建对象时调用。
  4. 构造函数的函数名要与类名一样,而普通的函数只要符合标识符的命名规则即可。
  5. 构造函数没有返回值类型。

 

构造函数注意的细节

1. 当类中没有定义构造函数时,系统会指定给该类加上一个空参数的构造函数。这个是类中默认的构造函数。当类中如果自定义了构造函数,这时默认的构造函数就没有了。

    备注:可以通过javap命令验证。

2.在一个类中可以定义多个构造函数,以进行不同的初始化。多个构造函数存在于类中,是以重载的形式体现的。因为构造函数的名称都相同。

 

1 class Perosn{ 2     private int id; 3      4     private String name; 5      6     private int age; 7      8     public Perosn(){ 9         cry();10     }11     public Perosn(int id, String name, int age) {12         this.id = id;13         this.name = name;14         this.age = age;15     }16     public int getId() {17         return id;18     }19     public void setId(int id) {20         this.id = id;21     }22     public String getName() {23         return name;24     }25     public void setName(String name) {26         this.name = name;27     }28     public int getAge() {29         return age;30     }31     public void setAge(int age) {32         this.age = age;33     }34     35     36     public void cry(){37         System.out.println("哇哇哇....");38     }39     40 }

问题:要求每个小孩出生都会哭,这份代码有两个构造函数,如果需要每个小孩出生都要哭的话,那么就需要在不同的构造函数中都调用cry()函数,但是这样子的话造成了代码重复问题,那么怎么解决呢?构造代码块。

构造代码块

构造代码块作用:给所有的对象进行统一的初始化。

1 class Perosn{ 2     private int id; 3      4     private String name; 5      6     private int age; 7      8     { 9         cry();// 每个Person对象创建出来都会执行这里的代码10     }11     12     public Perosn(){13         cry();14     }15     public Perosn(int id, String name, int age) {16         this.id = id;17         this.name = name;18         this.age = age;19     }20     public int getId() {21         return id;22     }23     public void setId(int id) {24         this.id = id;25     }26     public String getName() {27         return name;28     }29     public void setName(String name) {30         this.name = name;31     }32     public int getAge() {33         return age;34     }35     public void setAge(int age) {36         this.age = age;37     }38     39     40     public void cry(){41         System.out.println("哇哇哇....");42     }43     44 }
View Code

作用

1:给对象进行初始化。对象一建立就运行并且优先于构造函数。

2:与构造函数区别

1:构造代码块和构造函数的区别,构造代码块是给所有对象进行统一初始化, 构造函数给对应的对象初始化。

2:构造代码块的作用:它的作用就是将所有构造方法中公共的信息进行抽取。

例如孩子一出生统一哭

1 class Boy { 2  3     String name; 4     int age; 5     String gender; 6      // 构造代码块,给所有对象进行初始化。 7     { 8         System.out.println("哭。。。"); 9     }10      11     Boy() {12         System.out.println("无参构造");13     }14 15     Boy(String n, int a, String g) {16         name = n;17         age = a;18         gender = g;19         System.out.println("有参构造");20     }21 22     void run() {23         System.out.println("跑...");24     }25 26 }27 28 class Demo9 {29 30     public static void main(String[] args) {31 32         System.out.println();33         Boy b = new Boy();34 35         Boy b2 = new Boy("jack", 1, "男");36 37     }38 }
View Code

this关键字

       疑问:创建的p对象为什么没有值。

解答:name与age在指定的构造函数里面已经存在,当name=name这个语句执行的时候,如果jvm在该方法内能寻找到该变量,则不会去寻找成员变量,那么要想指定给成员变量或对象的属性进行初始化赋值,那么必须指定name是成员属性。

1、this 的概述

this关键字代表是对象的引用。也就是this在指向一个对象,所指向的对象就是调用该函数的对象引用。

1:没有this会出现什么问题

    1:定义Person类

       1:有姓名年龄成员变量,有说话的方法。

       2:定义构造方法,无参的,多个有参的。都要实现。

1 Vclass Person { 2  3     String name; 4     int age; 5     //无参数构造函数 6     Person() { 7         System.out.println("这是无参的构造函数"); 8     } 9     10     //有参数构造函数11     Person(int a) {12         age = a;13         System.out.println("有参构造1");14     }15     //有参数构造函数16     Person(String n) {17         name = n;18         System.out.println("有参构造2");19     }20     //有参数构造函数21     Person(int a, String n) {22         age = a;23         name = n;24         System.out.println("有参构造");25     }26     27     //普通函数28     void speak() {29         System.out.println("hah");30     }
View Code

2;假设定义40个成员变量,第一个有参构造初始化20个变量,第二个有参构造需要初始化40个变量。

       1:第二个有参构造想要使用第一个有参构造。

       2:成员函数相互之间可以调用。构造函数可以吗?

  3:编译失败,那么构造函数之间应该存在相互调用的模式。this就可以完成这个工作。

1 class Person { 2     String name; 3     int age; 4  5     Person() { 6  7     } 8     Person(String n){ 9         name=n;10     }11     Person(String n, int a) {12         //编译报错13         Person(n);14         age = a;15     }16 }
View Code

3:总结:实际工作中,存在着构造函数之间的相互调用,但是构造函数不是普通的成员函数,不能通过函数名自己接调用

              所以sun公司提供this关键字。

2:this是什么

       1:在构造函数中打印this

       2:创建对象,打印对象名p

       3:this和p是一样的都是内存地址值。

       4:this代表所在函数所属对象的引用。

 

1 class Student { 2     String name; 3     String gender; 4     int age; 5  6     Student() { 7  8     } 9 10     Student(String name) {11         this();12         this.name = name;13     }14 15     Student(String name, String gender, int age) {16         this(name);17         System.out.println(this); // Student@c1716418 19         this.gender = gender;20         this.age = age;21     }22 23     void speak() {24         run();25         System.out.println("姓名:" + name + " 性别:" + gender + " 年龄:" + age26                 + " 哈哈!!!");27     }28 29     void run() {30         System.out.println("run.....");31     }32 33 }34 35 class Demo2 {36 37     public static void main(String[] args) {38 39         Student p = new Student("jack", "男", 20);40         System.out.println(p); // Student@c1716441 42         Student p2 = new Student("rose", "女", 18);43         System.out.println(p2);44 45         p.speak();46 47     }48 }
View Code

 

3:递归构造函数调用

       1:构造函数的相互调用

           在编译时期会报错

1 class Student { 2     String name; 3     String gender; 4     int age; 5     //构造函数见相互调用 6     Student() { 7         this(null); 8     } 9     //构造函数见相互调用10     Student(String name) {11         this();12         this.name = name;13     }14 15     Student(String name, String gender, int age) {16         this(name);17         this.gender = gender;18         this.age = age;19     }20 21     void speak() {22         run();23         System.out.println("姓名:" + name + " 性别:" + gender + " 年龄:" + age24                 + " 哈哈!!!");25     }26 27     void run() {28         System.out.println("run.....");29     }30 31 }
View Code

 

4:this只能在非静态中(没有static修饰的)函数使用

5:构造函数间相互调用必须放在构造函数的第一个语句中,否则编译错误

6:可以解决构造函数中对象属性和函数形参的同名问题。

转载于:https://www.cnblogs.com/Michael2397/p/5944121.html

你可能感兴趣的文章
移植wpa_supplicant2.5及界面配置wifi(原创)
查看>>
JAVA编码(52)—— API接口安全性设计
查看>>
c:"WINDOWS"Microsoft.NET"Framework"v2.0.50727"Temp
查看>>
android EditText自动弹出和自动关闭软键盘
查看>>
吉特日化MES-工业生产盲区
查看>>
Codeforces 517 #B
查看>>
实验四
查看>>
Scramble String
查看>>
php之接口概念
查看>>
01、计算机原理结构,及冯诺依曼体系结构
查看>>
Python 列表基本操作
查看>>
Linux TC基于CBQ队列的流量管理范例
查看>>
Python hashlib and hmac
查看>>
Fitnesse Page 简单使用
查看>>
C#.net 创建XML
查看>>
1057 数零壹
查看>>
隐马尔科夫模型(上)
查看>>
asp.net mvc FluentValidation 的使用
查看>>
java JvM
查看>>
HDU 1009 Just a Hook
查看>>