在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(),忽略字母大小写 |
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参数 |
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() | 去掉字符串的左右空格 |
字符串拆分需要有几点注意:
- 如果要按照“|”、“*”、“+”拆分,字符前需要加上转义字符“\”
- 如果是“\”,则需要写成“\\”
- 字符串有多个分隔符,可以使用“|”作为连字符
特别说明:
Java中字符串是不可变的,所有的对字符串本身的 *** 作都会产生新的对象
至于字符串为什么不可变
因为String源码中value数组被private和final修饰,final修饰,数组的指向对象不可变,private修饰,在类外就无法访问,而且String中没有提供getValue和setValue方法
4.StringBuilder和StringBuffer因为String *** 作字符串会产生新的对象,所以Java中提供了这两个类,这两个类的大部分功能都是类似的,String、StringBuilder、StringBuffer之间的区别如下:
- String内容不可变,StringBuilder和StringBuffer内容可变
- 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的方式返回 |
为使程序运行的更快,同时也为了节省内存,Java为基本数据类型和String都提供了常量池,常量池的位置在堆中,这里只讨论字符串常量池
因为常量池的存在,所以会有如下的情况:
常量池本质是哈希表,原理这里暂时跳过,只说结论:
双引号引起来的元素都存放在常量池里面,有且仅有一份,所以在存放常量的时候,会先去常量池检查是否存在此常量,存在则直接给地址,不存在才会存放常量
所以s1和s2是指向的常量池中的同一地址,而s3是实例化一个对象,这个对象指向的是常量池,但s3本身并没有指向常量池,大致的存储如下图:
String类内容结束,完
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)