Java012-API

姚根深發表於2019-01-19

API:(Application Programming Interface,應用程式程式設計介面)是一些預先定義的函式,目的是提供應用程式與開發人員基於某軟體或硬體的以訪問一組例程的能力,而又無需訪問原始碼,或理解內部工作機制的細節。

–< java.lang >– String字串:★★★☆
java中用String類進行描述。對字串進行了物件的封裝。這樣的好處是可以對字串這種常見資料進行方便的操作。物件封裝後,可以定義N多屬性和行為。

如何定義字串物件呢?String s = “abc”;只要是雙引號引起的資料都是字串物件。

特點:字串一旦被初始化,就不可以被改變,存放在方法區中的常量池中。

String s1 = “abc”; // s1指向的記憶體中只有一個物件abc。
String s2 = new String(“abc”); // s2指向的內容中有兩個物件abc、new 。

System.out.println(s1==s2);//false

System.out.println(s1.equals(s2));//true ,字串中equals比較的是字串內容是否相同。

字串的方法:

1:構造方法:將位元組陣列或者字元陣列轉成字串。
String s1 = new String();//建立了一個空內容的字串。
String s2 = null;//s2沒有任何物件指向,是一個null常量值。
String s3 = “”;//s3指向一個具體的字串物件,只不過這個字串中沒有內容。
//一般在定義字串時,不用new。
String s4 = new String(“abc”);
String s5 = “abc”; 一般用此寫法
new String(char[]);//將字元陣列轉成字串。
new String(char[],offset,count);//將字元陣列中的一部分轉成字串。

2:一般方法:
按照物件導向的思想:
2.1 獲取:
2.1.1:獲取字串的長度。length();
2.1.2:指定位置的字元。char charAt(int index);
2.1.3:獲取指定字元的位置。如果不存在返回-1,所以可以通過返回值-1來判斷某一個字元不存在的情況。
int indexOf(int ch);//返回第一次找到的字元角標
int indexOf(int ch,int fromIndex); //返回從指定位置開始第一次找到的角標
int indexOf(String str); //返回第一次找到的字串角標
int indexOf(String str,int fromIndex);

int lastIndexOf(int ch);
int lastIndexOf(int ch,int fromIndex);
int lastIndexOf(String str);
int lastIndexOf(String str,int fromIndex);
2.1.4:獲取子串。
String substring(int start);//從start位開始,到length()-1為止.
String substring(int start,int end);//從start開始到end為止。//包含start位,不包含end位。
substring(0,str.length());//獲取整串
2.2 判斷:
2.2.1:字串中包含指定的字串嗎?
boolean contains(String substring);
2.2.2:字串是否以指定字串開頭啊?
boolean startsWith(string);
2.2.3:字串是否以指定字串結尾啊?
boolean endsWith(string);
2.2.4:判斷字串是否相同
boolean equals(string);//覆蓋了Object中的方法,判斷字串內容是否相同。
2.2.5:判斷字串內容是否相同,忽略大小寫。
boolean equalsIgnoreCase(string) ;

2.3 轉換:
2.3.1:通過建構函式可以將字元陣列或者位元組陣列轉成字串。
2.3.2:可以通過字串中的靜態方法,將字元陣列轉成字串。
static String copyValueOf(char[] );
static String copyValueOf(char[],int offset,int count);
static String valueOf(char[]);
static String valueOf(char[],int offset,int count);
2.3.3:將基本資料型別或者物件轉成字串。
static String valueOf(char);
static String valueOf(boolean);
static String valueOf(double);
static String valueOf(float);
static String valueOf(int);
static String valueOf(long);
static String valueOf(Object);
2.3.4:將字串轉成大小寫。
String toLowerCase();
String toUpperCase();
2.3.5:將字串轉成陣列。
char[] toCharArray();//轉成字元陣列。
byte[] getBytes();//可以加入編碼表。轉成位元組陣列。
2.3.6:將字串轉成字串陣列。切割方法。
String[] split(分割的規則-字串);
2.3.7:將字串進行內容替換。注意:修改後變成新字串,並不是將原字串直接修改。
String replace(oldChar,newChar);
String replace(oldstring,newstring);
2.3.8: String concat(string); //對字串進行追加。
String trim();//去除字串兩端的空格

int compareTo();//如果引數字串等於此字串,則返回值 0;如果此字串按字典順序小於字串引數,則返回一個小於 0 的值;如果此字串按字典順序大於字串引數,則返回一個大於 0 的值。

–< java.lang >– StringBuffer字串緩衝區:★★★☆
構造一個其中不帶字元的字串緩衝區,初始容量為 16 個字元。
特點:
1:可以對字串內容進行修改。
2:是一個容器。
3:是可變長度的。
4:緩衝區中可以儲存任意型別的資料。
5:最終需要變成字串。

容器通常具備一些固定的方法:
1,新增。
StringBuffer append(data):在緩衝區中追加資料。追加到尾部。
StringBuffer insert(index,data):在指定位置插入資料。
2,刪除。
StringBuffer delete(start,end);刪除從start至end-1範圍的元素
StringBuffer deleteCharAt(index);刪除指定位置的元素
//sb.delete(0,sb.length());//清空緩衝區。
3,修改。
StringBuffer replace(start,end,string);將start至end-1替換成string
void setCharAt(index,char);替換指定位置的字元
void setLength(len);將原字串置為指定長度的字串
4,查詢。(查不到返回-1)
int indexOf(string); 返回指定子字串在此字串中第一次出現處的索引。
int indexOf(string,int fromIndex);從指定位置開始查詢字串
int lastIndexOf(string); 返回指定子字串在此字串中最右邊出現處的索引。
int lastIndexOf(string,int fromIndex); 從指定的索引開始反向搜尋
5,獲取子串。
string substring(start); 返回start到結尾的子串
string substring(start,end); 返回start至end-1的子串
6,反轉。

StringBuffer reverse();字串反轉

–< java.lang >– StringBuilder字串緩衝區:★★★☆
JDK1.5出現StringBuiler;構造一個其中不帶字元的字串生成器,初始容量為 16 個字元。該類被設計用作 StringBuffer 的一個簡易替換,用在字串緩衝區被單個執行緒使用的時候(這種情況很普遍)。
方法和StringBuffer一樣;

StringBuffer 和 StringBuilder 的區別:
StringBuffer執行緒安全。
StringBuilder執行緒不安全。

單執行緒操作,使用StringBuilder 效率高。

多執行緒操作,使用StringBuffer 安全。

StringBuilder sb = new StringBuilder(“abcdefg”);
sb.append(“ak”); //abcdefgak
sb.insert(1,”et”);//aetbcdefg
sb.deleteCharAt(2);//abdefg
sb.delete(2,4);//abefg
sb.setLength(4);//abcd
sb.setCharAt(0,`k`);//kbcdefg
sb.replace(0,2,”hhhh”);//hhhhcdefg

//想要使用緩衝區,先要建立物件。
StringBuffer sb = new StringBuffer();
sb.append(12).append(“haha”);//方法呼叫鏈。
String s = “abc”+4+`q`;

s = new StringBuffer().append(“abc”).append(4).append(`q`).toString();

class Test{
public static void main(String[] args) {
String s1 = “java”;
String s2 = “hello”;
method_1(s1,s2);
System.out.println(s1+”….”+s2); //java….hello

StringBuilder s11 = new StringBuilder(“java”);
StringBuilder s22 = new StringBuilder(“hello”);
method_2(s11,s22);
System.out.println(s11+”—–“+s22); //javahello—–hello
}
public static void method_1(String s1,String s2){
s1.replace(`a`,`k`);
s1 = s2;
}
public static void method_2(StringBuilder s1,StringBuilder s2){
s1.append(s2);
s1 = s2;
}

}

基本資料型別物件包裝類:是按照物件導向思想將基本資料型別封裝成了物件。
好處:
1:可以通過物件中的屬性和行為操作基本資料。
2:可以實現基本資料型別和字串之間的轉換。

關鍵字 對應的類名
byte Byte
short Short paserShort(numstring);
int Integer 靜態方法:parseInt(numstring)
long Long
float Float
double Double
char Character
Boolean Boolean

基本資料型別物件包裝類:都有 XXX parseXXX 方法

只有一個型別沒有parse方法:Character ;

Integer物件: ★★★☆
數字格式的字串轉成基本資料型別的方法:
1:將該字串封裝成了Integer物件,並呼叫物件的方法intValue();
2:使用Integer.parseInt(numstring):不用建立物件,直接類名呼叫;

將基本型別轉成字串:
1:Integer中的靜態方法 String toString(int);
2:int+””;

將一個十進位制整數轉成其他進位制:
轉成二進位制:toBinaryString
轉成八進位制:toOctalString
轉成十六進位制:toHexString
toString(int num,int radix);

將其他進位制轉換十進位制:
parseInt(string,radix); //將給定的數轉成指定的基數進位制;

在jdk1.5版本後,對基本資料型別物件包裝類進行升級。在升級中,使用基本資料型別物件包裝類可以像使用基本資料型別一樣,進行運算。
Integer i = new Integer(4); //1.5版本之前的寫法;
Integer i = 4; //自動裝箱,1.5版本後的寫法;
i = i + 5;
//i物件是不能直接和5相加的,其實底層先將i轉成int型別,在和5相加。而轉成int型別的操作是隱式的。自動拆箱:拆箱的原理就是i.intValue();i+5運算完是一個int整數。如何賦值給引用型別i呢?其實有對結果進行裝箱。
Integer c = 127;
Integer d = 127;
System.out.println(c = = d); //true

//在裝箱時,如果數值在byte範圍之內,那麼數值相同,不會產生新的物件,也就是說多個數值相同的引用指向的是同一個物件。