2013年計(jì)算機(jī)二級(jí)JAVA考點(diǎn)整理(1)

字號(hào):

1 JAVA SE
    1.1 深入JAVA API
    1.1.1 Lang包
    1.1.1.1 String類和StringBuffer類
    位于java.lang包中,這個(gè)包中的類使用時(shí)不用導(dǎo)入
    String類一旦初始化就不可以改變,而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ì)于回車換行,在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': //回車時(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; //如果不是回車,換行,則將讀取的數(shù)據(jù)存入數(shù)組中。
    }
    }
    }
    }
    String類的常用成員方法
    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ù)類型包裝類的作用是:將基本的數(shù)據(jù)類型包裝成對(duì)象。因?yàn)橛行┓椒ú豢梢灾苯犹幚砘緮?shù)據(jù)類型,只能處理對(duì)象,例如vector的add方法,參數(shù)就只能是對(duì)象。這時(shí)就需要使用他們的包裝類將他們包裝成對(duì)象。
    例:在屏幕上打印出一個(gè)*組成的矩形,矩形的寬度和高度通過(guò)啟動(dòng)程序時(shí)傳遞給main()方法的參數(shù)指定。
    public class testInteger
    {
    public static void main(String[] args)
    //main()的參數(shù)是string類型的數(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)樗强勺芳拥摹?BR>    for(int j=0;j
    {
    sb.append('*');
    }
    System.out.println(sb.toString()); //在打印之前,要將stringbuffer轉(zhuǎn)化為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)在運(yùn)行結(jié)果上相同,但效率相差很多。
    (1) 在每一次循環(huán)中,都要先將string類型轉(zhuǎn)換為stringbuffer類型,然后將‘*’追加進(jìn)去,然后再調(diào)用tostring()方法,轉(zhuǎn)換為string類型,效率很低。
    (2) 在沒(méi)次循環(huán)中,都只是調(diào)用原來(lái)的那個(gè)stringbuffer對(duì)象,沒(méi)有創(chuàng)建新的對(duì)象,所以效率比較高。