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