Java面向对象的三大特性
发布日期:2022-02-14 16:09:29
浏览次数:22
分类:技术文章
本文共 5591 字,大约阅读时间需要 18 分钟。
封装
- 概念:将一组逻辑相关的属性或方法封装在类中,通过访问权限修饰符来隐藏内部细节,公开访问的接口的技术称之为类的封装技术。
- 封装的好处:
- 隐藏内部实现细节;保护其不受外部影响
- 方便内部修改
- 降低外部使用的复杂度
- 良好的封装可降低耦合
属性的封装方式
- 用private修饰属性
- 提供set方法和get方法来分别为属性设置值或者取得属性值
- setter、getter方法是public(公开的),命名遵守setter属性名与getter属性名的规则,boolean的get方法使用is属性名
private String name;private int age;private boolean result;public void setName(String name){ this.name=name;}public String getName(){ return name;}public void setAge(int age) { this.age=age;}public int getAge() { return age;}public void setResult(boolean result) { this.result=result;}public boolean isResult(){ return true;}
构造器的封装(单例模式使用私有构造器)
public class InstanceTon { private static InstanceTon instanceTon = new InstanceTon(); private InstanceTon(){} public static InstanceTon getInstance(){ return instanceTon; }}
当然方法也能封装,使用访问权限修饰符来实现
继承
- 概念:一个类的定义基于另一个已存在的类(即子类基于父类),可实现代码的重用,子类能够获得已有类(父类)的属性和方法(非私有),并能扩展其它属性或方法的能力。
- 使用关键字extends实现继承
继承与构造器
- 子类继承父类,父类的构造器先执行,子类的构造器后执行
- 默认情况下,子类会调用父类的默认无参构造器
- 子类调用父类的非默认构造器,需使用super关键字并且指定正确的参数类型
- super调用父类的构造器必须在子类的构造器第一行
public class Animal { public Animal() { System.out.println("构造Animal"); } public Animal(int index){ System.out.println("构造Animal@"); } public Animal(int x,int y){ System.out.println("构造Animal@@"); }}public class Fish extends Animal { public Fish() { System.out.println("构造Fish"); } public Fish(int index){ super(12,23); System.out.println("构造Fish&"); }}public class SeaFish extends Fish { public SeaFish(){ System.out.println("构造SeaFish"); } public SeaFish(int index){ super(23); System.out.println("构造SeaFish%"); } public static void main(String[] args) { SeaFish seaFish = new SeaFish(23); System.out.println("======**======"); }}
SeaFish(int index)–>Fish(int index)–>Animal(int x,int y)。子类有义务先去执行父类构造方法则会先去构造父类,super关键字指明了使用父类的那个构造器。输出结果如下:
构造Animal@@构造Fish&构造SeaFish%======**======
- 继承中构成方法重写的条件
- 方法名相同
- 形参相同
- 同返回值类型
- 子类方法的访问权限控制符不能缩小
public class Shape { public void draw() { System.out.println("正在画图形"); } public double area(double x) { System.out.println("计算面积"); return x; }}public class Crcle extends Shape { private double radius; private double area; public void draw() { System.out.println("正在画圆"); } public double area(double x) { area = x*x*Math.PI; return area; }}public class App { public static void main(String[] args) { Crcle crcle = new Crcle(); crcle.draw(); Square square = new Square(); square.draw(); }}
- final修饰符
- final修饰类,则该类不可被继承;
- final修饰属性,该属性不可变;
- final修饰方法,该方法不可被重写;
- 接口可以继承多个接口,类是单继承的
多态
- 面向对象三大特性之一;
- 含义:对外一种表现形式,对内多种具体实现;
典型用法:
//父类变量指向子类实现Parent = new Child();//接口的变量指向实现类的实现 Interfacei = new Implementation();
体现
- 方法重载
- 方法重写
多态参数(依赖关系”use-a”)
方法的参数为父类或者接口时,可传入父类的子类或者接口的实现类
/*** 限额对象* @author Administrator**/public class Quota { private double amount; private String type; public double getAmount() { return amount; } public void setAmount(double amount) { this.amount = amount; } public String getType() { return type; } public void setType(String type) { this.type = type; }}/*** 限额加载器* @author Administrator**/public interface QuotaLoader { Quota load(String userId);}/*** 业务限额加载器* @author Administrator**/public class BusinessQuotaLoader implements QuotaLoader { @Override public Quota load(String userId) { return null; }}/*** 央行政策性限额* @author Administrator**/public class PolicyQuotaLoader implements QuotaLoader{ @Override public Quota load(String userId) { return null; }}public class CalcService { private static final QuotaLoader[] QUOTA_LOADERS = { new PolicyQuotaLoader(),new BusinessQuotaLoader()}; public static void main(String[] args) { List
quotas = new ArrayList<>(); for(QuotaLoader ql : QUOTA_LOADERS){ Quota q = ql.load("xxxx"); quotas.add(q); } //quotas排序,得到最小的限额 }} 扩展性强
转换
- 隐式转换:把子类转换为父类;
强制转换(类型兼容):用(类型)强制转换(需注意编译期类型与运行期类型);
//父类强转子类(子类名)父类实例 //运行报错Animal不能强转为Cat Animal animal = new Animal(); Cat cat = (Cat)animal; //能转 Animal anim = new Cat(); Cat c = (Cat)anim; //把子类转为父类,隐式转换(自动转换) //运行报错Dog不能强转为Cat Animal anima = new Dog(); Cat ca = (Cat)anima; //编译报错 Dog dog = new Dog(); //Cat cat2 = (Cat)dog;
如果强制转换的两个类型没有父子关系,编译正常,运行报错;
- 运行期类型与编译期类型(运用多态时需注意)
- Animal animal = new Cat();
- 运行期Cat,编译期Animal;
- 同名属性,与类型名相同;
- 多态环境下的属性和方法
- 静态方法,与类型名相同;
- 成员方法,由于重写,会先去执行子类方法;
- 同名属性,与类型名相同 ;
public class Animal { public String age = "3"; public void bark(){ System.out.println("动物叫"); } public static void sf(){ System.out.println("父类静态方法"); }}public class Cat extends Animal { public int age = 5; public void bark(){ System.out.println("喵~喵~"); } public void catchMice(){ System.out.println("抓老鼠"); } public static void sf(){ System.out.println("子类静态方法"); }}public class Dog extends Animal { public void bark(){ System.out.println("汪汪"); }}public class App2 { public static void main(String[] args) { Animal a = new Cat(); //对于成员方法调用,因为方法覆盖的问题,导致运行期调用的是子类的方法 a.bark(); //对于同名的静态方法调用,声明为何类型则调用该类型的方法 a.sf(); //对于同名的属性,实际为声明类型的属性 System.out.println(a.age); }}
转载地址:https://blog.csdn.net/qq_29593573/article/details/72886283 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
网站不错 人气很旺了 加油
[***.192.178.218]2024年03月27日 15时22分39秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
分布式事务 四种方案
2019-04-27
redis和spring整合
2019-04-27
iis6 和iis7s上整个网站重定向
2019-04-27
iis7 url重写和重定向
2019-04-27
navicat工具来将SQL Server数据迁移到MySQL
2019-04-27
微信公众号从头开发(接入与消息)
2019-04-27
端口占用 杀死进程
2019-04-27
XStream xml与javabean之间的互转
2019-04-27
Android应用构建:10:使用sdkmanager管理sdk
2019-04-27
Kubernetes基础:MacOS上设定Dashboard
2019-04-27
Go基础:MacOS上配置go语言开发环境
2019-04-27
Operator基础:1: Operator Framework简介
2019-04-27
Operator基础:2: Operator SDK安装
2019-04-27
Operator基础:3: 使用Operator SDK创建Operator
2019-04-27
GitLab基础:使用API获取某个项目下所有成员及权限信息
2019-04-27
Subversion Edge:下载官方旧版的Subversion Edge
2019-04-27
OpenEuler简介与安装
2019-04-27
轻量级容器引擎iSula简介
2019-04-27
Bash基础:在MacOS上确认版本与升级Bash的方法
2019-04-27
版本管理:Subversion Edge:旧版使用OpenJDK的问题和对应方法
2019-04-27