java记录一下字符串比较以及引申的设计模式缓冲区内容

本文主要是介绍java记录一下字符串比较以及引申的设计模式缓冲区内容,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

java简单记录一下字符串比较的相关

本文在 内容空("")和 引用空(null)以及 双等号(==)和 equals 方法上进行记录

1.内容空和引用空

① 顾名思义,内容空即为String本身地址中没有存放任何东西,即没有内容,但是String是实例化的,是有地址的

例如:String str=new String(""); 其中str是真正指向一个存放String的地址的,只不过这个地址存放的String是空的

② 很好理解,与之对应的就是引用空,即String声明的引用只是声明了,并没有实例化,也就是没有指向任何地址

例如:String str;这时候的str就是引用空,只是声明了一个引用,他并没有指向实际的一个地

 

2.双等号和equals

理解了上述的一个简单的前提,再来说明最基础的字符串判断

先来看一个例子:

        String str1=new String("abc");String str2=new String("abc");System.out.println(str1==str2);System.out.println(str1.equals(str2));

以上声明并实例化了两个String字符串,并使其内容均为"abc",然后对比两种比较的输出结果

很明显,结果说明了一切(这里浪漫小白也想对大家说,有什么问题弄不懂,直接上代码跑一下结果,然后分析)

①双等号判断返回值false,也就是两者不等,原因很简单,双等号判断的是地址是否一致(顺带着也就判断了内容,哈哈。滑稽,地址都一样,内容能不一样?),而两个实例化的str1和str2显然是分配的两个不同的地址空间来存放abc字符串

②这就简单的说明了,equals判断的其实才是抛开地址后的字符串内容的比较,也就是地址不同,但内容相同的匹配

所以在判断字符串是否内容匹配的时候要用equals

这里需要说明的是:此处的equals只是针对string类来说的,为什么呢?

原因很简单,equals本身是Object的方法,而其在object的方法定义中,其逻辑就是双等号,有兴趣可以直接找源码看一下。

所以说,默认的equals其实也是和双等号一样的逻辑判断,但是我们经常使用到的jdk所提供的类库中的大部分都是重写了equals的逻辑判断,将其改为了内容判断,比如上述中的string类。这也说明了我们经常直接使用java所提供的类库中的equals大部分都是对equals进行过重写的!

理解了上述,这里多记录一种情况,也很好理解

就是,当一个字符串引用为空的时候,即String str=null的时候,是不能够用equals的,这个细节每个人都懂,因为没有实例化不能使用非静态方法,但是,作者周围的朋友却经常会遇到这一类问题,就是实际编程过程中,在判断字符串是否为空的时候,经常就直接用str.equals(""),要知道你的str不一定是声明的时候就创建的,很可能来源于其他任何可以使用字符串引用的地方!这时候要留意一下你的str是否是空指针

以上的说明,很简单,很基础,却很频繁,然后说明一下设计模式缓冲区问题

java本身的关于字符串初始化时候缓冲区相关的解释说明

还是看例子,

public class Test {public static void main(String a[]){//String str1=new String("abc");//String str2=new String("abc");String str1="abc";String str2="abc";System.out.println(str1==str2);System.out.println(str1.equals(str2));}
}

然后看结果,

哎,这一看就看出了关键,这时候Str1 == Str2 返回值是 true,用我们刚才理解的双等号判断的含义,就知道了,此时str1和str2

的指针指向是一致的,就是说这两个引用的实际地址是一样的

那这本质的原因是什么呢?其实就是一种缓存区的设计模式。

java中直接声明的实际字符串"abc"是存在在常量池位置的,并且是唯一的,像例子中的一样,str1=“abc”的时候,这时候abc其实本身就是一个直接使用的字面量,只不过又让str1这个引用指向了他(这个字符串放在了常量区)。str2又等于“abc”的时候,其实也是指向的刚才的那个常量池中abc的位置!

换句话说,就类似于现在有了一个实际的String类型的str3,然后新声明String str1=str3,String str2=str3,那么str1和str2当然都是指向了一个地址(str3)了!但是所谓的不同就是,这里的str3 是实例化的String,他的地址就是String应该在的地址,而我们例子中直接使用的“abc”字符串是放在常量池中的。

而对比之前的例子String str=new String();这样的方式,就没有这个问题了,因为new关键字,就实例化了一个真正的String,有自己的地址空间(在堆中),然后把abc这个内容放进这个地址空间中。

总结来说,就是直接使用(字面量)的字符串形式是存放在一种缓冲区的模式(常量池)中的,且相同内容的存放是唯一的。

 

 

 

这篇关于java记录一下字符串比较以及引申的设计模式缓冲区内容的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/202159

相关文章

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操