1 JAVA SE
1.1 深入JAVA API
1.1.1 Lang包
1.1.1.1 String類和StringBuffer類
位于java.lang包中,這個包中的類使用時不用導入
String類一旦初始化就不可以改變,而stringbuffer則可以。它用于封裝內容可變的字符串。它可以使用tostring()轉換成string字符串。
String x=”a”+4+”c”編譯時等效于String x=new StringBuffer().append(“a”).append(4).append(“c”).toString();
字符串常量是一種特殊的匿名對象,String s1=”hello”;String s2=”hello”;則s1==s2;因為他們指向同一個匿名對象。
如果String s1=new String(“hello”);String s2=new String(“hello”);則s1!=s2;
/*逐行讀取鍵盤輸入,直到輸入為“bye”時,結束程序
注:對于回車換行,在windows下面,有'\r'和'\n'兩個,而unix下面只有'\n',但是寫程序的時候都要把他區(qū)分開*/
public class readline
{
public static void main(String args[])
{
String strInfo=null;
int pos=0;
byte[] buf=new byte[1024];//定義一個數(shù)組,存放換行前的各個字符
int ch=0; //存放讀入的字符
system.out.println(“Please input a string:”);
while(true)
{
try
{
ch=System.in.read(); //該方法每次讀入一個字節(jié)的內容到ch變量中。
}
catch(Exception e)
{
}
switch(ch)
{
case '\r': //回車時,不進行處理
break;
case '\n': //換行時,將數(shù)組總的內容放進字符串中
strInfo=new String(buf,0,pos); //該方法將數(shù)組中從第0個開始,到第pos個結束存入字符串。
if(strInfo.equals("bye")) //如果該字符串內容為bye,則退出程序。
{
return;
}
else //如果不為bye,則輸出,并且竟pos置為0,準備下次存入。
{
System.out.println(strInfo);
pos=0;
break;
}
default:
buf[pos++]=(byte)ch; //如果不是回車,換行,則將讀取的數(shù)據(jù)存入數(shù)組中。
}
}
}
}
String類的常用成員方法
1、 構造方法:
String(byte[] byte,int offset,int length);這個在上面已經用到。
2、 equalsIgnoreCase:忽略大小寫的比較,上例中如果您輸入的是BYE,則不會退出,因為大小寫不同,但是如果使用這個方法,則會退出。
3、 indexOf(int ch);返回字符ch在字符串中首次出現(xiàn)的位置
4、 substring(int benginIndex);
5、 substring(int beginIndex,int endIndex);
返回字符串的子字符串,4返回從benginindex位置開始到結束的子字符串,5返回beginindex和endindex-1之間的子字符串。
基本數(shù)據(jù)類型包裝類的作用是:將基本的數(shù)據(jù)類型包裝成對象。因為有些方法不可以直接處理基本數(shù)據(jù)類型,只能處理對象,例如vector的add方法,參數(shù)就只能是對象。這時就需要使用他們的包裝類將他們包裝成對象。
例:在屏幕上打印出一個*組成的矩形,矩形的寬度和高度通過啟動程序時傳遞給main()方法的參數(shù)指定。
public class testInteger
{
public static void main(String[] args)
//main()的參數(shù)是string類型的數(shù)組,用來做為長,寬時,要轉換成整型。
{
int w=new Integer(args[0]).intValue();
int h=Integer.parseInt(args[1]);
//int h=Integer.valueOf(args[1]).intValue();
//以上為三種將字符串轉換成整形的方法。
for(int i=0;i { StringBuffer sb=new StringBuffer(); //使用stringbuffer,是因為它是可追加的。 for(int j=0;j { sb.append('*'); } System.out.println(sb.toString()); //在打印之前,要將stringbuffer轉化為string類型。 } } } 比較下面兩段代碼的執(zhí)行效率: (1)String sb=new String(); For(int j=0;j { Sb=sb+’*’; } (2) StringBuffer sb=new StringBuffer(); For(int j=0;j { Sb.append(‘*’); } (1) 和(2)在運行結果上相同,但效率相差很多。 (1) 在每一次循環(huán)中,都要先將string類型轉換為stringbuffer類型,然后將‘*’追加進去,然后再調用tostring()方法,轉換為string類型,效率很低。 (2) 在沒次循環(huán)中,都只是調用原來的那個stringbuffer對象,沒有創(chuàng)建新的對象,所以效率比較高。
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |