一、java.lang.String

  1、string对象不可变,被final修饰,不能被继承。

  2、赋值方式:

    (1)直接赋值。比如: String name = "rick";

    (2)使用new关键字创建。比如:String name = new String("rick");

  

  3、常用构造方法:

    (1)public String();   //无参构造方法,用来创建空字符串的String对象。

    (2)public String(String original);   //用已知的字符串original创建一个String对象。

    (3)public String(char value[]);  //用字符数组value创建一个String对象。

    (4)public String(char value[], int offset, int count);   //用字符数组value的offset开始的count个字符创建一个String对象。

    (5)public String(byte bytes[]);     //用字节数组bytes创建一个String对象。

    (6)public String(byte bytes[], String charsetName);  //根据指定编码格式charsetName,用字节数组bytes创建一个String对象。

    (7)public String(byte bytes[], int offset, int length, String charsetName);   //根据指定编码格式charsetName,用字节数组bytes的offset开始的length个字符创建一个String对象。

  4、常用方法:

    (1)public int length() ;  //返回该字符串的长度。

    (2)public boolean isEmpty() ;   //判断字符串是否为空。

    (3)public char charAt(int index) ;   //返回字符串中指定位置的字符;字符串范围为 0 ~ length()-1。

    (4)public byte[] getBytes(String charsetName);  //根据指定编码格式charsetName,将字符串转为字节数组。  

    (5)public boolean equals(Object anObject);  //用于比较两个字符串内容是否相同。相同返回true,不同返回false。

    (6)public boolean equalsIgnoreCase(String anotherString);  //与equals比较类似,但忽略大小写。

    (7)public int compareTo(String anotherString);   //按字典顺序逐个字符进行比较,返回的数即为字符间的差距(大小关系)。若字符大于anotherString的字符,则返回正数,小于则返回负数,等于则返回0。

    (8)public int compareToIgnoreCase(String str);  //与compareTo类似,但忽略大小写。

    (9)public boolean startsWith(String prefix);    //判断字符串是否以指定字符串prefix开头。

    (10)public boolean endsWith(String suffix); //判断字符串是否以指定字符串suffix结尾。

    (11)public int hashCode();  //用于返回字符串的哈希码。

    (12)public boolean contains(CharSequence s);   //判断当前字符串是否包含 给定的子字符串s。

    (13)public String concat(String str) ;   //用于字符串的拼接。等价于 符号 “+”。

    (14)public String trim();  //用于去除字符串首尾两端的空格。

    (15)public String toLowerCase();  //将字符串全转成小写字符串。

    (16)public String toUpperCase();  //将字符串全转为大写字符串。

    (17)public char[] toCharArray() ;  //将字符串转为字符数组。

    (18)public String substring(int beginIndex);  //从当前字符串中的beginIndex位置起,取出剩余的字符作为一个新的字符串返回。

    (19)public String substring(int beginIndex, int endIndex);  //从当前字符串中的beginIndex位置起,取出到endIndex-1位置的字符作为一个新的字符串返回。

    (20)public String replace(char oldChar, char newChar);   //用字符newChar替换当前字符串中所有的oldChar字符,并返回一个新的字符串。

    (21)public String replaceAll(String regex, String replacement);将字符串中符合regex格式的子串替换成replacement,此时并未改变原始字符串。

    (22)public String[] split(String regex); //将字符串使用regex标记分割,并将分割后的单词存入字符串数组中。

    (23)public boolean matches(String regex);  //判断当前字符串对象是否与参数regex格式相匹配。

二、java.lang.StringBuffer、java.lang.StringBuilder

  1、当频繁修改字符串时,需要使用 StringBuffer 和 StringBuilder 类。与String 类不同的是,StringBuffer 和 StringBuilder 类的对象能够被多次的修改,并且不产生新的未使用对象。

  2、StringBuffer与StringBuilder大体上相似,只是StringBuffer属于线程安全的。对于单线程的程序,推荐使用StringBuilder。

  3、常用构造方法:(以StringBuffer为例)

    (1)public StringBuffer();  //默认构造一个不带字符的字符串缓冲区,初始容量为16个字符。

    (2)public StringBuffer(String str);  //构造一个str.length() + 16的字符串缓冲区。

  4、常用方法:(以StringBuffer为例)

    (1)追加:

        public synchronized StringBuffer append(Object obj);   //将对象追加到字符串的末尾。

    (2)插入:

        public StringBuffer insert(int dstOffset, CharSequence s) ; //将字符串s插入到指定位置 dstOffset。字符串范围为 0 ~ length()-1。

    (3)删除:

        public synchronized StringBuffer delete(int start, int end);  //删除start ~ end-1 范围的字符。

        public synchronized StringBuffer deleteCharAt(int index);  //删除指定位置的字符。

    (4)替换:

        public synchronized StringBuffer replace(int start, int end, String str);   //用给定 String 中的字符替换此序列(start ~ end-1)的子字符串中的字符。

        public synchronized void setCharAt(int index, char ch);  //用给定的字符ch,替换指定位置的字符。

        public synchronized void setLength(int newLength);  // 将给定的字符串,裁剪成指定长度。

    (5)获取子串:

        public synchronized String substring(int start);    //返回从start位置开始 的所有字符。

        public synchronized String substring(int start, int end);   //返回 start ~ end-1 位置的所有字符。

    (6)字符串反转:

        public synchronized StringBuffer reverse();   //将字符串倒序输出。

    (7)查找:

        public int indexOf(String str);   //正序查找(从前往后找),返回指定子字符串在此字符串第一次出现的索引,若没有,则返回-1。

        public synchronized int indexOf(String str, int fromIndex); //从 fromIndex 位置开始查找。返回指定子字符串在此字符串第一次出现的索引,若没有,则返回-1。

        public int lastIndexOf(String str); //倒序查找(从后往前找)返回指定子字符串在此字符串第一次出现的索引,若没有,则返回-1。

        public synchronized int lastIndexOf(String str, int fromIndex) ;  //从 fromIndex 位置开始查找。返回指定子字符串在此字符串第一次出现的索引,若没有,则返回-1。

三、String、StringBuffer、StringBuilder的区别

  1、String中由final修饰的字符数组来保存字符串,即private final char value[],所以String不可变。

  2、StringBuffer与StringBuilder继承 AbstractStringBuilder类,且其构造方法中调用AbstractStringBuilder类的构造方法,而AbstractStringBuilder类未使用final修饰字符数组来保存字符串,即char value[], 故StringBuilder与StringBuilder可变。

  3、线程安全?
    (1)String对象不可变,所以是线程安全的。
    (2)StringBuffer由于方法加入同步锁,所以是线程安全的。
    (3)StringBuilder没有同步锁,所以是线程不安全的。

  4、对于String对象,给其赋值分两种情况:
    (1)直接赋值,即String str = "123";时,若常量池中存在"123",则str指向这个字符串,若不存在,则创建一个"123"并置于常量池中,将其引用返回。
    (2)使用new关键字,即String str = new String("123");如果常量池中没有"123",则创建"123"并置于常量池中,然后new关键字会在堆中创建一个String对象,并将堆中的引用返回。

  5、使用情况?
    (1)操作少量数据,推荐使用String。
    (2)单线程下操作大量数据,推荐使用StringBuilder。
    (3)多线程下操作大量数据,推荐使用StringBuffer。

四、java.util.StringTokenizer

  1、String类中的split()方法是使用正则表达式分解字符串。使用StringTokenizer类可以不使用正则表达式分解字符串。

  

  2、构造方法:

    (1)public StringTokenizer(String str);    //为字符串s构造一个分析器,使用默认的分隔标记(空白符),即空格符(多个空格被看成一个空格),换行符,回车符,Tab符等。

    (2)public StringTokenizer(String str, String delim);   //为字符串s构造一个分析器,使用delim中的字符作为分隔符。

    注意:分隔标记的任意组合仍是分隔标记。

  3、常用方法:

    (1)public int countTokens() ;  //获取当前分析器中按照标记切割后的单词数量

    (2)public String nextToken();   //逐个获取字符串中分割的单词,每次成功获取,则单词数自动减一。

    (3)public boolean hasMoreElements()   //控制循环,若当前分析器中还有单词,即单词数大于1,则返回true。

 import java.util.StringTokenizer;

 public class Test {
public static void main(String args[]) {
StringTokenizer st = new StringTokenizer("hello,,, world", ",");
System.out.println("切割后单词数量为: " + st.countTokens());// 输出按标记切割后的单词数
System.out.println("单词分别为: ");
while (st.hasMoreTokens()) {// 控制循环
System.out.println(st.nextToken()); // 获取单词
}
}
}
/*
* 测试结果:
* 切割后单词数量为: 2
* 单词分别为:
* hello
* world
*
*/

Java基础--常用API--字符串相关API的更多相关文章

  1. Java基础--常用API--日期相关API

    一.java.util.Date 1.只用于显示系统时间,其大部分操作由Calendar代替. 格林威治时间(GMT):指的是1970年1月1日0时,不同地区有时间差. 默认输出格式:星期.月.日.时 ...

  2. Java基础--常用API--IO流相关API

    一.IO流 1.定义: IO流指的是Input/Output流,即输入流/输出流. 输入流:将外界信息写入程序,即从外界获取信息,属于读操作. 输出流:将程序数据发送给外界,即向外界传输数据,属于写操 ...

  3. java基础--常用函数总结

    java基础--常用函数总结 2019-3-16-23:28:01-----云林原创 1.split()字符串分割函数 将一个字符串分割为子字符串,然后将结果作为字符串数组返回. 2.Math.flo ...

  4. java中常用的字符串的截取方法

    java中常用的字符串的截取方法   1.length() 字符串的长度 例:char chars[]={'a','b'.'c'}; String s=new String(chars); int l ...

  5. Java基础-处理json字符串解析案例

    Java基础-处理json字符串解析案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 作为一名开发人员,想必大家或多或少都有接触到XML文件,XML全称为“extensible ...

  6. 零基础学Java第四节(字符串相关类)

    本篇文章是<零基础学Java>专栏的第四篇文章,文章采用通俗易懂的文字.图示及代码实战,从零基础开始带大家走上高薪之路! String 本文章首发于公众号[编程攻略] 在Java中,我们经 ...

  7. JAVA基础5——与String相关的系列(1)

    与String相关的系列 String, 是JAVA中常见的一个引用类型,且其具有一定的特殊性. String类型被设置为final型,即不可继承,也就不可修改其中的实现. String可以改变吗 S ...

  8. Java基础——常用类(Date、File)以及包装类

    本文要点: 基本数据类型的包装类 字符串相关类: 不可变字符序列:String 可变字符序列:StringBuffer.StringBuilder 时间处理相关类: Date DateFormat.S ...

  9. JAVA基础--常用类 String,StringBuffer, 基础数据类型包装类, Math类, Enum类

    字符串相关类: String, StringBuffer String类为不可变的字符序列 String s1="hello"; String s2="hello&quo ...

随机推荐

  1. render 的执行流程

    流程 :  render 只能识别 字符串,对于其他的css,html,js,jquery样式是不能识别的,它会将文件中的内容解析称为字符串拿到前端页面,浏览器进行渲染. 例如 : # 视图函数 de ...

  2. 20145239 《Java程序设计》第6周学习总结

    20145239 <Java程序设计>第6周学习总结 教材学习内容总结 10.1.1串流设计 Java将输入/输出抽象化为串流,数据有来源及目的地,衔接两者的是串流对象. 输入串流代表对象 ...

  3. IDEA:Application Server was not connected before run configuration stop, reason: Unable to ping 1099

    原文链接 : http://blog.csdn.net/x6582026/article/details/70807269 最近第一次玩IDEA时碰到tomcat启动问题:Application Se ...

  4. WCF异常处理

    [读书笔记] 在进行分布式应用的异常处理时需要解决和考虑的基本要素: 异常的封装:服务端抛出的异常如何序列化传递到客户端 敏感信息的屏蔽:抛出的异常往往包含一些敏感的信息,直接将服务操作执行过程抛出的 ...

  5. Contiki 2.7 Makefile 文件(三)

    2.第二部分 这里的usage,targets,savetarget,savedefines都是伪目标. 和all不同,这些伪目标不会被执行,除非显式指定这些目标. 这里有两个目标savetarget ...

  6. 【Lintcode】153.Combination Sum II

    题目: Given a collection of candidate numbers (C) and a target number (T), find all unique combination ...

  7. AtCoder Grand Contest 002 F:Leftmost Ball

    题目传送门:https://agc002.contest.atcoder.jp/tasks/agc002_f 题目翻译 你有\(n*k\)个球,这些球一共有\(n\)种颜色,每种颜色有\(k\)个,然 ...

  8. 用linqpad来插入多条数据

    其中Customers为数据库的某个表名, Custom自动被默认为单条记录的对象, 利用构造,InsertOnSubmit, 以及SubmitChanges实现插入数据. 注意:linqpad的la ...

  9. 12 Vue学习 项目技术栈

    vue2 + vuex + vue-router + webpack + ES6/7 + less + element-ui 1:vuex: Vuex 是一个专为 Vue.js 应用程序开发的状态管理 ...

  10. bzoj4176

    莫比乌斯反演 根据约数和个数公式 $ans = \sum_{i=1}^{n}\sum_{j=1}^{n}\sum_{x|i}\sum_{y|j}{[gcd(i, j)==1]}$ 交换枚举顺序 $an ...