linkin大话面向对象--封装和隐藏
- 软件开发追求的境界:高内聚,低耦合
高内聚:尽可能把模块的内部数据,功能实现细节隐藏在模块内部独立完成,不允许外部直接干预
低耦合:仅暴露少量的方法给外部使用
- 到底为什么要对一个雷或者对象实现良好的封装,可以实现以下目的:
1,隐藏类的实现细节
2,让使用者只能通过实现预定的方法来访问数据,从而可以在该方法里加入控制逻辑,限制对属性的不合理访问
3,还可以进行数据检查,有利于保证对象信息的完整性
4,便于修改,提高代码的可维护性
- 为了实现良好的封装,需要从2个方面来考虑
1,把对象的属性和实现细节隐藏起来,不允许外部直接访问
2,把方法暴露出来,让方法来控制对这些属性进行安全的访问和操作
去餐馆吃饭,我们只要能吃到菜就OK了,至于这个厨师长啥样,单眼皮还是双眼皮,怎么做的菜,用了什么牌子的地沟油,我们都没必要知道。我们使用的电脑其实就是体现了封装的思想,它里面什么网卡,声卡是怎么插放的,怎么设计的,我们不要知道,我们只需打开电脑就可以用了。这就如同找一个人来修电脑,只需要知道修好了还是没修好。至于他怎么修的可以不用了解。可是封装好了,外界怎么使用呢?(向外暴露一些简单的入口,供使用)
方法是类中最小的封装体。那么类也一样是一种封装形式,有写方法需要暴露出去,有些就不用。
- 访问权限控制:
private:本类内部可以访问,不能继承到子类
default:本类内部可以访问,同包其他类也可以访问。同包可继承
protected:本类内部可以访问,不同包的子类也可以访问,同包其他类也可以访问。能继承到子类
public:任何地方都可以访问 ,能继承到子类
以下图片整理的很好:
|
修饰符 |
类内部 |
同一个包 |
子类 |
任何地方 |
|
private |
√ |
|||
|
default |
√ |
√ |
||
|
protected |
√ |
√ |
√ |
|
|
public |
√ |
√ |
√ |
√ |
- 关于访问控制符的使用,存在以下原则:
1,类中的绝大部门属性都应该使用private修饰,只有一些static修饰的,类似全局变量的属性,才使用public
2,如果某个类主要用作其他类的父类,那么应该使用protected来修饰这个类的方法
3,希望暴露给其他类调用的方法使用public来修饰
注意了:如果一个java源文件里定义了一个public修饰的类,则这个源文件的文件名必须与public修饰的类的类名相同
- JavaBean规范:
一个类必须有一个参数为空的构造方法,所有的字段必须使用private修饰;并向外提供getter/setter。
若字段的第二个字母是小写的,把第一个字母变成大的,再加上get/set作为前缀(最常见的)。
若第二个字母是大写的,就保持原样再加上get/set(特殊)。
注意了:boolean 类型的变量没有getXX,只有 isXX;
以下是一个标准的javabean,代码如下:
/**
*
* @version 1L
* @author LinkinPark
* @since 2014-10-27
* @motto 梦似烟花心似水,同学少年不言情
* @desc ^封装实际上就是2个方面的含义:把该隐藏的隐藏起来,把该暴露的暴露出来
*/
public class JavaBean {
//使用private修饰,将这些属性隐藏起来,要是想修改这个类的属性,提供get和set方法
private String name;
private int age; public JavaBean(){ } public String getName() {
return name;
} public void setName(String name) {
//在这里还可以加入自己的逻辑判断
if("LinkinPark".equals(name)){
System.out.println("不可以的,林肯公园是偶的名字,不能随便拿来赋值");
return;
}else{
this.name = name;
}
} public int getAge() {
return age;
} public void setAge(int age) {
//保证自己写的类的属性不要出现与实际情况不符的情况
if(age>100 || age<0){
System.out.println("");
}else{
this.age = age;
}
} }
linkin大话面向对象--封装和隐藏的更多相关文章
- linkin大话面向对象--内部类
内部类说白了就是类中有类 内部类:嵌套类 外部类:宿主类 内部类主要有以下作用:记住了3个字:多继承... 1,内部类提供了更好的封装,可以把内部类隐藏在外部类中,不允许同一个包中的其他类访问该类. ...
- linkin大话面向对象--组合
继承是实现类重用的重要手段,但是它有一个最大的坏处:破坏封装.相比之下,组合也是实现类重用的重要方式,但是采用组合方式实现类重用则能提供更好的封装性.比如人有手一样,在人的类中增加一个手的属性. 何时 ...
- linkin大话面向对象--类和对象
我们每天在撸码,那么我们在敲什么东西呢?明显的我们在写类,写一个类,写一个接口,写某个接口里面写一些属性,在某个类里面写一个方法,然后以一个对象调用方法,对于j2ee来讲的话,可能还会写一些jsp,静 ...
- linkin大话面向对象--闭包和回调
先来理解2个概念:闭包和回调 什么是闭包? 闭包是一个可调用的对象,它记录了一些信息,这些信息来自于创建他的作用域.通过这个定义,可以看出内部类是面向对象的闭包,因为他不仅包含了外部类对象的信 ...
- linkin大话面向对象--多态
java引用变量有2个类型,一个是编译时类型,一个是运行时类型: 编译时类型:声明的类型,把它看做是什么东西 运行时类型:真正的类型,实际上指的是什么东西 如果编译时类型和运行时类型不同,就出现多态. ...
- linkin大话面向对象--继承
[修饰符] class SubClass extends SuperClass 按照这种关系,我们把SuperClass类称为父类或基类,把SubClass称为子类或派生类或拓展类.extend ...
- linkin大话面向对象--构造器详解
对象的产生格式:类名称 对象名 = new 类名称(); 因为有(),所以是方法,实际上它就是构造方法,并且是非私有的构造方法.如:CellPhone cp = new CellPhone( ...
- linkin大话面向对象--GC和jar包
GC java的垃圾回机制是java语言的重要机制之一.当程序创建对象,数组等引用类型实体时,系统都会在堆内存中为之分配一块内存区,对象就保存在这块内存区中.当这块内存不再被任何变量引用时,这块内存就 ...
- linkin大话面向对象--枚举
枚举类(enum) 其实我们使用到枚举的地方还是很多的,其实我们可以完全人工的来实现枚举的功能.比如说我现在手里的项目我就是自己实现的枚举,说白了,枚举就是一个类的多例模式. 1,使用enum声明,默 ...
随机推荐
- 跟我一起读postgresql源码(九)——Executor(查询执行模块之——Scan节点(上))
从前面介绍的可优化语句处理相关的背景知识.实现思想和执行流程,不难发现可优化语句执行的核心内容是对于各种计划节点的处理,由于使用了节点表示.递归调用.统一接口等设计,计划节点的功能相对独立.代码总体流 ...
- CentOS环境下tomcat启动超级慢的解决方案
在本地开发环境,应用正常启动. 在CentOS测试环境,应用启动速度也是正常的. 但是在阿里云的生产环境,tomcat启动超级慢,并且在最终打印出来以下内容: org.apache.catalina. ...
- shader程序员需要注意的优化Tips
在写shader的时候,其实一些写法对于其执行影响非常大,而且由于gpu和cpu在架构上的不同,代码的优化思想也不一样,最近一直在写几个shader,为了性能问题,查阅了很多资料,把一些tips总结下 ...
- 一次完整的http的请求过程
一个完整的http的完成请求过程: 输入网址-> 域名解析-> tcp的三次握手-> 建立tcp连接后发起http 请求-> 服务器响应http ,发送数据给浏览器-> ...
- web前端教程:CSS 布局十八般武艺都在这里了
CSS布局 布局是CSS中一个重要部分,本文总结了CSS布局中的常用技巧,包括常用的水平居中.垂直居中方法,以及单列布局.多列布局的多种实现方式(包括传统的盒模型布局和比较新的flex布局实现), ...
- C++拷贝构造函数(深拷贝与浅拷贝)
转自http://blog.csdn.net/lwbeyond/article/details/6202256/ 一. 什么是拷贝构造函数 对于普通类型的对象来说,它们之间的复制是很简单的,例如:in ...
- 使用jemeter手工编写注册、登陆脚本 运用 fiddler (三)
手工注册脚本的录制 我们可以发现 编写手工脚本 需要用到两个软件一起合作才能编写成功 工作亦是如此 养成良好的团队合作精神 是必不可少的 现在我们来看手工编写注册脚本 第一步 :我们先进入网站首页 ...
- HihoCoder 1325 平衡树·Treap
HihoCoder 1325 平衡树·Treap 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho:小Hi,我发现我们以前讲过的两个数据结构特别相似. 小Hi:你说 ...
- AtCoder Grand Contest 013
这场打得蛮菜的,很晚才出BC,还一堆罚时…… A - Sorted Arrays 题目大意:将给定数列划分成单调不增或单调不减的区间,求最少区间数. 贪心即可. #include<cstdio& ...
- poj 3294
Life Forms Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 12688 Accepted: 3552 Descr ...