热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

字段不显示继承_关于Java中的不可变性

点击上方蓝字关注?来源:蓝灰_qhttps:www.jianshu.comp78ee812fec13详解1场景在面向对象编程里,不变性是一个有点冷门的话

点击上方蓝字关注 ?

f0574a920516de8d5d29a74ebf1259fa.gif

来源:蓝灰_qhttps://www.jianshu.com/p/78ee812fec13

详解

1 场景

在面向对象编程里,不变性是一个有点冷门的话题,一般在考察String特性的面试题中比较常见,但其实不变性是一个非常有用的设计。例如:某个通用的配置对象,只在初始化时赋值一次,之后不能被修改,如何避免被同事调用和修改?某个为多线程同时提供数据的只读对象,如何确保只读,也就是避免被同事修改?...

2 分析

要在Java中实现不变性的对象,主要是确保它禁止修改,但完全写死的对象实用性很低,还是需要为对象赋值一次,这就可以分解为两个问题:

2.1 禁止修改

1-私有化方法和字段setter和public字段当然是禁止的,这样在普通语法层面上屏蔽修改入口。2-使用final字段final修饰符的直接作用是从编译器级别就锁死引用,引用不可变更,否则编译器会报错。final可以用于修饰类、方法和字段,分别作用如下:final类—禁止继承,把类锁死。final方法—禁止重写,在编译期即绑定具体方法。final字段—禁止修改,在类加载时即把final字段放进常量池。

所以,需要使用final字段,声明该字段为不可变。3-小心里式替换里式替换本身是六大设计原则之一,但是在不可变对象中,这是一个非常危险的性质,因为一个继承自基类的子类实例,可以轻松替换掉基类实例,从而破坏不可变性。

解决方法就是给类加上final修饰,禁止继承。4-杜绝变量逃逸/逸出变量逸出是一个很容易忽视的点,如果外部能够拿到内部字段的引用,或者在赋值时能够传入一个引用,就可以通过修改引用去修改内部字段,这也是不允许的。

解决方法就是,涉及外部引用或赋值时,一律使用深拷贝,如:

public String(char value[]) {     this.value = Arrays.copyOf(value, value.length); // 深拷贝赋值 }

2.2 赋值一次

不可变对象一般是需要赋值一次的,完全写死的不可变对象意味着扩展性很差,只能通过改代码来修改,不具备实用性。但是,采用了final修饰符的字段,只能在三种情况下得到值:1-常量;2-代码块;3-构造函数赋值;前两种情况其实就是代码写死的方式,所以我们只能在构造函数中实现赋值一次。

3 实现

根据上文分析,要实现不可变对象,需要做到以下几点:1.代码中禁用setter和public字段;2.使用final修饰类和字段;3.在构造函数中赋值,注意要使用深拷贝赋值;

经过这样的操作,就可以实现一个比较安全的不可变对象了。

4 漏洞

为什么说比较安全呢,因为还有一些漏洞可以破坏不可变性。1- 反射final字段虽然实现了不可变,但那是常规操作,如果使用反射,还是可以操作final字段的。不过,如果final字段在代码中定义为常量,就是安全的,因为编译器会优化getter函数,直接返回定义的这个常量,而不是final字段。当然,这种情况下,final字段就不能通过构造函数赋值了。2- 序列化如果不可变对象实现了序列化,通过反序列化也可以得到一个对象的拷贝。我们知道序列化可以破坏单例,因为他会创建一个新的内存对象及其引用。不过序列化对于不可变性还是比较友好的,因为反序列化得到的新内存对象与原始对象内容一致,在只读时没有不良影响。

—————END—————

0d6309d552308396923935879a99c515.png     

 
 创作不易,点个“
在看5d52450a3d7ce80dc965a31bc0f345cc.gif




推荐阅读
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • 本文探讨了C语言中指针的应用与价值,指针在C语言中具有灵活性和可变性,通过指针可以操作系统内存和控制外部I/O端口。文章介绍了指针变量和指针的指向变量的含义和用法,以及判断变量数据类型和指向变量或成员变量的类型的方法。还讨论了指针访问数组元素和下标法数组元素的等价关系,以及指针作为函数参数可以改变主调函数变量的值的特点。此外,文章还提到了指针在动态存储分配、链表创建和相关操作中的应用,以及类成员指针与外部变量的区分方法。通过本文的阐述,读者可以更好地理解和应用C语言中的指针。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • Java在运行已编译完成的类时,是通过java虚拟机来装载和执行的,java虚拟机通过操作系统命令JAVA_HOMEbinjava–option来启 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • 本文讨论了在手机移动端如何使用HTML5和JavaScript实现视频上传并压缩视频质量,或者降低手机摄像头拍摄质量的问题。作者指出HTML5和JavaScript无法直接压缩视频,只能通过将视频传送到服务器端由后端进行压缩。对于控制相机拍摄质量,只有使用JAVA编写Android客户端才能实现压缩。此外,作者还解释了在交作业时使用zip格式压缩包导致CSS文件和图片音乐丢失的原因,并提供了解决方法。最后,作者还介绍了一个用于处理图片的类,可以实现图片剪裁处理和生成缩略图的功能。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • Java和JavaScript是什么关系?java跟javaScript都是编程语言,只是java跟javaScript没有什么太大关系,一个是脚本语言(前端语言),一个是面向对象 ... [详细]
  • 深入理解Java虚拟机的并发编程与性能优化
    本文主要介绍了Java内存模型与线程的相关概念,探讨了并发编程在服务端应用中的重要性。同时,介绍了Java语言和虚拟机提供的工具,帮助开发人员处理并发方面的问题,提高程序的并发能力和性能优化。文章指出,充分利用计算机处理器的能力和协调线程之间的并发操作是提高服务端程序性能的关键。 ... [详细]
  • linux进阶50——无锁CAS
    1.概念比较并交换(compareandswap,CAS),是原⼦操作的⼀种,可⽤于在多线程编程中实现不被打断的数据交换操作࿰ ... [详细]
  • 预备知识可参考我整理的博客Windows编程之线程:https:www.cnblogs.comZhuSenlinp16662075.htmlWindows编程之线程同步:https ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • Apache Shiro 身份验证绕过漏洞 (CVE202011989) 详细解析及防范措施
    本文详细解析了Apache Shiro 身份验证绕过漏洞 (CVE202011989) 的原理和影响,并提供了相应的防范措施。Apache Shiro 是一个强大且易用的Java安全框架,常用于执行身份验证、授权、密码和会话管理。在Apache Shiro 1.5.3之前的版本中,与Spring控制器一起使用时,存在特制请求可能导致身份验证绕过的漏洞。本文还介绍了该漏洞的具体细节,并给出了防范该漏洞的建议措施。 ... [详细]
author-avatar
作祟椰
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有