RIL.java【2】

1.

synchronized
(sPoolSync
) {

------------------------------------------------------
Java 的同步機制:
Java的同步分同步方法和同步語句塊,無論何種同步,其加鎖的對象都是一個對象。

同步方法:
其加鎖對象是該方法所屬的類的實例,和
synchronized (this)具有同樣的效果,例如類A有兩個對象a1和a2,其中有一個同步方法func1:

class A{
synchronized void func1(){
dosomething...
}
}

A a1,a2;

當線程1中調用a1訪問方法func1時,線程2中調用a1訪問方法func1將會被阻塞,而如果在線程2中調用a2來訪問func1則不會阻塞。

同步語句塊:
void func()
{
private byte[] lock = new byte[0];
synchronized (lock){
dosomething
}
}
同步語句塊的作用是隻有在拿到了該同步鎖後才能執行其語句塊。

2.
static RILRequest obtain (int request , Message result ) {
----------------------------------------------------------------------------------
通常在需要高效率處理的地方我們可以使用內存池來優化我們的程序,其中最常用的方法就是使用鏈表是內存池,每次需要創建對象時,首先從
已經分配的對象鏈表中查找,如果有空閒的對象,則直接返回該對象,如果沒有則創建一個新的對象,並將該對象加入到內存池鏈表中,同時
在程序使用完該對象時應釋放該對象回內存池供下次使用。

3.
StringBuilder sb = new StringBuilder (8 );
---------------------------------------------------------
String,StringBuffer,StringBuilder的區別:
String是一個不可變對象,在對String對象進行修改時實際上相當於重新創建了一個String對象,因此對於經常變化的字符串最好不要使用
String來操作。
StringBuffer是一個可變的對象,在對其字符串修改時是直接修改其內容,不會創建新的對象,因此大部分情況下我們應該使用StringBuffer,
同時StringBuffer是線程安全的。
StringBuilder與StringBuffer類似,但不是線程安全的,只是其速度快些,所以如果能確保只有一個線程使用的,字符串又需要經常修改的
話最好用StringBuilder.

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章