【JavaSE】String类

【JavaSE】String类,第1张

在C语言中,如果要表示字符串而且对字符串进行 *** 作的话,依靠的是数组和指针,而Java中提供了String类用来专门表示字符串,String类中常见的方法,以及一些细节是本篇重点

目录

1.定义字符串

2.字符串的存储

3.String中常用的方法

3.1字符串的比较

3.2查找字符串

3.3转换字符串

4.StringBuilder和StringBuffer

5.常量池


1.定义字符串

字符串常见的构造方式如下:

String s1 = "with";


String s2 = new String("with");


char[] array = {'w','i','t','h'};
String s3 = new String(array);
2.字符串的存储

由于String是引用类型,所以变量存储的并不是字符串本身,而是地址

我们首先来看看String的源码

可以看到:String类中只有两个成员变量,其中value是字符数组,所以定义的字符串是由value数组进行接收的,据此可大致推出字符串的存储,如下图:

3.String中常用的方法 3.1字符串的比较

equals(Object anObject)

比较字符串内容是否相同,返回值为布尔值

equalsIgnoreCase(Object anObject)

功能同equals(),不同的是此方法忽略字母的大小写

compareTo(String s)

比较字符串内容,返回值为int

compareToIgnoreCase(String str)

同compareTo(),忽略字母大小写
3.2查找字符串
charAt(int index)返回下标为index处的字符,index越界会抛出异常
int indexOf(int ch)此方法是重载方法,有多个结构,功能是返回变量ch第一次在字符串中出现的位置,没有的话返回-1
int indexOf(int ch,int fromlndex)从fromlndex位置开始向后找ch第一次出现的位置
int lastIndexOf(int ch)同样是重载方法,从字符串末尾开始往前面找ch第一次出现的位置,没有返回-1,和index一样也有fromlndex参数
3.3转换字符串
String valueOf(int i)

将数字转换为字符串,这是个重载方法

字符串转数字的方法有parseInt()、parseDouble()等,不过不在String类中,在各自的包装类里面

String toUpperCase()

小写字母转换为大写

大写转小写的方法为 toLowerCase()

char[] toCharArray()字符串转为字符数组
String format()创建格式化的字符串
String replaceAll(String regex,String replacement)

替换字符串中所有的指定内容

替换字符使用的是replace,返回值也是String

String replaceFirst(String regex,String replacement)替换字符串首个指定内容
String[] split(String regex)重载方法,将字符串按照指定格式进行拆分,可指定拆分成多少组
String substring(int beginIndex)重载方法,截取字符串内容,可以指定结尾的位置,取值范围是左开右闭
String trim()去掉字符串的左右空格

字符串拆分需要有几点注意:

  1. 如果要按照“|”、“*”、“+”拆分,字符前需要加上转义字符“\”
  2. 如果是“\”,则需要写成“\\”
  3. 字符串有多个分隔符,可以使用“|”作为连字符

特别说明:

Java中字符串是不可变的,所有的对字符串本身的 *** 作都会产生新的对象

至于字符串为什么不可变

因为String源码中value数组被private和final修饰,final修饰,数组的指向对象不可变,private修饰,在类外就无法访问,而且String中没有提供getValue和setValue方法

4.StringBuilder和StringBuffer

因为String *** 作字符串会产生新的对象,所以Java中提供了这两个类,这两个类的大部分功能都是类似的,String、StringBuilder、StringBuffer之间的区别如下:

  1. String内容不可变,StringBuilder和StringBuffer内容可变
  2. StringBuffer采用同步处理,属于线程安全 *** 作,StringBuilder则不是

这里列出一些常用的方法:

StringBuffer deleteCharAt(int index)

删除index位置字符

StringBuffer delete(int start, int end)

删除[start, end)区间内的字符

StringBuffer replace(int start, int end,String str)

将[start, end)位置的字符替换为str

String substring(int start)

从start开始一直到末尾的字符以String的方式返回

String substring(int start,int end)

将[start, end)范围内的字符以String的方式返回

StringBuffer reverse()

反转字符串

String toString()

将所有字符按照String的方式返回

5.常量池

为使程序运行的更快,同时也为了节省内存,Java为基本数据类型和String都提供了常量池,常量池的位置在堆中,这里只讨论字符串常量池

因为常量池的存在,所以会有如下的情况:

常量池本质是哈希表,原理这里暂时跳过,只说结论:

双引号引起来的元素都存放在常量池里面,有且仅有一份,所以在存放常量的时候,会先去常量池检查是否存在此常量,存在则直接给地址,不存在才会存放常量 

所以s1和s2是指向的常量池中的同一地址,而s3是实例化一个对象,这个对象指向的是常量池,但s3本身并没有指向常量池,大致的存储如下图:

 String类内容结束,完

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/733450.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-27
下一篇 2022-04-27

发表评论

登录后才能评论

评论列表(0条)

保存