面向对象-封装

一.包

1.简介

当我们把所有的java类都写src下的第一层级,如果是项目中,也许会有几百个java文件。

  • src下的文件会很多,开发的时候不方便查找,也不方便维护
  • 如果较多的文件中有同名的,十分麻烦
    • 模块1中有一个叫test.java
    • 模块2中有一个叫test.java
    • 这种情况下你必须把其中的一项改名

所以解决的方法有很多:

  • 根据分类创建不同的文件夹
  • 不同的文件夹放不同的java类

所以,在这里,我们准确的说,包就是一个一个的文件夹!!
其作用就是方便开发者管理、查找、维护代码。为了避免命名的冲突(虽然我起名都起的怪怪的)。

2.创建&重命名

创建:
image.png
重命名:
image.png

3.定义&声明&导入

定义:

一般来说,包的名字一定都是纯英文(不怕被骂也可以选择其他的,或者有啥特殊癖好),都是小写

命名规则:

公司的域名(倒着).项目名.模块名

  - cn.xxx.test.login(xxx公司的test项目下的登录模块)
  - cn.yyy.try.best(yyy公司的try项目下的最好模块)

image.png

声明:

语法一般都是-----package 包名
注意必须都放在第一行
其作用是:

  - 声明自己所在的位置
  - 方便别人调用的时候找到

image.png
包的申明:不需要你自己写,idea自动回帮你添加。一定要有,没有回报错。

导入:

帮你找到要用的包,例如,自己定义的包和jdk里面有的包
image.png

二.封装

我们可以先举一个例子:

public class Work03 {
    public static void main(String[] args) {
        BankCard bankCard = new BankCard("001", "中国工商银行", 0.0);

        bankCard.saveMoney(100, 123); //输入密码,存钱,余额增加【经过了银行】

        bankCard.balance = 20000; // 直接修改余额。绕过银行。

        bankCard.saveMoney(100, 123);
    }
}

说明了什么呢?
用户不经过银行,直接任意的篡改成员变量balance。 不符合现实生活,绕过银行,随意更改余额。封装没有做好,把余额直接暴露给用户,用户可以操作余额。
十分危险的是吧,但也挺对我们心动的,哈哈哈哈。
image.png

1.简介

封装的思想

洗衣机就是一个典型的封装思想。
洗衣机被一层壳子保住,核心的功能对外是封装(不可见的)。它提供一个操作面板给用户,用户选择模式,点击按钮开始就开始洗衣服。 把想暴露给你的暴露给你,不想暴露给你的,给你提供一个操作的窗口,让你操作。
银行卡的例子呢就是,暴露给你的是一个一个的柜台窗口(工作人员跟我对接), 我存钱了,钱的去处,卡里余额的改变,用户不知道。被银行封装起来了。

封装的好处
将细节隐藏起来,不让外界随便使用,但是我们可以提供一个公共的接口让外界间接使用隐藏起来的细节。
  • 对于使用者:更加的方便(通过点击几个键就能洗衣服,通过银行的柜台就能存钱获取利息)
  • 开发者:系统的可扩展性,可维护性,安全性
  • 安全性:银行没有把内部暴露给你,更加的安全。
  • 扩展性:银行的存款利率变了,内部变就行了。外部是不影响其使用。

2.详解

封装主要的功能

保护成员变量不被随意的访问与修改(就像余额不能随即修改)
权限控制(没达到权限的就不能访问)

  • 跟包有关
  • 例子:有些属性,必须要求同一个包下面才能访问。
封装的步骤(重要)

将成员变量的修饰符都改为private:

  • public: 公共的、公开的。 最大权限,被其修饰的成员,在任意目录(包)下,都可以访问到 (所有类)
  • protected:受保护的
  • private:私有的

提供外界访问和修改成员变量的方法:

  • 成员变量的修改和读取都要经过类里面
  • 访问: 修饰符[public] 成员变量的类型 get成员变量名() { return 成员变量 }
  • 修改: 修饰符[public] void set成员变量名(成员变量的类型 成员变量名) { this. 成员变量名 = 值 }

修饰符详解(权限控制):

  • public 最大权限,被其修饰的成员,在任意目录(包)下,都可以访问到
  • protected: 在同包类和子类中都可以访问
  • 默认不写: 只能在同包类中访问
  • private: 只能在类中被访问 【最私密的一个权限】
封装的例子
public class BankCardTwo {
     private double balance;
//修饰符+变量类型+变量名
    
     public BankCardTwo() {    }    
     
     public BankCardTwo(double balance) {        
         this.balance = balance;    }        
    
     public double getBalance() {        
         return balance;    }    
    
     public void setBalance(double balance) {    
         this.balance = balance;    }
}

下一章解释下this和javabean,

希望各位读者大大一键三连!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/771689.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Nuxtjs3教程

起步 官方文档 官方目录结构 安装 npx nuxi@latest init <project-name>后面跟着提示走就行 最后yarn run dev 启动项目访问localhost:3000即可 路由组件 app.vue为项目根组件 <nuxt-page />为路由显示入口 将app.vue更改内容如下 <template><d…

WPS中制作甘特图的详细教程

网上没几个详细说怎么在WPS中制作甘特图的&#xff0c;我自己整理了一下详细教程&#xff0c;最终效果如下图所示&#xff1a; 1.写好需要展示的项目相关信息&#xff0c;如下图所示&#xff1a; #####这个进度的百分比渐变效果这样设置就行了 2.现在我们需要计算已用时间和剩…

lodash中flush的使用(debounce、throttle)

在项目的配置中&#xff0c;看到了一个请求&#xff0c;类似是这样的 import { throttle } from lodash-es// 请求函数 async function someFetch(){const {data} await xxx.post()return data }// 节流函数 async function throttleFn(someFetch,1000)// 执行拿到数据函数 a…

Zabbix 配置MySQL数据库监控

Zabbix MySQL数据库监控简介 通过 Zabbix 监控 MySQL 数据库&#xff0c;可以获取有关数据库性能、运行状况和资源使用情况的详细信息&#xff0c;帮助及时发现和解决问题。 Zabbix官方提供了一个名为MySQL by Zabbix agent的监控模板&#xff0c;该模板专为 Zabbix 通过 Zabb…

Java中的文件IO

文件,我们之前在C语言中接触过,是在硬盘上存储数据的方式,操作系统帮我们把硬盘的一些细节都封装起来了,因此在这里我们只需要了解文件的相关接口即可. 首先硬盘是用来存储数据的,和内存相比,硬盘的存储空间更大,访问速度更慢,成本更低,可以实现持久化存储,而操作系统通过&quo…

Polkadot 安全机制揭秘:保障多链生态的互操作性与安全性

作者&#xff1a;Filippo Franchini&#xff0c;Web3 Foundation 原文&#xff1a;https://x.com/filippoweb3/status/1806318265536242146 编译&#xff1a;OneBlock Polkadot 是一个创新的多链区块链平台&#xff0c;旨在实现不同区块链之间的互操作性和共享安全性。本文将详…

c++习题02-浮点数求余

目录 一&#xff0c;问题 二&#xff0c;思路 三&#xff0c;代码 一&#xff0c;问题 二&#xff0c;思路 虽然在浮点类型中没有取余的运算&#xff08;无法直接使用%符号取余&#xff09;&#xff0c;但是我们都知道在数学中&#xff0c;除法是减法的连续运算&#xff…

软件测试最全面试题及答案整理(2024最新版)

1、你的测试职业发展是什么? 测试经验越多&#xff0c;测试能力越高。所以我的职业发展是需要时间积累的&#xff0c;一步步向着高级测试工程师奔去。而且我也有初步的职业规划&#xff0c;前3年积累测试经验&#xff0c;按如何做好测试工程师的要点去要求自己&#xff0c;不断…

师从IEEE fellow|博士后加拿大阿尔伯塔大学成行

V老师指定申请加拿大&#xff0c;优先对方出资的博士后&#xff0c;如果外方无资助&#xff0c;也可以自筹经费&#xff0c;但要求必须是博士后头衔。最终我们为其落实了加拿大阿尔伯塔大学的postdoctoral fellow&#xff08;博士后研究员&#xff09;&#xff0c;尽管是无薪职…

经典链表算法题:找到环的入口。清晰图示推导出来

Leetcode题目链接 原理 重画链表如下所示&#xff0c;线上有若干个节点。记蓝色慢指针为 slow&#xff0c;红色快指针为 fast。初始时 slow 和 fast 均在头节点处。 使 slow 和 fast 同时前进&#xff0c;fast 的速度是 slow 的两倍。当 slow 抵达环的入口处时&#xff0c;如…

前端播放RTSP视频流,使用FLV请求RTSP视频流播放(Vue项目,在Vue中使用插件flv.js请求RTSP视频流播放)

简述&#xff1a;在浏览器中请求 RTSP 视频流并进行播放时&#xff0c;直接使用原生的浏览器 API 是行不通的&#xff0c;因为它们不支持 RTSP 协议。为了解决这个问题&#xff0c;开发者通常会选择使用像 flv.js 这样的库&#xff0c;它专为在浏览器中播放 FLV 和其他流媒体格…

4款引以为豪的办公软件,使用起来,舒适度满满

Everything 是Windows神级搜索软件&#xff0c;能做到秒级响应。 Everything 之前小编在文章里提过好几次&#xff0c;但还有很多小伙伴不知道&#xff0c;那就再给大家种草一下哈。 只需要打开一次&#xff0c;Everything就会自动为你的文件建立索引&#xff0c;之后&#…

Spring MVC 中使用 RESTFul 编程风格

1. Spring MVC 中使用 RESTFul 编程风格 文章目录 1. Spring MVC 中使用 RESTFul 编程风格2. RESTFul 编程风格2.1 RESTFul 是什么2.2 RESTFul风格与传统方式对比 3. Spring MVC 中使用 RESTFul 编程风格(增删改查)的使用3.1 准备工作3.2 RESTFul 风格的 “查询” 所有&#xf…

概率论与数理统计_下_科学出版社

contents 前言第5章 大数定律与中心极限定理独立同分布中心极限定理 第6章 数理统计的基本概念6.1 总体与样本6.2 经验分布与频率直方图6.3 统计量6.4 正态总体抽样分布定理6.4.1 卡方分布、t 分布、F 分布6.4.2 正态总体抽样分布基本定理 第7章 参数估计7.1 点估计7.1.1 矩估计…

视频网关的作用

在数字化时代&#xff0c;视频通信已经成为了人们日常生活和工作中的重要部分。为了满足不同设备和平台之间的视频通信需求&#xff0c;各种视频协议应运而生。然而&#xff0c;这些协议之间的差异使得相互通信变得复杂。因此&#xff0c;视频网关作为一种重要的网络设备&#…

使用TensorRT进行加速推理(示例+代码)

目录 前言 一、TensorRT简介 1.1TensorRT 的主要特点 1.2TensorRT 的工作流程 二、具体示例 2.1代码 2.2代码结构 2.3打印结果 前言 TensorRT 是 NVIDIA 开发的一款高性能深度学习推理引擎&#xff0c;旨在优化神经网络模型并加速其在 NVIDIA GPU 上的推理性能。它支持…

告别写作难题,这些AI写作工具让你文思泉涌

在现实生活中&#xff0c;除了专业的文字工作者&#xff0c;各行各业都避免不了需要写一些东西&#xff0c;比如策划案、论文、公文、讲话稿、总结计划……等等。而随着科技的进步&#xff0c;数字化时代的深入发展&#xff0c;AI已经成为日常工作中必不可少的工具了&#xff0…

Django创建项目(1)

运行 注意 在本次创建Django项目时&#xff0c;出现了一点小问题&#xff0c;由于我之前pip换源过&#xff0c;换源用的是http&#xff0c;结果在创建时&#xff0c;pip只支持https&#xff0c;所以如果出现创建项目失败的问题&#xff0c;那么有可能是因为换源的问题&#xf…

electron-vue自定义标题

1.在主进程background.js或者main.js中主窗口配置frame: false async function createWindow() {Menu.setApplicationMenu(null);// Create the browser window.const win new BrowserWindow({width: 1000,height: 600,resizable: false,frame: false,webPreferences: {nodeI…

【CSS in Depth 2 精译】2.3 告别像素思维

当前内容所在位置 第一章 层叠、优先级与继承第二章 相对单位 2.1 相对单位的威力 2.1.1 响应式设计的兴起 2.2 em 与 rem 2.2.1 使用 em 定义字号2.2.2 使用 rem 设置字号 2.3 告别像素思维 ✔️2.4 视口的相对单位2.5 无单位的数值与行高2.6 自定义属性2.7 本章小结 2.3 告别…