String类的详细介绍和Stringbuffer、Stringbuilder 类的简单介绍

 

String类的详细介绍和Stringbuffer、Stringbuilder 类的简单介绍

String类

一、获取

  1.1:字符串中包含的字符数,也就是字符串的长度
  int length():获取长度
 1.2:根据位置获取位置上某个字符。
  char charAt(int index)
 1.3:根据字符获取该字符在字符串中的位置。
int indexOf(int ch):返回的是ch在字符串中第一次出现的位置。
  int indexOf(int ch,int fromIndex):从fromIndex指定位置开始,获取ch在字符串中出现的位置。
  int indexOf(String str):返回的是str在字符串中第一次出现的位置。
  int indexOf(String str,int fromIndex):从fromIndex指定位置开始,获取str在字符串中出现的位置。
 1.4:int lastIndexOf(String str):反向索引。

 

 

 


二、判断

2.1:字符串中是否包含某一个子串。
      boolean contains(str);
   特殊之处:indexOf(str):可以索引str第一次出现为止,如果返回-1,表示该str不在字符串中存在。 所以,也可以用于对指定判断是否包含。
    if(str.indexOf("a")!=1)   而且该方法既可以判断,也可以获取出现的位置。

 2.2:字符串中是否有内容。
    boolean isEmpty():原理就是判断长度是否为0。
 2.3:字符串是否以指定内容开头。
   boolean startsWith(str);
 2.4:字符串是否以指定内容结尾。
   boolean endsWith(str);
 2.5:判断字符内容是否相同,复写了object类中的equals方法。
   boolean equals(str);
 2.6:判断内容是否相同,并忽略大小写。
  boolean.equalsIgnorecase();

 


三、转换

 3.1:将字符数组转成字符串。
  构造函数:String(char[])
      String(char[],offset,count):将字符数组中的一部分转成字符串
   静态方法:
     static String copyValueOf(char[]);
     static String copyValueOf(char[] data,int offset,int count);

     static String valueOf(char[]);
 3.2:将字符串转成字符组
  char[] tocharArray();

 3.3:将字节数组转成字符串。
      String(byte[])
     String(byte[],offset,count):将字节数组中的一部分转成字符串
 3.4:将字符串转成字节数组。
  byte[] getBytes()

 3.5:将基本数据类型转成字符串,
 static String valueOf(int)
 static String valueOf(double)

 // 3+"" 与 String.valueOf(3)的值是一样的
 特殊:字符串和字节数组在转换过程中,是可以指定编码的。

 
 

四、替换

 String replace(oldchar,newchar);

5>切割
 String[] split(regex);

6>子串。获取字符串中的而一部分
 String subString(begin);
 String subString(begin,end);

7>转换,去除空格,比较。 
 7.1:将字符串转成大写或小写
   String toUpperCsae() 大转小
   String toLowerCsae() 小转大

 7.2:将字符串两端的多个空格去除
   String trim();

 7.3:对两个字符串进行自然顺序的比较
   int compareTo(string);




 

五、示例展示

 请看如下代码,下面的代码都是针对上面string七种用法而进行一一举例说明:

代码如下:

class StringMethodDemo 
{
 public staticvoid method_Zhuanhuan_Qukong_Bijiao() {
    String s ="     hello Java    ";
    System.out.println(s);//打印结果是:(hello和java前后门都有空格)hello java
    System.out.println(s.toUpperCase());//打印结果是:(HELLO和JAVA前后门都有空格)HELLO JAVA
    System.out.println(s.toLowerCase());//打印及结果是:带空格的“hello java”
    System.out.println(s.trim());//打印及结果是:不带空格的“hello java”
    String s1 = "abc";
    String s2 ="aaa";
    System.out.println(s1.compareTo(s2)); //比较数的大写,打印结果是:1,因为b对应ascii值是98,//a对应是97,所以b-a=1
 }
 public static void method_sub() {
    String s ="abcdef";
    System.out.println(s.substring(2)); //打印结果是:cdef,从指定位置开始到结尾。如果角标不存在,会出现字符串角标越界。
    System.out.println(s.substring(2,4)); //打印结果是:cd,包含头,不包含尾。
 }
 public staticvoid method_split() {
    String s ="zhangsan,lisi,wangwu";
    String[] arr = s.split(",");//以,为分割,分割成数组3个3个值
    for(int x=0; x<arr.length; x++)  {
        System.out.println(arr[x]);//分别输出zhangsan  lisi  wangwu 
    }
 }
 public static void method_replace() {
    String s ="hello java";
    //String s1 = s.replace('a','n'); //把a 替换为n
    //String s1 = s.replace('w','n');  //如果要替换的字符不存在,返回的还是原串

     String s1 = s.replace("java","world");//把java 替换为world
     System.out.println("s="+s); //打印结果是:hello java因为字符串一旦被初始化,值就不可被改变
     System.out.println("s1="+s1);//打印结果是:hello jnvn
 }
 public static void method_trans() {
    char[] arr ={'a','b','c','d','e','f'};
    String s = new  String(arr,1,3);
    System.out.println("s="+s);//打印结果是:bcd
    String s1 = "zxcvbnm";
    char[] chs =s1.toCharArray();
    for(int x=0; x<chs.length; x++) {
         System.out.println("ch="+chs[x]);//打印结果是:ch=z,x,c,v,b,n,m
    }
 }
 public static void method_is() {
     String str ="ArrayDemo.java";//下面的判断对的就返回true否则返回false
     System.out.println(str.startsWith("Array"));//判断文件名称是否是Array单词开头

     System.out.println(str.endsWith(".java"));//判断文件名称是否是.java的文件
     System.out.println(str.contains("Demo"));//判断文件中是否包含Demo
 }
 
 public static void method_get() {
     String str ="abcdeakpf";
     System.out.println(str.length());//长度
     System.out.println(str.charAt(4)); //根据索引获取字符
  //System.out.println(str.charAt(40));当访问到字符串中不存在的角标时会发生StringIndexOutOfBoundsException(字符串角标越界异常)
     //根据字符获取索引
     System.out.println(str.indexOf('a')); //输出0
     System.out.println(str.indexOf('a',3));// /输出打印的是5,因为角标3是d,
     //所以从d后面开始找a,第5个角标是a
     //System.out.println(str.indexOf('t',3))打印:-1,如果没有找到角标,返回-1
     System.out.println(str.lastIndexOf("a")); //反向索引一个字符出现的位置(从右往左查找,但是角标还是从左开始),输出还是5

 }
 public static void main(String[] args)  {
    method_Zhuanhuan_Qukong_Bijiao();
    //method_sub();
    //method_split();
    //method_replace();  
    //method_trans(); 
     //method_is();
    //method_get();
      /*
      String s1 ="abc";
      String s2 =new String("abc");
      String s3 = "abc";
     System.out.println(s1==s2);//输出false
      System.out.println(s1==s3); //输出true
    
      */
    }
 }


 

六、Stringbuffer类和Stringbuilder类

String 字符串常量
StringBuffer 字符串变量(线程安全)
StringBuilder 字符串变量(非线程安全)


 简要的说, String类型和 StringBuffer 类型的主要性能区别其实在于 String 是不可变的对象, 因此在每次对 String 类型进行改变的时候其实都等同于生成了一个新的 String 对象,然后将指针指向新的 String 对象,所以经常改变内容的字符串最好不要用 String ,因为每次生成对象都会对系统性能产生影响,特别当内存中无引用对象多了以后, JVM 的 GC 就会开始工作,那速度是一定会相当慢的。

buffer是缓存的意思,builder是建设的意思

StringBuffer和StringBuilder使用的方法是一样的

StringBuffer 是线程安全的 StringBuilder是线程不安全的

 

怎么理解Stringbuffer 是线程安全的 stringbuilder是线程不安全的

1、 多个线程操作同一个StringBuffer对象会顺序进行(内部很多方法是同步方法)

2、多个线程操作同一个StringBuilder是同时的,这时候可能出现与预期不符合的结果

3、StringBuilder由于是线程不安全的,所以性能更好。

4、大部分情况下都是单线程操作字符串,这时候选择StringBuilder。  

速度比较:StringBuilder速度较快           StringBuffer相对较慢

 

七、StringBuffer和StringBuilder的一些使用的方法

重要的是append()和inset(),这两个在java都没有

 

 

append的使用

 

StringBuilder sb = new StringBuilder(“”);//不能像String直接用双引号定义变量,这里需要new出来
sb.Append( "123456789" );//添加一个字符串
sb.Length = 3;//设置容量为3
System.out.println ( sb.toString() );//这里输出:123

sb.Length = 30;//重新设置容量为30
System.out.println ( sb.ToString() + ",结尾");//这里在原来字符串后面补齐空格,至到Length的为30
System.out.println ( sb.Length );//这里输出的长度为30

 

 

 

insert的使用

 

 

/*显示格式转换

 * 整数位每隔3位用逗号隔开

 * insert方法在StringBuffer才有

 * */

public static void main(String[] args){

double d=1234.5;

     //double先转换为String类型,再转换为StringBuffer类型

    StringBuffer sb=new StringBuffer(d+"");

    for (inti = sb.indexOf(".")-3;i > 0; i-=3) {

        sb.insert(i,",");

    }

    System.out.println(“d=”+d);//输出d=1,234.5

}

   

用一个例子来看StringBuilder和String之间的速度差距:

 

 

public class StringTest {
 
    // String类和StringBuffer速度的比较
    public static void main(String[] args) {
       StringBuffer sb = new StringBuffer ("");//创建Stringbuffer对象,并实例化
       int i = 0;
       long StartTime = System.currentTimeMillis();//获取系统循环执行开始时间的毫秒数
       while (i <100000) {
           sb.append((i + "").toString());//使用append方法
           i++;
       }
       long EndTime = System.currentTimeMillis();//获取系统循环执行结束时间的毫秒数
       System.out.println("StringBuffer时间:" + (EndTime - StartTime));//计算时间差
      
       String sb1 = "";//创建String对象
       i = 0;
       StartTime = System.currentTimeMillis();//获取系统循环执行开始时间的毫秒数
       while (i <100000) {
           sb1 = sb1 + i;//和append效果一样
           i++;
       }
       EndTime = System.currentTimeMillis();//获取系统循环执行结束时间的毫秒数
       System.out.println("String时间:" + (EndTime - StartTime));//计算时间差
    }
}


 运行结果:



运行结果相差很大哦!

 

所以StringBuilder和StringBuffer用于变量经常改变的情况,运行速度很快,

但是其他情况还是比较多使用String这个类的!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

峥嵘life

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值