Java支持漢字作為classname
char
可以存儲漢字String 是java中的字符串,它繼承于CharSequence。 String 是java中的字符串,它繼承于CharSequence。
CharSequence
與String
都能用于定義字符串,但CharSequence
的值是可讀可寫序列,而String
的值是只讀序列(待確定)Integer
Integer使用了一個靜態內部類(嵌套類),里面包含了一個 緩存數組cache[],默認情況下,[-128, 127]之間的整數會在第一次使用時(類加載時)被自動裝箱,放在cache[]數組里。區間的上限值high設置JVM參數-XX:AutoBoxCacheMax來改變,默認情況下參數為127(byte類型的范圍),存儲在java.lang.Integer.IntegerCache.high屬性中。
使用Integer.valueOf()進行構造時,就使用了cache[]緩存數組
Integer 之間比較最好不要用 == 。
- ? 通配符類型
<? extends T> 表示類型的上界,表示參數化類型的可能是T 或是 T的子類
<? super T> 表示類型下界(Java Core中叫超類型限定),表示參數化類型是此類型的超類型(父類型),直至Object
- map 的遍歷
Map<Integer, Integer> map = new HashMap<Integer, Integer>();
for (Map.Entry<Integer, Integer> entry : map.entrySet()) {
System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());
}
- (1)final 方法:不允許該類復寫(指該方法不可被繼承成員重新定義);允許編輯器將對此方法的調用轉換為inline調用機制。
內聯不一定好,當被指定為內聯的方法體很大時,展開的開銷可能就已經超過了普通函數調用調用的時間,引入了內聯反而降低了性能,因為在選擇這個關鍵字應該慎重些,不過,在以后高版本的JVM中,在處理內聯時做出了優化,它會根據方法的規模來確定是否展開調用。
(2)使用final是所謂的安全發布(safe publication)的一種方式: 如果一個對象將會在多個線程中訪問并且你并沒有將其成員聲明為final,則必須提供其他方式保證線程安全
“其他方式”可以包括聲明成員為volatile,使用synchronized或者顯式Lock控制所有該成員的訪問。
當構造函數結束時,final類型的值是被保證其他線程訪問該對象時,它們的值是可見的(當聲明一個final成員時,必須在構造函數退出前設置它的值)
final類型的成員變量的值,包括那些用final引用指向的collections的對象,是讀線程安全而無需使用synchronization的
不可變對象(指所有的成員都是final并且成員要么是基本類型,要么指向另一個不可變對象)可以并發訪問而無需使用同步機制。通過final引用讀取“實際不可變”對象(指成員雖然實際并不是final,然而卻從不會改變)也是安全的。
參考:http://www.cnblogs.com/mianlaoshu/articles/3648403.html
- 在多線程中使用同步容器,如果使用Iterator迭代容器或使用使用for-each遍歷容器,在迭代過程中修改容器會拋出ConcurrentModificationException異常。想要避免出現ConcurrentModificationException,就必須在迭代過程持有容器的鎖。但是若容器較大,則迭代的時間也會較長。那么需要訪問該容器的其他線程將會長時間等待。從而會極大降低性能。----這也是同步容器的缺點,因此發展出并發容器
隱式迭代的情況,如toString,hashCode,equalse,containsAll,removeAll,retainAll等方法都會隱式的Iterate,也可能拋出ConcurrentModificationException。
- try catch finally :return
(1)有finally語句,這在return之后還會執行finally(return的值會暫存在棧里面,等待finally執行后再返回)
可行的做法有四:
1.return語句只在函數最后出現一次。
2.return語句僅在try和catch里面都出現。
3.return語句僅在try和函數的最后都出現。
4.return語句僅在catch和函數的最后都出現。
注意,除此之外的其他做法都是不可行的,編譯器會報錯。
示例
public class ReturnTest {
public static int func(int arg){
int i = 0;
try {
System.out.println("in try……");
i = 1000 / arg ;
//return i ;
}catch (Exception e){
e.printStackTrace();
System.out.println("in catching ……");
return 1000;
}finally {
System.out.println("in finally ……");
// return 10000;
}
return i;
}
public static void main(String[] args){
System.out.println(ReturnTest.func(0));
}
}
- finalize
finalize()的功能 : 一旦垃圾回收器準備釋放對象所占的內存空間, 如果對象覆蓋了finalize()并且函數體內不能是空的, 就會首先調用對象的finalize(), 然后在下一次垃圾回收動作發生的時候真正收回對象所占的空間.
在Java中,如果內存總是充足的,那么垃圾回收可能永遠不會進行,也就是說filalize()可能永遠不被執行
,顯然指望它做收尾工作是靠不住的。
那么finalize()究竟是做什么的呢?它最主要的用途是回收特殊渠道申請的內存
。Java程序有垃圾回收器,所以一般情況下內存問題不用程序員操心。但有一種JNI(Java Native Interface)調用non-Java程序(C或C++),finalize()的工作就是回收這部分的內存。
參考:1
CountDownLatch : 一個線程(或者多個), 等待另外N個線程完成某個事情之后才能執行。
CyclicBarrier : N個線程相互等待,任何一個線程完成之前,所有的線程都必須等待。
這樣應該就清楚一點了,對于CountDownLatch來說,重點是那個“一個線程”, 是它在等待, 而另外那N的線程在把“某個事情”做完之后可以繼續等待,可以終止。而對于CyclicBarrier來說,重點是那N個線程,他們之間任何一個沒有完成,所有的線程都必須等待。