Java之封装与访问权限控制(一)

对于封装的概念,我总觉得自己还是挺了解的,但是真要我说,还真说不出个啥来。我只能默默地通过身边的例子加上书本理论完善我对封装的认识。

就比如,我们在玩游戏的时候,我们只能通过完成指定任务获得金币,并不能直接修改金币的值,作为玩家的我们,如果轻易就能修改机密,那岂不是乱套啦。设计者明显不想让我们这么做,他们允许我们享受游戏,但是这些禁忌碰不得。这就是封装的一个例子。

封装的概念

封装是面向对象三大特征之一。

将对象的状态信息隐藏再对象内部,不允许外部程序直接访问对象内部信息,而是通过该类所提供的方法对内部信息进行操作和访问。

优点

  • 隐藏类的实现细节。
  • 使用者只能通过预定的方法访问数据,可以控制方法逻辑,限制不合理访问。
  • 可进行数据检查,利于保证对象信息的完整性。
  • 便于修改,提高代码的可维护性。

需要考虑

  • 将对象的成员变量和实现细节隐藏起来,不允许外部直接访问。
  • 把方法暴露出来,让方法来控制对这些成员变量进行安全的访问操作。

将该隐藏的隐藏起来,将该暴露的暴露出来。

访问控制符

控制级别

public > protected >缺省> private

访问控制级别表

private default protected public
同一个类中
同一个包中
子类中
全局范围内

private(当前类访问权限):被修饰的成员只能在该类的内部被访问。

缺省(包访问权限) :缺省就是没有任何修饰符所修饰,缺省的成员可以被同一个包中的其他类所访问,关于包的概念,之后再提。

protected(子类访问权限) :被修饰的成员既可以被同一个包中的其他类访问,也可以被不同包中的子类所访问。关于子类和父类之后将会总结~

public(公共访问权限) :被修饰的成员可以被其他所有类访问,不论是否在同一包,不论是否具有继承关系。

注意

  • 外部类只能由public或缺省两种修饰方式,其他两个修饰没啥太大意义。

  • Java源文件的命名问题:

    • 定义的所有类中没有用public修饰,文件名随意取,合法就行,但不建议这样。
    • 如果定义了public修饰的类,文件名必须与public修饰的类类名相同,所以一个java源文件中只能有一个public修饰的类。
  • private用来修饰成员变量非常合适,可以很好实现隐藏和封装的目的。

  • 通常来说,用protected修饰一个方法,是希望子类来重写这个方法。

属性私有化

先来看看我们原先写过的简单的类及测试:

package com.my.pac08;

public class People {
public static void main(String[] args) {
Man man = new Man();
man.age = -4;
man.name = "12345";
man.run();
}
} class Man {
int age;
String name; void run() {
System.out.println("running..");
}
}
  • 一切都是那么普通,可以不加修饰符的地方都没有加。
  • 我们还是普通地创建了对象,普通地通过对象访问其属性。
  • 但是这样子会产生一个很明显的问题:要是和上面一样,赋上很离谱的值,就会产生同样离谱的结果
  • 于是我们采用了以下的解决办法。
package com.my.pac07;

public class Person {
//private 修饰符对成员变量 进行隐藏
private String name;
private int age; public String getName() {
return name;
} public void setName(String name) {
if (name.length() > 5) {
System.out.println(name+"的长度太长,取名失败!");
return;
}
System.out.println("取名成功!");
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
if (age < 0) {
System.out.println("输入年龄不合法!");
return;
}
this.age = age;
}
}
  • 将name和age两个实例变量用private修饰。
  • 加上与之匹配的一组方法,setter与getter方法用来设置与获取属性。
  • 在设置方法处,加入了逻辑判断,限制非法或无效赋值。
package com.my.pac07;

public class PersonTest {
public static void main(String[] args) {
Person p = new Person(); /*private修饰属性,不在同一个类中无法直接访问,需要
使用对应的getter和setter方法。
错误 p.name = 5;
错误 p.age = 10;
*/ //名字长度超过限制,通过加入逻辑控制输入
p.setName("Longname"); System.out.println(p.getName());
//赋符合标准的名字
p.setName("Dady"); System.out.println("p的名字是:"+p.getName());
//年龄超出限制,不能小于0
p.setAge(-4); System.out.println(p.getAge());
//赋正常年龄值
p.setAge(10); System.out.println("p的年龄是:"+p.getAge());
}
}
  • 无法再用对象.属性的方式直接访问。
  • 需要通过setter方法设置合理值,用getter方法获取值。
  • 两个方法的形式:set+首字母大写的属性,例如setName。getter方法同理。

以上简单的例子,就是私有化属性,隐藏需要隐藏的,并提供可以访问属性的方法,展示需要展示的,这就是封装性的体现之一。

链接下篇:Java之封装与访问权限控制(二)

Java之封装与访问权限控制(一)的更多相关文章

  1. Java之封装与访问权限控制(二)

    目录 Java之封装与访问权限控制(二) 包:库单元 import import static Java常用包 Java之封装与访问权限控制(二) 访问权限控制是具体实现的隐藏,是封装性的一部分体现. ...

  2. Java编程思想之六访问权限控制

    访问控制(或隐藏具体实现)与"最初的实现并不恰当"有关. 访问权限控制的等级,从最大权限到最小权限依次为:public,protected,包访问权限(没有关键字)和private ...

  3. java基础-类成员访问权限控制

    一 前言 这篇文章是很基础的一文,没多大深度,对于开发人员必然是熟练于心.本篇文章的主题是为什么java要设置类成员访问级别?其原因也很简单,就是为了面向对象的封装特性:将类成员使用不同的访问级别控制 ...

  4. 初读"Thinking in Java"读书笔记之第六章 --- 访问权限控制

    包:库单元 包内包含有一组类,他们在单一的名字空间下被组织在一起. 通过import ***.***.*可以将某个包下的所有类导入到当前文件中. 每个Java源文件最多只能有一个public类,且名称 ...

  5. (转)浅析Java中的访问权限控制

    原文地址: http://www.cnblogs.com/dolphin0520/p/3734915.html 今天我们来一起了解一下Java语言中的访问权限控制.在讨论访问权限控制之前,先来讨论一下 ...

  6. 浅析Java中的访问权限控制

    浅析Java中的访问权限控制 今天我们来一起了解一下Java语言中的访问权限控制.在讨论访问权限控制之前,先来讨论一下为何需要访问权限控制.考虑两个场景: 场景1:工程师A编写了一个类ClassA,但 ...

  7. JAVA笔记 -- 访问权限控制

    访问权限控制 没有权限控制的时候,由于所有的接口都是可以访问的.当一个类库部分代码,发现有更好的方法解决的时候,可能其他接口会发生改动.这会导致另一个地方的引用该类库的程序发生崩溃.为了解决这种问题, ...

  8. Java访问权限控制

    访问权限控制           java提供了访问权限修饰词,以供类库开发人员向客户端程序员指明哪些是可用的,哪些是不可用的.访问权限控制的等级,从最大权限到最小权限依次是:public.prote ...

  9. Java之路(五) 访问权限控制

    在Java中,所有事物都具有某种形式的访问权限控制. 访问权限的控制等级从最大到最小依次为:public,protected,包访问权限(无关键词)和private. public,protected ...

随机推荐

  1. VisualStudio2012编辑器错误

    https://blogs.msdn.microsoft.com/webdev/2014/11/11/dialog-box-may-be-displayed-to-users-when-opening ...

  2. Shell入门01-bash Shell特性

    命令和文件自动补齐 [root@hadoop04 ~]# yum -y install bash-completion 命令历史记忆功能 1.上下键 查看历史命令 2.!number 执行histor ...

  3. idea object is not a member of package

    可能的原因: 1. pom.xml 依赖的工程没有deploy, 所有需要本地install改工程 2. 工程以来的库没有加入到 pom.xml中 3. 以上都没有问题,则右键该工程 => ma ...

  4. Reveal分析工具的使用

    首先:在reveal官网http://revealapp.com/下载适用版本.试用版本是30天免费,可以选择破解.破解链接http://pan.baidu.com/s/1bnc5wwn?errno= ...

  5. imageView的使用

    转自:http://www.runoob.com/ios/att-ios-ui-imageview.html 图像视图用于显示单个图像或动画序列的图像. 重要的属性 image highlighted ...

  6. Java修炼——内部类详解

    内部类详解 定义:将一个类定义在另一个类的内部,该类就称为内部类 类中定义的内部类特点: 内部类作为外部类的成员,可以直接访问外部类的成员 (包括 private 成员),反之则不行. 内部类做为外部 ...

  7. Cannot forward after response has been committed问题的解决

    Cannot forward after response has been committed问题解决及分析 通过TOMCAT把系统启动,可以正常登陆门户,登陆进去选择子系统的时候点击登陆的时候,可 ...

  8. [TimLinux] JavaScript input框的onfocus/onblur/oninput/onchange事件介绍

    1. onfocus事件 input框获取到焦点时,触发了该事件,比如获取到焦点时,修改input框的背景色.这个功能其实可以使用css的伪类:focus来定义. 2. onblur事件 这个与onf ...

  9. BZOJ2809 dispatching(左偏树)

    在一个忍者的帮派里,一些忍者们被选中派遣给顾客,然后依据自己的工作获取报偿.在这个帮派里,有一名忍者被称之为 Master.除了 Master以外,每名忍者都有且仅有一个上级.为保密,同时增强忍者们的 ...

  10. MySQL面试总结

    MySQL面试总结 # MySQL的存储引擎 `MyISAM`(默认表类型):非事务的存储引擎,基于传统的`ISAM`(有索引的顺序访问方法)类型,是存储记录和文件的标准方法,不是事务安全,不支持外键 ...