java封装是什么意思,JAVA封装

  • 单词什么意思
  • 2024-01-05

java封装是什么意思?Java封装是一种面向对象编程(OOP)的概念,指将数据和行为组合成一个黑盒子,对外展现出有限的接口和方法,同时隐藏了内部的实现细节。封装的主要目的是保证数据的安全性和完整性,防止意外的修改和不当的访问。那么,java封装是什么意思?一起来了解一下吧。

java面向对象的三大特征

什么是封装?

封装从字面上来理解就是包装的意思,专业点就是信息隐藏,是指利用抽象数据类型将数据和基于数据的操作封装在一起,使其构成一个不可分割的独立实体,数据被保护在抽象数据类型的内部,尽可能地隐藏内部的细节,只保留一些对外接口使之与外部发生联系。的其他对象只能通过包裹在数据外面的已经授权的操作来与这个封装的对象进行交流和交互。也就是说用户是无需知道对象内部的细节,但可以通过该对象对外提供的接口来访问该对象。

在现实世界当中我们可以看到很多事物都是封装好的,比如“鼠标”,外部有一个壳,将内部的原件封装起来,至于鼠标内部的细节是什么,我们不需要关心,只需要知道鼠标对外提供了左键、右键、滚动滑轮这三个简单的操作。对于用户来说只要知道左键、右键、滚动滑轮都能完成什么功能就行了。为什么鼠标内部的原件要在外部包装一个“壳”呢,起码内部的原件是安全的,不是吗。

再如“数码相机”,外部也有一个壳,将内部复杂的结构包装起来,对外提供简单的按键,这样每个人都可以很快的学会照相了,因为它的按键很简单,另外照相机内部精密的原件也受到了壳儿的保护,不容易坏掉。

面向对象的三个特性:

1、封装

2、继承

3、多态

根据以上的描述,可以得出封装有什么好处呢?

封装之后就形成了独立实体,独立实体可以在不同的环境中重复使用,显然封装可以降低程序的耦合度,提高程序的扩展性,以及重用性或复用性,例如“鼠标”可以在A电脑上使用,也可以在B电脑上使用。

简述java中类和对象的关系

封装指的是将对象的状态信息(属性)和行为(方法)捆绑为一个逻辑单元的机制。

Java中通过将数据封装、声明为私有的(private),再提供一个或多个公开的(public)方法实现对该属性的操作,以实现下述目的:

隐藏一个类的实现细节;

防止对封装数据的未经授权的访问。使用者只能通过事先定制好的方法来访问数据,可以方便地加入控制逻辑,限制对属性的不合理操作;

有利于保证数据的完整性;

便于修改,增强代码的可维护性.

java封装的好处

封装:

类的封装性即不能让外面的类随意修改一个类的成员变量;

在定义一个类的成员(包括变量和方法),使用private关键字说明这个成员的访问权限,只能被这个类的其他成员方法调用,而不能被其他的类中的方法所调用;

为实现封装性,常将类的成员变量声明为private,再通过public的方法来对这个变量进行访问。对一个变量的操作,一般都有 读取和赋值操作,我们一般定义两个方法来实现这两种操作,即:getXxx()与setXxx();

一个类就是一个模块,我们应该让模块仅仅公开必须要让外界知道的内容,而隐藏其他的一切内容。再进行程序设计时,应尽量避免一个模块直接修改或操作另一个模块的数据,模块设计追求强内聚(许多功能尽量在类的内部独立完成,不让外面干预),弱耦合(提供给外部尽量少的方法调用)。

正确理解封装:

正确地封装Java类

一个设计良好的工程是由一些能够正确执行中定义好的独立任务的Java成员函数组成,这样的工程具有很好的扩展性。相反,那些功能混乱定义不一的函数,在重载或另一环境调用的过程中会容易发生冲突。

在Java的封装功能中,我提出了与Java封装概念相称的启发概念。

java如何实现封装

前面有private 修饰的【属性】或者是【方法】,不能【直接】被外部类的实例化对象访问,这样就是封装。

像属性或者方法用private 修饰之后 不能直接访问。

class Person{

private String name; // 属性被封装

//getset 方法可以

//public 修饰的方法可以

public String printName(){//【自定义的方法】

return name;

}

}

现这种一般如果name的属性是public,new Person().name 这样就可以直接访问。

现在如果想要访问的话new Person().name是错误的,因为name被封装,不能直接的访问了。

要通过它里面的其他的方法访问,new Person().printName();【getset 方法可以访问,其他的public修饰的方法也可以】

java中的多态是什么意思

关于这个问题,我想举一个例子:

lz如果你接触过老的面向过程的编程,

以前封装性很差的程序是这样的

比如用C写一套处理链表的程序,他的数据和函数是分开的

数据保存在一个内存区域里,所有相关的函数,比如增加节点啊,减少节点什么的都是直接操作这个内存区域的指针

比如这样

LIST *p=.....;//开辟空间

AddNode(p,...)//这样来操作

带来了很多额外的不安全因素,因为谁都可以操作这个指针

如果你写的是一个第三方库,那么别人使用的时候完全不在你的控制之下

现在的面向对象程序则不然,

将数据和与之对应的操作(也就是方法)绑定在一个块中

比如在Java中

LinkedList list=new LinkedList();

list.add(...);

这样所有的内部结构对于外部用户都是透明的,不用管内部实现和结构,如何储存数据,都不用管内部实现(一些数据程序成员的访问权限是private protected就是为了数据安全性)

而原先的方式,数据是非封装的,因为外部程序可以随便更改数据,不利于程序的安全运行

以上提到的就属于面向对象封装性的意义,不过实际的好处还不只这些

lz有问题,欢迎给我发消息,我们可以具体讨论一下

以上就是java封装是什么意思的全部内容,java中的封装:将对象的属性和行为隐藏起来,只提供一个接口,用户只要通过对接口的访问,就可以实现自己想要的操作。封装就好像是:微波炉有加热包子的这个方法,你想加热肉包子(“方法”),你只需要将包子放进微波炉里。

猜你喜欢