A. java7,8的幾個特性(自己的理解,大神們多指
JDK 1.7部分新特性
1)switch支持String類型 本質上是對int類型的匹配,
實現原理為:通過case後面的str對象調用hashcode()方法,得到一個int類型的hash值,然後用這個hash值來唯一標識這個case.當匹配時,首先調用這個字元串的hashcode()方法,獲得一個hash值,用這個hash值與case匹配,若沒有則不存在,若有則接著調用equals()方法進行匹配。String變數不能為null ,case後的字元串也不能為null ,否則會出現NullPointerException.
2)可以在catch中捕獲多個異常
3)對數值字面量進行了改進
增加了二進制字面量的表示 0B001 0b001
在數字中可以添加分隔符 123_456 下劃線只能用在數字中間 編譯時被去掉
4)使用泛型的時候增加了類型推斷機制
java7之前
Map<String,String> map = new HashMap<String,String>();
java7引進類型推斷後
Map<String,String> map = new HashMap<>();
5)增加了 try-with-resources語句 (聲明一個或多個資源的try語句)
資源指在使用完成後,必須關閉釋放的對象,try-with-resources語句確保在該語句執行之後關閉每個資源
try(InputStreamfis=newFileInputStrean("input.txt");){while(fis.read()!=1){
System.out.println(fis.read());
}
}catch(Exceptione){
e.printStackTrace();
}
DK 1.8 部分新特性
1)增加了Lambda表達式的支持 Lambda表達式是一個匿名函數 允許把函數作為一個方法的參數
示例
Arrays.AsList(2,8,1).forEach(i->System.out.println(i));//1
Arrays.AsList(2,8,1).forEach((Integeri)->System.out.println(i));//2
在java8以前 對於列表的排序 如果有自定義的類 則需要制定自定義的排序方法
Person[]people={newPerson("Iack",22),newPerson("Tony",35)};
Arrays.sort(people,newComparator<Person>(){//自定義排序方法new一個Conparator重寫compare方法
@Overridepublicintcompare(Persona,Personb){returna.getAge()-b.getAge();
}
});for(Personp:people){
System.out.println(p);
}
Lambda表達式
Arrays.sort(people,(Persona,Personb)->a.getAge()-b.getAge());
Arrays.sort(people,(a,b)->a.getAge()-b.getAge());
Lambda表達式是通過函數式介面實現的 (只有一個方法的普通介面)。函數式介面可以隱式的轉換為Lambda表達式,為了與普通的介面區分開,增加了註解@FunctionalInterface
@FunctionalInterfaceinterface
fun{
voidf();
}
2)介面增加了方法的默認實現和靜態方法 JDK1.8通過使用關鍵字 default可以給介面中的方法添加默認實現,此外,介面中還可以定義靜態方法。
interfaceIn8{
voidf();
defaultvoidg(){
System.out.println("default");
}
staticvoidh(){
System.out.println("static");
}
}
引入介面默認方法實現 是為了實現介面升級 在原有的設計中,如果想要升級介面,例如給介面中添加一個新的方法,會導致所有實現這個介面的類都需要被修改。
3)方法引用 方法引用指的是可以直接使用java類或對象的方法
Arrays.sort(people,Comparator.comparing(Person::getAge));
方法引用共有下面四種方式
引用構造方法 ClassName::new
引用類靜態方法 ClassName::methodName
引用特定類的任意對象方法 ClassName::methodName
引用某個對象的方法 instanceName::methodName
4)註解
JDK 1.5中引入了註解機制 但有限制 相同註解在同一位置只能聲明一次 JDK 1.8中引入了重復註解機制後,相同的註解在同一個地方可以聲明多次
擴展註解使用范圍 可以給局部變數 泛型 和方法異常等提供註解
5)加強了類型推測機制
6)參數名字 在編譯時增加 -parameters選項 以及增加反射API 與 Parameter.getName()方法實現了獲取方法參數名的功能
7)新增optional類 處理空指針
8)新增Stream類 和函數式編程統一
9)日期新特性
10)增加了調用javaScript的引擎
11)Base64 字元編碼格式 用來作為電子郵件 或webService附件的傳輸編碼
12)並行數組
更多的特性,請J對比JAVA下7以及8的JDK的相關內容
B. Java7與Java8是同一軟體嗎
JAVA7和JAVA8是JAVA的不同版本,主要是JAVA的API不同,對用戶的區別可能是有些類庫的變化,不如新增加了一些類庫,改變了一些類庫的設計,也有可能廢棄一些類庫。
C. Java 7鏈変粈涔堟柊鐗規э紵
鍑犱箮鏂規柟闈㈤潰閮芥湁閲嶅ぇ鏇存柊錛屼婦鍑犱釜璇娉曚笂鐨勬柊鐗規э紝鍏朵粬鏂歸潰寤鴻浣犲幓鏌ユ壘鐩稿叧璧勬枡銆
1銆乻witch...case鏀鎸佸瓧絎︿覆銆
2銆佹暟瀛楀瓧闈㈤噺鏀硅繘錛屽姞鍏ヤ簩榪涘埗瀛楅潰閲忚〃紺猴細濡0b001001錛堝嶮榪涘埗鏁板瓧9錛夋垨0B001001錛
鏁板瓧瀛楅潰閲忎腑鍙浠ヤ嬌鐢ㄤ笅鍒掔嚎鍒嗗壊錛屼互浣塊暱鏁板瓧渚誇簬闃呰伙紝濡100000鍙浠ュ啓鎴100_000錛屽氨濂芥瘮鐜板疄鐢熸椿涓鍐欐垚100,000渚誇簬闃呰諱竴鏍楓
3銆佷紭鍖栧紓甯稿勭悊錛孴hroable綾誨炲姞addSuppressed鍜実etSuppressed鏂規硶錛岀敤鏉ヨ板綍琚鍏朵粬寮傚父鎶戝埗鑰屾棤娉曟e父鎶涘嚭鐨勫紓甯革紱
涓涓猚atch瀛愬彞鍙浠ユ崟鑾峰氫釜寮傚父錛屾瘡涓寮傚父涔嬮棿浣跨敤鈥渱鈥濆垎鍓詫紝濡俢atch (ClassNotFoundException cnfe | IOException ioe)錛
榪樻湁鍏朵粬鐨勪竴浜涗紭鍖栵紝濡傚紓甯哥被涓鍖呭惈鏇村氫俊鎮錛岀簿紜寮傚父鎶涘嚭絳夌瓑銆
4銆丣ava 7涔嬪墠閫氬父鍦╰ry閲屽壋寤鴻祫婧愶紝finally閲屽硅祫婧愯繘琛屽叧闂絳夋搷浣滐紝Java 7涓鍙浠ヤ嬌鐢╰ry-with-resources璇鍙ワ紝鑰屼笉闇瑕佸叧蹇冭祫婧愮殑鍏抽棴錛屽傗斺
try (InputStream input = new FileInputStream("D:/test1.txt");
OutputStream output = new FileOutputStream("D:/test2.txt")) {
byte[] buffer = new byte[1024];
int len = -1;
while ((len = input.read(buffer) != -1 ) {
output.write(buffer, 0, len);
}
}
灝嗚祫婧愮殑鍒涘緩鍐欏湪try鍚庣殑鎷鍙烽噷錛岃繖鏍峰氨涓嶉渶瑕佷嬌鐢╢inally璇鍙ユ潵淇濊瘉璧勬簮鐨勬g『鍏抽棴錛岀敱鉶氭嫙鏈鴻嚜鍔ㄥ畬鎴愶紝紼嬪簭鍛樺彧闇瑕佸叧蹇冧笟鍔¢昏緫鍗沖彲銆
5銆佸叧浜庡彉闀垮弬鏁扮殑浼樺寲錛屽炲姞浜咢SafeVarargs娉ㄨВ錛孞ava 7涔嬪墠鍦ㄤ嬌鐢ㄥ彲鍙橀暱鍙傛暟鐨勬柟娉曟椂錛屽傛灉鍙傛暟浼犻掔殑鏄涓嶅彲鍏蜂綋鍖栫殑綾誨瀷錛堝傛硾鍨嬬被鍨婰ist<String>錛変細浜х敓璀﹀憡淇℃伅錛屽傛灉甯屾湜榪涘埗璇ヨ﹀憡錛岄渶瑕佷嬌鐢ˊSuppressWarnings("unchecked")娉ㄨВ榪涜屽0鏄庯紝Java 7涓錛屽傛灉寮鍙戜漢鍛樼『淇℃煇涓浣跨敤浜嗗彲鍙橀暱鍙傛暟鐨勬柟娉曞湪涓庢硾鍨嬬被涓璧蜂嬌鐢ㄦ椂涓嶄細鍑虹幇綾誨瀷瀹夊叏闂棰橈紝灝卞彲浠ヤ嬌鐢ˊSafeVarargs娉ㄨВ鏉ュ0鏄庛傛敞鎰忚ユ敞瑙e彧鑳界敤浜庡彲鍙橀暱鍙傛暟鐨勬柟娉曟垨鑰呮瀯閫犳柟娉曪紝騫朵笖鏂規硶蹇呴』澹版槑涓簊tatic鎴杅inal銆
D. java7和java8有什麼區別
8增加了一些新特性,但之前做的項目用的是7,一般不會因為8出了新特性而更換JDK。一段時間內,8不會大規模取代7。
有些項目還停留在jdk1.4或者1.5,我接觸的jdk1.6比較多,7也並不是使用優勢多大
另外,我不知道題主這問題到底想做什麼0.0