[TOC]
# java的API
Object類是Java語言中的根類,即所有類的父類。它中描述的所有方法子類都可以使用。所有類在創建對象的時候,最終找的父類就是Object。object類有構造方法
接口不繼承object類
## equals
equals方法,用于比較兩個對象是否相同,它其實就是使用兩個對象的內存地址在比較。Object類中的equals方法內部使用的就是==比較運算符。
~~~
/*
描述人這個類,并定義功能根據年齡判斷是否是同齡人
由于要根據指定類的屬性進行比較,這時只要覆蓋Object中的equals方法
在方法體中根據類的屬性值進行比較
*/
class Person extends Object{
int age ;
//復寫父類的equals方法,實現自己的比較方式
public boolean equals(Object obj) {
//判斷當前調用equals方法的對象和傳遞進來的對象是否是同一個
if(this == obj){
return true;
}
//判斷傳遞進來的對象是否是Person類型
if(!(obj instanceof Person)){
return false;
}
//將obj向下轉型為Perosn引用,訪問其屬性
Person p = (Person)obj;
return this.age == p.age;
}
}
~~~
注意:在復寫Object中的equals方法時,一定要注意public boolean equals(Object obj)的參數是Object類型,在調用對象的屬性時,一定要進行類型轉換,在轉換之前必須進行類型判斷。
## toString
toString方法返回該對象的字符串表示,其實該字符串內容就是對象的類型+@+內存地址值。
由于toString方法返回的結果是內存地址,而在開發中,經常需要按照對象的屬性得到相應的字符串表現形式,因此也需要重寫它。
~~~
class Person extends Object{
int age ;
//根據Person類的屬性重寫toString方法
public String toString() {
return "Person [age=" + age + "]";
}
}
~~~
# string類
查閱API中的String類的描述,發現String 類代表字符串。Java 程序中的所有字符串字面值(如 "abc" )都作為此類的實例實現。
~~~
//演示字符串
String str = "abc";
str = "ef";
~~~
字符串是常量;它們的值在創建之后不能更改,這是什么意思呢?其實就是說一旦這個字符串確定了,那么就會在內存區域中就生成了這個字符串。字符串本身不能改變,但str變量中記錄的地址值是可以改變的
字符串有大量的重載的構造方法。通過String類的構造方法可以完成字符串對象的創建,那么,通過使用雙引號的方式創建對象與new的方式創建對象,有什么不同呢?看如下程序與圖解:
~~~
String s3 = "abc";
String s4 = new String("abc");
System.out.println(s3==s4);//false
System.out.println(s3.equals(s4));//true,
//因為String重寫了equals方法,建立了字符串自己的判斷相同的依據(通過字符串對象中的字符來判斷)
~~~
s3和s4的創建方式有什么不同呢?
* s3創建,在內存中只有一個對象。這個對象在字符串常量池中
* s4創建,在內存中有兩個對象。一個new的對象在堆中,一個字符串本身對象,在字符串常量池中
# 字符串緩沖區
StringBuffer類
StringBuffer又稱為可變字符序列,它是一個類似于 String 的字符串緩沖區,通過某些方法調用可以改變該序列的長度和內容
StringBuffer是個字符串的緩沖區,即就是它是一個容器,容器中可以裝很多字符串。并且能夠對其中的字符串進行各種操作
# StringBuilder類
StringBuilder類,它也是字符串緩沖區,StringBuilder與它和StringBuffer的有什么不同呢?
我們閱讀StringBuilder的API說明發現,它也是一個可變的字符序列。此類提供一個與 StringBuffer 兼容的 API,但不保證同步。該類被設計用作 StringBuffer 的一個簡易替換,用在字符串緩沖區被單個線程使用的時候(這種情況很普遍)。如果可能,建議優先采用該類,因為在大多數實現中,它比 StringBuffer 要快。
# 總結
* Object: 它是所有類的超類,祖宗類。java中所有的類都直接或間接的繼承這個類
- 方法
public String toString() 返回當前對象中的內容, 對于Object類默認操作來說,返回的對象的類型+@+內存地址值
public boolean equals(Object obj) 比較兩個對象內容是否相同,對于Object類默認操作來說,比較的是地址值
* String: 字符串類,字符串是常量;它們的值在創建之后不能更改
- 方法
boolean equals(Object obj) 判斷兩個字符串中的內容是否相同
boolean equalsIgnoreCase(String str) 判斷兩個字符串中的內容是否相同, 忽略大小寫
boolean contains(String str) 判斷該字符串中 是否包含給定的字符串
boolean startsWith(String str) 判斷該字符串 是否以給定的字符串開頭
boolean endsWith(String str) 判斷該字符串 是否以給定的字符串結尾
boolean isEmpty() 判斷該字符串的內容是否為空的字符串 ""
int length() 獲取該字符串的長度
char charAt(int index) 獲取該字符串中指定位置上的字符
String substring(int start) 從指定位置開始,到末尾結束,截取該字符串,返回新字符串
String substring(int start,int end) 從指定位置開始,到指定位置結束,截取該字符串,返回新字符串
int indexOf(int chr ) 獲取給定的字符,在該字符串中第一次出現的位置
int indexOf(String str) 獲取給定的字符串,在該字符串中第一次出現的位置
int indexOf(int chr,int fromIndex) 從指定位置開始,獲取給定的字符,在該字符
byte[] getBytes() 把該字符串 轉換成 字節數組
char[] toCharArray() 把該字符串 轉換成 字符數組
String replace(char old,char new) 在該字符串中,將給定的舊字符,用新字符替換
String replace(String old,String new) 在該字符串中, 將給定的舊字符串,用新字符串替換
String trim() 去除字符串兩端空格,中間的不會去除,返回一個新字符串
String toLowerCase() 把該字符串轉換成 小寫字符串
String toUpperCase() 把該字符串轉換成 大寫字符串
int indexOf(String str,int fromIndex) 從指定位置開始,獲取給定的字符串,在該字符串中第一次出現的位置
* StringBuffer/StringBuilder:
- 方法
public StringBuffer append(String str) 在原有字符串緩沖區內容基礎上,在末尾追加新數據
public StringBuffer insert(int offset,String str) 在原有字符串緩沖區內容基礎上,在指定位置插入新數據
public StringBuffer deleteCharAt(int index) 在原有字符串緩沖區內容基礎上,刪除指定位置上的字符
public StringBuffer delete(int start,int end) 在原有字符串緩沖區內容基礎上,刪除指定范圍內的多個字符
public StringBuffer replace(int start,int end,String str)在原有字符串緩沖區內容基礎上,將指定范圍內的多個字符 用給定的字符串替換
public StringBuffer reverse() 將字符串緩沖區的內容 反轉 "abc"----"cba"
public String substring(int start) 從指定位置開始,到末尾結束,截取該字符串緩沖區,返回新字符串
public String substring(int start,int end) 從指定位置開始,到指定位置結束,截取該字符串緩沖區,返回新字符串
創建一個字符串緩沖區對象。用于存儲數據。
~~~
StringBuffer sb = new StringBuffer();
sb.append("haha"); //添加字符串
sb.insert(2, "it");//在指定位置插入
sb.delete(1, 4);//刪除
sb.replace(1, 4, "cast");//替換指定范圍內的內容
String str = sb.toString();
~~~
注意:append、delete、insert、replace、reverse方法調用后,返回值都是當前對象自己,所以說,StringBuffer它可以改變字符序列的長度和內容
- 基礎
- 編譯和安裝
- scanner類(鍵盤錄入)
- Random類(隨機數)
- 數組
- 方法
- 類
- ArrayList集合
- char與int
- eclipse
- IDEA
- 變量與常量
- 常用API
- String,StringBuffer,StringBuilder
- 正則,Date,DateFormat,Calendar
- 包裝類,System,Math,Arrays,BigInteger,BigDecimal
- 集合,迭代器,增強for,泛型
- List,set,判斷集合唯一
- map,Entry,HashMap,Collections
- 異常
- IO
- File
- 遞歸
- 字節流
- 字符流
- IO流分類
- 轉換流
- 緩沖流
- 流的操作規律
- properties
- 序列化流與反序列化流
- 打印流
- commons-IO
- IO流總結
- 多線程
- 線程池
- 線程安全
- 線程同步
- 死鎖
- lock接口
- ThreadLoad
- 等待喚醒機制
- 線程狀態
- jdbc
- DBUtils
- 連接池DBCP
- c3p0連接池
- 網絡編程
- 多線程socket上傳圖片
- 反射
- xml
- 設計模式
- 裝飾器模式
- web service
- tomcat
- Servlet
- response
- request
- session和cookie
- JSP
- EL
- JSTL
- 事務
- 監聽器Listener
- 過濾器Filter
- json
- linux安裝軟件
- 反射詳解
- 類加載器和注解
- 動態代理
- jedis
- Hibernate
- 簡介
- 創建映射文件
- Hibernate核心配置文件
- 事務和增刪改查
- HibernateUtils
- 持久化對象的三種狀態
- 檢索方式
- query
- Criteria
- SQLQuery
- 持久化類
- 主鍵生成策略
- 緩存
- 事務管理
- 關系映射
- 注解
- 優化
- struts2
- 搭建
- 配置詳解
- Action
- 結果跳轉方式
- 訪問ServletAPI方式
- 如何獲得參數
- OGNL表達式
- valueStack 值棧
- Interceptor攔截器
- spring
- 導包
- IOC和DI
- Bean獲取與實例化
- Bean屬性注入
- spring注解
- 注解分層
- junit整合
- aop
- 動態代理實現
- cglib代理實現
- aop名詞
- spring的aop
- aop-xml詳解
- aop-注解詳解
- 代理方式選擇
- jdbcTemplate
- spring事務管理
- 回滾注意
- 事務傳播屬性
- MyBatis
- MyBatis簡介
- 入門程序
- 與jdbc hibernate不同
- 原始Dao開發
- Mapper動態代理方式
- SqlMapConfig.xml配置文件
- 輸入參數pojo包裝類
- resultMap
- 動態sql
- 一對一關聯
- 一對多
- 整合spring
- 逆向工程
- maven
- maven簡介
- 倉庫
- maven目錄結構
- maven常用命令
- 生命周期
- eclipse中maven插件
- 入門程序
- 整合struct
- 依賴范圍
- 添加插件
- idea配置
- jar包沖突
- 分模塊開發
- 構建可執行的jar包(包含依賴jar包)
- springMVC
- 處理流程
- java面試
- java版本升級
- java1-8版本變更
- java9新特性
- 鎖
- java資料
- idea
- jdk版本切換
- log4j
- 入門實例
- 基本使用方法
- Web中使用Log4j
- spring中使用log4j
- java代碼優化