亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

java語(yǔ)言

java中String和StringBuffer的區(qū)別

時(shí)間:2024-08-01 17:15:14 java語(yǔ)言 我要投稿
  • 相關(guān)推薦

java中String和StringBuffer的區(qū)別

  String這個(gè)類(lèi)是Java中使用得最頻繁的類(lèi)之一,以下就是小編精心推薦java中String和StringBuffer的區(qū)別,希望對(duì)大家有幫助!

  看到這個(gè)講解的不錯(cuò),所以轉(zhuǎn)一下

  在java中有3個(gè)類(lèi)來(lái)負(fù)責(zé)字符的操作。

  1.Character 是進(jìn)行單個(gè)字符操作的,

  2.String 對(duì)一串字符進(jìn)行操作,不可變類(lèi)。

  3.StringBuffer 也是對(duì)一串字符進(jìn)行操作,是可變類(lèi)。

  String:

  是對(duì)象不是原始類(lèi)型.

  為不可變對(duì)象,一旦被創(chuàng)建,就不能修改它的值.

  對(duì)于已經(jīng)存在的String對(duì)象的修改都是重新創(chuàng)建一個(gè)新的對(duì)象,然后把新的值保存進(jìn)去.

  String 是final類(lèi),即不能被繼承.

  StringBuffer:

  是一個(gè)可變對(duì)象,當(dāng)對(duì)他進(jìn)行修改的時(shí)候不會(huì)像String那樣重新建立對(duì)象

  它只能通過(guò)構(gòu)造函數(shù)來(lái)建立,

  StringBuffer sb = new StringBuffer();

  注意:不能通過(guò)賦值符號(hào)對(duì)它進(jìn)行付值.

  sb = "welcome to here!";//error

  對(duì)象被建立以后,在內(nèi)存中就會(huì)分配內(nèi)存空間,并初始保存一個(gè)null.向StringBuffer中賦值的時(shí)候可以通過(guò)它的append()方法.

  sb.append("hello");

  字符串連接操作中StringBuffer的效率要比String高:

  String str = new String("welcome to ");

  str += "here";

  的處理步驟實(shí)際上是通過(guò)建立一個(gè)StringBuffer,然后調(diào)用append(),最后

  再將StringBuffer toSting();

  這樣的話String的連接操作就比StringBuffer多出了一些附加操作,當(dāng)然效率上要打折扣.

  并且由于String 對(duì)象是不可變對(duì)象,每次操作Sting 都會(huì)重新建立新的對(duì)象來(lái)保存新的值.

  這樣原來(lái)的對(duì)象就沒(méi)用了,就要被垃圾回收.這也是要影響性能的.

  看看以下代碼:

  將26個(gè)英文字母重復(fù)加了5000次,

  String tempstr = "abcdefghijklmnopqrstuvwxyz";

  int times = 5000;

  long lstart1 = System.currentTimeMillis();

  String str = "";

  for (int i = 0; i < times; i++) {

  str += tempstr;

  }

  long lend1 = System.currentTimeMillis();

  long time = (lend1 - lstart1);

  System.out.println(time);

  可惜我的計(jì)算機(jī)不是超級(jí)計(jì)算機(jī),得到的結(jié)果每次不一定一樣一般為 46687左右。

  也就是46秒。

  我們?cè)倏纯匆韵麓a

  String tempstr = "abcdefghijklmnopqrstuvwxyz";

  int times = 5000;

  long lstart2 = System.currentTimeMillis();

  StringBuffer sb = new StringBuffer();

  for (int i = 0; i < times; i++) {

  sb.append(tempstr);

  }

  long lend2 = System.currentTimeMillis();

  long time2 = (lend2 - lstart2);

  System.out.println(time2);

  得到的結(jié)果為 16 有時(shí)還是 0

  所以結(jié)論很明顯,StringBuffer 的速度幾乎是String 上萬(wàn)倍。當(dāng)然這個(gè)數(shù)據(jù)不是很準(zhǔn)確。因?yàn)檠h(huán)的次數(shù)在100000次的時(shí)候,差異更大。不信你試試

  如果還是不能夠明白:

  1)String的聯(lián)合+方法與StringBuff的append方法的區(qū)別:

  String的+運(yùn)算符在進(jìn)行字符串運(yùn)算時(shí),首先將當(dāng)前的字符串對(duì)象轉(zhuǎn)換為StringBuff 類(lèi)型,調(diào)用其append方法,最后再將生成的StringBuff 對(duì)象通過(guò)其toString 方法轉(zhuǎn)換為String類(lèi)型的字符串,所以其效率要低。

  但是在可讀性上,還是String的連接運(yùn)算符要高。

  2)StringBuff是線程安全的

  String是線程是非安全的

  3)String是不可以修改的字符串對(duì)象,而StringBuff是可以修改的。

  public static boolean fileCopy(String srcStr, String destStr) {

  File srcFile = null;

  File destFile = null;

  Reader reader = null;

  Writer writer = null;

  boolean flag = false;

  try {

  srcFile = new File(srcStr);

  if (!srcFile.exists()) {

  System.out.println(“源文件不存在”);

  System.exit(0);

  } else {

  reader = new FileReader(srcFile);

  }

  destFile = new File(destStr);

  writer = new FileWriter(destFile);

  char[] buff = new char[1024];

  int len;

  String str = “”;

  StringBuffer sbuff = new StringBuffer();

  while ((len = reader.read(buff)) != -1) {

  // str += new String(buff, 0, len);

  sbuff.append(new String(buff,0,len));

  }

  // writer.write(str.toCharArray());

  writer.write(sbuff.toString().toCharArray());

  flag = true;

  writer.flush();

  reader.close();

  writer.close();

  } catch (IOException e) {

  System.out.println(“文件拷貝異常:= ” + e.getMessage());

  }

  return flag;

  }


【 java中String和StringBuffer的區(qū)別】相關(guān)文章:

JAVA中STRING的常用方法總結(jié)04-04

Java中hashmap和hashtable的區(qū)別03-30

Java中對(duì)象和引用的具體區(qū)別12-04

java中i++和++i的區(qū)別04-02

關(guān)于java中堆和棧的區(qū)別04-03

Java中靜態(tài)綁定和動(dòng)態(tài)綁定的區(qū)別04-02

Java中定義與聲明的區(qū)別03-19

對(duì)Java中HashMap和TreeMap的區(qū)別的深入理解04-02

JavaScript與Java的區(qū)別11-26