27访问修饰符以及面向对象的三大特征

访问修饰符

就是确定类、变量、方法等能不能够被正常访问的修饰符

Java本身提供了四个访问修饰符

  1. public 在任何地方都可以正常访问,权限最大
  2. protected 同包、子类、同类
  3. 默认(缺省) 不写 同包、同类
  4. private 同类
    注意:protected 、private 不能修饰类

举例

在这里插入图片描述在这里插入图片描述

面向对象的三大特征

封装

定义

从广义上来说,封装就是将物品保管起来封存起来
面向对象上说的封装,是一种特指:
将类的属性私有化(不在为外界提供直接访问属性的方式)
提供对应的getter 和 setter方法来访问和设置属性。

目的

封装的目的:数据的安全性和私密性

POJO(Plain Ordinary Java Object):经典的Java类

举例
package com.openlab.ke.code1;

//标准的Java bean
//JOPO

public class Admin {
	private String username;
	private String password;
	private int age;
	private String nickname;
	private String email;
	private String avatar;

	public String getUsername() {
		return username;
	}

	public void setUsername(String username) {
		this.username = username;
	}

	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}

	public int getAge() {
		return age;
	}

	public void setAge(int age) {
		this.age = age;
	}

	public String getNickname() {
		return nickname;
	}

	public void setNickname(String nickname) {
		this.nickname = nickname;
	}

	public String getEmail() {
		return email;
	}

	public void setEmail(String email) {
		this.email = email;
	}

	public String getAvatar() {
		return avatar;
	}

	public void setAvatar(String avatar) {
		this.avatar = avatar;
	}

	public Admin() {

	}

	public Admin(String username, String password, int age, String nickname, String email, String avatar) {
		this.username = username;
		this.password = password;
		this.age = age;
		this.nickname = nickname;
		this.email = email;
		this.avatar = avatar;
	}
	
	//tostring 就是用来test
	@Override
	public String toString() {
		return "Admin [username=" + username + ", password=" + password + ", age=" + age + ", nickname=" + nickname
				+ ", email=" + email + ", avatar=" + avatar + "]";
	}
	
	public static void main(String[] args) {
		Admin admin = new Admin();
		admin.setUsername("张三");
		admin.setAge(19);
		
		//java中,如果你在控制台上打印对象,默认toString
		System.out.print(admin);
	}

}

Admin [username=张三, password=null, age=19, nickname=null, email=null, avatar=null]

举例

在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

继承

在Java中,如果要有继承存在,被继承的类叫做父类(超类、基类),继承的类叫做子类(派生类),Java使用extends 关键字实现继承

定义

Java中,如果一个类,继承了另外一个类,则把这种现象叫做继承,此时这个类就会 继承父类(被继承的类)中的能够被继承的类成员(重点方法)

继承范围

子类会继承父类中的属性和方法

  • 如果父类和子类在同包中,只要不是private修饰的都能继承
  • 如果父类和子类在不同的包中,只能继承public、protected修饰的

举例

package com.openlab.ke.extend;

public class RichMan {
	public double money =1000000;
	protected String hourse = "白龙马";
	String car = "奔驰";
	private String ship = "神舟九号";
	
	public void say() {
		System.out.println("我对钱不感兴趣");
	}
	
	protected void say2() {
		System.out.println("我真是太傻了,竟然对钱没兴趣");
	}
	
	private void say3() {
		System.out.println("所以我到底对什么感兴趣");
	}

}

package com.openlab.ke.extend;

public class Son extends RichMan {
	public static void main(String[] args) {
		Son s = new Son();
		s.say();
		s.say2();
		
	}

}

继承的目的

面向对象的继承,就是为了提高代码的复用性。

覆盖(override) | 重写(overwrite)

当一个子类继承父类后,发现某个方法不满足自己使用的时候,重写(覆盖)该方法,实现能够满足自己使用的方法

方法

在Java中,重写父类方法,直接在子类中定义相同名称的方法即可
从jdk1.5开始,引入@Override这个注解
super关键字

package com.openlab.ke.extend;

public class Animal {
	
	public void say() {
		System.out.println("我是个小动物,但是我不知道怎么叫~~~~");
	}

}

package com.openlab.ke.extend;

public class Dog extends Animal {
	
	//重写父类方法,该方法名称必须和父类一样
	//访问修饰符,允许放大,不能缩小,建议保持一致
	//注解,标明是重写的方法
	@Override
	public void say() {
		System.out.println("汪汪汪");
	}
	
	public void say1() {
		System.out.println("wuwuwuw");
		//super关键字,调用父类的方法
		super.say();
	}
	
	public static void main(String[] args) {
		Dog d = new Dog();
		d.say1();
		//instanceof 关键字,用来判断对象是否是某个类的实例
		System.out.println(d instanceof Dog);
		
		
	}

}

wuwuwuw
我是个小动物,但是我不知道怎么叫~~~~
true

继承链

Java是典型的单继承机制,一个类只能有一个父类!!!
Java类存在一个根类(root class),object类!

instanceof关键字

用来判断对象是否是某个类的实例

final关键字

  • final修饰变量,该变量就会称为常量,不能够在被修改(runtime)
  • final可以修饰类,一旦final修饰类,该类就是最终类,不允许被继承
  • final还可以修饰方法,该方法为最终方法,该方法不允许重写(Override)
举例
package com.openlab.ke.extend;

public class TestFinal {
	//使用final定义常量
	public static final double PI =3.1415926;
	
	public static void main(String[] args) {
		System.out.println(PI);
	}

}

在这里插入图片描述

面试题

为什么String类会设计为final修饰

首先,被final修饰的变量,无论是类属性、对象属性、形参还是局部变量,都需要进行初始化操作。而String被final修饰主要由于两个方面:安全性和效率

一)效率:使用字符串池

final修饰的String,代表这个类不能被继承,而String是一个char类型的数组,证明它是不可更改的,但这也仅仅是引用地址不可改,再加上被private修饰,证明数组本身也不会改变。只有当字符串本身也不会变的时候才可以使用字符串池,这样节省空间

二)安全性:String类被final修饰不能被继承,无法修改,在多线程情况下也是安全的。

内部类

内部类可以直接访问包裹着它的外部类任何属性和方法(包括私有的)
一般而言,定义内部类,主要的目的肯定是在包裹着它的外部类中使用它

package com.openlab.code10.innerclass;

import com.openlab.code10.innerclass.TestInnerClass.Inner01;
import com.openlab.code10.innerclass.TestInnerClass.Inner02;


public class TestInnerClass {
	private int id = 10;
	private static String name;
	
	public void say() {
		Inner01 t = new Inner01();
		t.say();
	}
	
	//此时Inner01就是TestInnerClass的内部类
	class Inner01{
		public void say() {
			System.out.println(id);
			
		}
	}
	
	//static 可以修饰内部类
	//静态类(静态内部类),能直接访问外部类的静态属性
	public static class Inner02{
		public void say() {
			TestInnerClass tic = new TestInnerClass();
			System.out.println(tic.id);
			System.out.println(name);
			
		}
		
	}

}

class outer{
	public void say() {
		//如果在外界初始化内部类对象
		//TestInnerClass tic = new TestInnerClass();
		//Inner01 t1 = tic.new Inner01();
		
		Inner01 t1 = new TestInnerClass().new Inner01();
		t1.say();
		
		//如果是静态内部类,可以使用下面方式创建
		Inner02 t2 = new TestInnerClass.Inner02();
		
	}
}

import static

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

多态

一个事务的多种状态
多态是在继承的基础上存在的,父类引用指向子类实例

举例

package com.openlab.ke.polymorphic;

public class Pet {
	
	public String name;
	public int age;
	public int health;
	
	//宠物的治疗方案
	public void cure() {
		
	}
}

package com.openlab.ke.polymorphic;

public class QQ extends Pet {

	@Override
	public void cure() {
		System.out.println("充值");
		System.out.println("会员");
		System.out.println("开黑");
		System.out.println("然后就好了");
		this.health = 100;
	}
	
	

}

package com.openlab.ke.polymorphic;

public class Pig extends Pet {

	@Override
	public void cure() {
		System.out.println("大师兄说要给力");
		System.out.println("三师弟说要回家");
		System.out.println("我说要回高老庄");
		System.out.println("散伙了,我的病也好了");
		this.health = 100;
	}
	
	

}

package com.openlab.ke.polymorphic;

public class Master {

	private String name;
	private QQ qq;
	private Pig pig;

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public QQ getQq() {
		return qq;
	}

	public void setQq(QQ qq) {
		this.qq = qq;
	}

	public Pig getPig() {
		return pig;
	}

	public void setPig(Pig pig) {
		this.pig = pig;
	}
	
	//治疗企鹅的方法
//	public void cure(QQ qq) {
//		if(qq.health <60) {
//			System.out.println("充值");
//			System.out.println("开黑");
//			System.out.println("会员");
//			System.out.println("封号");
//			qq.health = 100;
//			
//		}
//	}
//	
//	public void cure(Pig pig) {
//		if(qq.health <60) {
//			System.out.println("喊大师兄");
//			System.out.println("女菩萨真好看");
//			System.out.println("嫦娥妹妹真好看");
//			System.out.println("放开师傅冲我来");
//			qq.health = 100;
//			
//		}
//	}
	//多态,使用父类引用,来替代子类对象,此时父类引用代指的是所有子类对象
	public void cure(Pet pet) {
		if(pet.health < 60) {
			pet.cure();
		}
	}


}

package com.openlab.ke.polymorphic;

public class Test02 {
	public static void main(String[] args) {
		Master master = new Master();
		master.setName("张三");
		
		QQ qq = new QQ();
		qq.name = "帝王🐧";
		qq.age = 12;
		qq.health = 50;
		
		Pig pig = new Pig();
		pig.name = "八戒";
		pig.age = 420;
		pig.health = 30;
		
		master.setPig(pig);
		master.setQq(qq);
		
		master.cure(pig);
		master.cure(qq);
		
		
		
	}

}

大师兄说要给力
三师弟说要回家
我说要回高老庄
散伙了,我的病也好了
充值
会员
开黑
然后就好了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值