Java三大特性,五大原则,深刻解读,读完这一篇就够了!

2023-11-08 06:21

本文主要是介绍Java三大特性,五大原则,深刻解读,读完这一篇就够了!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录:

  • 三大基本特征:
    • 一.封装:
      • 理解:
      • 模拟问题:
      • 封装的好处:
    • 二.继承:
      • 概念:
      • 优点和缺点:
      • 使用:
      • 使用场景":
      • 继承中构造方法的访问特点:
      • 继承中构造方法的访问特点-父类没有空参构造方法:
      • 使用继承的注意事项:
    • 三.多态:
      • 概念:
      • 多态的前提:
      • 多态的好处和弊端:
      • 多态中转型:
  • 五大基本原则:
    • 一.单一责任制原则:
      • 优点:
      • 缺点:
      • 使用场景:
    • 二.开放密闭原则:
      • 概念:
      • 作用:
      • 案例:
      • 优点:
    • 三.里氏替换原则:
      • 概念:
      • 举例说明:
      • 提示:
    • 四.依赖倒置原则:
      • 定义:
      • 问题:
      • 解决方案:
      • 理解:
      • 实例:
      • 注意:
    • 五.接口隔离原则:
      • 定义:
      • 解决方案:
      • 理解:
      • 接口隔离原则的含义是:

三大基本特征:

一.封装:

理解:

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

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

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

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

对比一下没有封装和有封装~

没有封装的时候

模拟问题:

  1. 描述Employee类。定义姓名,工号,性别的成员变量,和工作的方法。成员使用public修饰。
  2. 创建Employee对象,对象.成员的方式进行赋值。最后该对象调用工作方法。
  3. 总结:如果不使用封装,很容易赋值错误,并且任何人都可以更改,造成信息的 不安全。
  4. 问题解决:使用封装
/*** @Author: NanQiang* @Date: 2020/7/15 11:18*/
public class EmployeeDemo {public static void main(String[] args) {// 创建对象Employee jack = new Employee();// 进制通过类名.成员的形式调用成员。初始化实例变量jack.name = "jack";jack.id = "123456";jack.gender = "男";// 调用成员方法jack.work();System.out.println();// 传入非法的参数jack.gender = "不是男人";jack.work();}
}class Employee {String name;String id;String gender;public void work() {System.out.println(id + ":" + name + ":" + gender + " 努力工作中!!!");}
}

有封装的时候

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

/*** @Author: NanQiang* @Date: 2020/7/15 11:18*/
public class EmployeeDemo {public static void main(String[] args) {// 创建对象Employee jack = new Employee();//编译报错jack.name = "jack";jack.id = "123456";jack.gender = "男";// 编译报错jack.gender = "不是男人";jack.work();}
}class Employee {//使用了private修饰了成员变量private String name;private String id;private String gender;public void work() {System.out.println(id + ":" + name + ":" + gender + " 努力工作中!!!");}
}

修改Employee类 性别的修饰符修改为private

1:编译不通过

2:private修饰的成员在自己所在的类中可以使用,在类外边不可以使用。

3:Employee类的gender的修饰符修改为private后,无法再类外调用,那么如何给gender设置值?

  1:对外提供公开的用于设置对象属性的public方法1:设置set2:获取get2:在set方法中加入逻辑判断,过滤掉非法数据。3:将所有的成员变量封装加上private,提供get、set方法

权限修饰符:在这里插入图片描述

/*** @Author: NanQiang* @Date: 2020/7/15 11:18*/
public class EmployeeDemo {public static void main(String[] args) {// 创建对象Employee jack = new Employee();// 调用公有方法,给成员变量赋值。jack.setId("007");jack.setName("jack");jack.setGender("男xx");// 获取实例变量的值System.out.println(jack.getGender());System.out.println(jack.getId());System.out.println(jack.getName());// 调用成员方法jack.work();}
}class Employee {private String name;private String id;private String gender;// 提供公有的get set方法public String getName() {return name;}public void setName(String n) {name = n;}public String getId() {return id;}public void setId(String i) {id = i;}public String getGender() {return gender;}public void setGender(String gen) {if ("男".equals(gen) || "女".equals(gen)) {gender = gen;} else {System.out.println("请输入\"男\"或者\"女\"");}}public void work() 

这篇关于Java三大特性,五大原则,深刻解读,读完这一篇就够了!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/368332

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听