- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Java String类字符串的理解与认知由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
在java中,和C语言一样,也有关于字符串的定义,并且有他自己特有的功能,下面我们 。
一起来学习一下.
string在软件包java.lang下,所以不需要导包.
String字符串是java中的重点,String 类表示字符串类 ,所有的字符串(如"adf")都属于 。
此类,也就是说有" "双引号括起来的都属于此类, 。
字符串不可变,他们的值在创建之后不能被改变.
虽然String的值的不可变的,但是他们可以被共享。共享就是其他成员也可以拥有这个值, 。
字符串效果相当于数组(char[]),但是底层原理是字节数组(byte[]) 。
jdk8以前是字符数组,jdk9以后是字节数组.
public String() //创建一个空白字符串对象,不含有任何内容.
public String(char[] ch)//根据字符数组的内容来创建字符对象.
public String (byte[] b)//根据字节数组的内容来创建字节对象.
String s=“abc” //字节赋值的方式创建对象,内容就是abc.
public class StringDemo { public static void main(String[] args) { String s1=new String();//创建空的字符串,其中不包括任何内容 System.out.println("s1:"+s1); char[]chs={"a","b","c"}; String s2=new String(chs);//给chs创建对象 System.out.println("chs:"+s2);//输出ch:abc byte[]bys={97,98,99}; String s3=new String(bys); System.out.println("bys:"+s3);//输出bys:abc,他会 转化成对应的Ascll码值 String s4="abc"; System.out.println("s4:"+s4);//输出s4:abc }}
综上看,推荐使用直接赋值的方式得到字符串对象.
通过new创建的的字符串对象,每一次new都会申请一个内存空间,虽然内容一样, 。
但是地址不同 。
通过直接赋值的方式来创建对象,赋值相同的值,因为是常量在堆内存的常量池中, 。
进入常量池的规则是:如果常量池中没有这个常量,则在常量池中创建一个,如果有 。
,则把已经存在的常量地址赋值给他,所以创建不同的变量去接受相同的值,他的内容 。
是一样的,地址也是一样的 .
我们在比较两个数字是否相同时,一般用的是==来判断,那么要比较两个字符串相等 。
用的是什么呢,答案是用equls.
==用来判断两个字符串的地址是否相同,相同返回true,不同返回false.
equls用来比较两个字符串的值是否相同,相同返回true,不同返回false.
public class String1 { public static void main(String[] args) { String s1="hello"; String s2="world"; String s3= "helloworld"; String s4=s1+s2; System.out.println(s7==s8);//0 System.out.println(s3==s4);//比较两个字符串的地址是否相同 System.out.println(s3.equals(s4));//比较两个字符串中的值是否相同 }}
原因下文分析.
在字符串中,两个字符串相加可以的到一个新的字符串,这是我们知道的,但是地址会是一样的吗 。
看下列代码:
public class String1 { public static void main(String[] args) { String s1="hello"; String s2="world"; String s3= "helloworld"; String s4=s1+s2; String s5="he"+"llo"; String s6="hello"+"world"; String s7="hello"+s2; String s8=s1+"world"; System.out.println(s3==s6);//比较两个地址是否相同 System.out.println(s1==s5); System.out.println(s3==s7); System.out.println(s3==s8); System.out.println(s7==s8); System.out.println(s3==s4); System.out.println(s3.equals(s4));//比较两个字符串中的值是否相同 }}
我们仔细分析:
第一个:
String s3= "helloworld"; String s6="hello"+"world";
s3首先在常量池中创建了一个helloworld的常量,s6是有两个新的字符串连接起来的, 。
这两个字符串常量创建新的字符串常量,存储在常量池中时,因为helloworld已经存在, 。
所以常量池就不会创建新的字符串了,直接把已经存在的s3地址赋值给s6,所以他们地址 。
相同.
第二个:
String s1="hello"; String s5="he"+"llo";
这个分析和第一个一样,地址相同.
第三个:
String s2="world";String s3= "helloworld";String s7="hello"+s2;
s2在常量池中创建world,s3在常量池中创建helloworld,s7是由一个变量s2连接一 。
个新的字符串"world",首先会在常量池创建字符串"world",然后两者之间进行"+" 。
操作,根据字符串的串联规则,s7会在堆内存中创建StringBuilder(或StringBuffer) 。
对象,通过append方法拼接s2和字符串常量"world”,此时拼接成的字符串"helloworld" 。
是StringBuilder(或StringBuffer)类型的对象,通过调用toString方法转成String对 。
象"helloworld",所以s7此时实际指向的是堆内存中的"helloworld"对象,堆内存中对 。
象的地址和常量池中对象的地址不一样.
第四个:
String s1="hello";String s3= "helloworld";String s8=s1+"world";
解释同上,重新简单的说一下,s3在先在常量池中创建helloworld,s8是由变量s1和常量 。
world加起来的,会先在常量池中创建world,然他他们现在之后会在堆内存中存在,所以 。
他们的地址不同.
总结:一般带有变量的相加操作是在堆中创建的 。
第五个:
String s1="hello"; String s2="world"; String s7="hello"+s2; String s8=s1+"world";
解释和上面有些相似之处,他们都是有变量加常量,所以他们都是在堆内存中创建的, 。
堆内存的地址是不会相同的.
第六个:
String s1="hello"; String s2="world"; String s3= "helloworld"; String s4=s1+s2;
首先在常量池中创建唯一的常量,然后再,s4进行两个变量的相加操作,所生成的是在 。
堆内存中的,所以地址不同.
到此这篇关于Java String类字符串的理解与认知的文章就介绍到这了,更多相关Java String内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://blog.csdn.net/weixin_60719453/article/details/120746827 。
最后此篇关于Java String类字符串的理解与认知的文章就讲到这里了,如果你想了解更多关于Java String类字符串的理解与认知的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
如果您想使用 String.Concat() 连接 5 个或更多字符串,则它会使用 Concat(String[])。 为什么不一直使用 Concat(String[]) 而不再需要 Concat(S
今天在使用 String 时,我遇到了一种我以前不知道的行为。我无法理解内部发生的事情。 public String returnVal(){ return "5";
似乎在我所看到的任何地方,都有一些过时的版本,这些版本不再起作用。 我的问题似乎很简单。我有一个Java类,它映射到derby数据库。我正在使用注释,并且已经成功地在数据库中创建了所有其他表,但是在这
一、string::size_type() 在C++标准库类型 string ,在调用size函数求解string 对象时,返回值为size_type类型,一种类似于unsigned类型的int 数据
我正在尝试将数据保存到我的 plist 文件中,其中包含字符串数组的定义。我的plist - enter image description here 我将数据写入 plist 的代码是 -- let
我有一个带有键/值对的 JavaScript 对象,其中值是字符串数组: var errors = { "Message": ["Error #1", "Error #2"], "Em
例如,为了使用相同的函数迭代 List 和 List> ,我可以编写如下内容: import java.util.*; public class Test{ public static voi
第一个Dictionary就像 Dictionary ParentDict = new Dictionary(); ParentDict.Add("A_1", "1")
这是我的 jsp 文件: 我遇到了错误 The method replace(String, String, String) in the type Functions is not appl
我需要一些帮助。我有一个方法应该输出一个包含列表内容的 txt 文件(每行中的每个项目)。列表项是字符串数组。问题是,当我调用 string.Join 时,它返回文字字符串 "System.Strin
一位同事告诉我,使用以下方法: string url = "SomeURL"; string ext = "SomeExt"; string sub = "SomeSub"; string s
给定类: public class CategoryValuePair { String category; String value; } 还有一个方法: public
我正在尝试合并 Stream>>对象与所有 Streams 中的键一起映射到单个映射中. 例如, final Map someObject; final List>> list = someObjec
在这里使用 IDictionary 的值(value)是什么? 最佳答案 使用接口(interface)的值(value)始终相同:切换到另一个后端实现时,您不必更改客户端代码。 请考虑稍后分析您的代
我可以知道这两个字典声明之间的区别吗? var places = [String: String]() var places = [Dictionary()] 为什么当我尝试以这种方式附加声明时,只有
在 .NET 4.0 及更高版本中存在 string.IsNullOrWhiteSpace(string) 时,在检查字符串时使用 string.IsNullOrEmpty(string) 是否被视为
这个名字背后的原因是什么? SS64在 PowerShell 中解释此处的字符串如下: A here string is a single-quoted or double-quoted string
我打算离开 this 文章,尝试编写一个接受字符串和 &str 的函数,但我遇到了问题。我有以下功能: pub fn new(t_num: S) -> BigNum where S: Into {
我有一个结构为 [String: [String: String]] 的多维数组。我可以使用 for 循环到达 [String: String] 位,但我不知道如何访问主键(这个位 [String:
我正在尝试使用 sarama(管理员模式)创建主题。没有 ConfigEntries 工作正常。但我需要定义一些配置。 我设置了主题配置(这里发生了错误): tConfigs := map[s
我是一名优秀的程序员,十分优秀!