成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

Java 10新特性:類(lèi)型推斷

afishhhhh / 3527人閱讀

摘要:實(shí)際上并未引入太多新特性,不過(guò)有一個(gè)新特性最引人注目等了這么久終于支持類(lèi)型推斷了,那么今天就來(lái)看一看的類(lèi)型推斷,和其他語(yǔ)言相比有哪些異同吧。本次更新也支持了類(lèi)型推斷,對(duì)于這種重量級(jí)語(yǔ)言來(lái)說(shuō)還是一件值得高興的事。

0x01 Java 10簡(jiǎn)介

自從有了校內(nèi)的下載網(wǎng)站,很少上Oracle官網(wǎng)下載JDK了,結(jié)果前兩天聽(tīng)鐘神說(shuō)Java 10都出來(lái)了2333。干IT這行還真是要與時(shí)俱進(jìn)啊,那就來(lái)看一下Java 10吧。

Java 10實(shí)際上并未引入太多新特性,不過(guò)有一個(gè)新特性最引人注目:

JEP 286: Local-Variable Type Inference

等了這么久Java終于支持類(lèi)型推斷了,那么今天就來(lái)看一看Java 10的類(lèi)型推斷,和其他語(yǔ)言相比有哪些異同吧。

0x02 類(lèi)型推斷概述

類(lèi)型推斷是新型的高級(jí)語(yǔ)言提供的一類(lèi)功能,允許根據(jù)編譯上下文來(lái)推斷變量的類(lèi)型,不需要自己手動(dòng)寫(xiě)類(lèi)型,使得代碼更加簡(jiǎn)潔。

目前我接觸的編程語(yǔ)言中,JavaScript、Swift和Python都支持這種語(yǔ)法。本次Java 10更新也支持了類(lèi)型推斷,對(duì)于Java這種重量級(jí)語(yǔ)言來(lái)說(shuō)還是一件值得高興的事。

0x03 體驗(yàn)Java 10的類(lèi)型推斷功能

讓我們寫(xiě)一段Base64編碼的代碼,體驗(yàn)一下Java 10的類(lèi)型推斷功能:

//Java代碼
import java.util.Base64;
class Untitled {
    public static void main(String[] args) {
        var b64encoder = Base64.getEncoder();
        var encodeString = b64encoder.encodeToString("Hello World".getBytes());
        System.out.println(encodeString);
    }
}

初步體驗(yàn)還是不錯(cuò)的,只是我的IDE還沒(méi)有升級(jí),還不支持自動(dòng)提示這種語(yǔ)法。甚至Eclipse還不能正常編譯Java 10的代碼,我只能手動(dòng)通過(guò)javac來(lái)編譯。整體而言Java 10的類(lèi)型推斷功能是類(lèi)似于Swift/JavaScript的,需要寫(xiě)var關(guān)鍵字,并不像是Python那樣的使用方式。

0x04 Java 10類(lèi)型推斷的不足

上面的用法看起來(lái)很友好,那么有沒(méi)有更自由的寫(xiě)法呢?很快的我就收到了編譯器錯(cuò)誤:

//Java代碼
import java.util.Base64;
class Untitled {
    public static void main(String[] args) {
        var b64encoder = Base64.getEncoder();
        var encodeString = b64encoder.encodeToString("Hello World".getBytes());
        System.out.println(encodeString);
        var a = 1,b = 2;
    }
}
錯(cuò)誤: "var" 不允許在復(fù)合聲明中使用
        var a = 1,b = 2;
            ^
1 個(gè)錯(cuò)誤

看來(lái)Java 10的類(lèi)型推斷還是有諸多限制和不便,不像其他語(yǔ)言那般好用,對(duì)比一下Swift語(yǔ)言:

//Swift代碼
import Foundation
let string = "Hello World"
let data = string.data(using: String.Encoding.utf8)!
let encodeString = data.base64EncodedString()
print(encodeString)
var a = 1, b = 2;

比如說(shuō)Java 10并沒(méi)有let關(guān)鍵字,也就是說(shuō),并不能快速的使用類(lèi)型推斷定義常量。同時(shí)也不能一次用var定義多個(gè)變量,當(dāng)同類(lèi)型變量較多的時(shí)候,我覺(jué)得還不如把類(lèi)型寫(xiě)出來(lái)。

同時(shí),根據(jù)官方的說(shuō)明,你也不能將var用于成員變量,只能用于局部變量,例如下面的例子會(huì)出現(xiàn)編譯錯(cuò)誤:

//Java代碼
import java.util.Base64;
class Untitled {
    class Student {
        var name = "";
        Student(String name) {
            this.name = name;
        }
    }
    
    public static void main(String[] args) {
        var b64encoder = Base64.getEncoder();
        var encodeString = b64encoder.encodeToString("Hello World".getBytes());
        System.out.println(encodeString);
    }
}
錯(cuò)誤: 此處不允許使用 "var"
        var name = "";
        ^
1 個(gè)錯(cuò)誤

而在其他語(yǔ)言中,你可以更自由的使用var,在任何你想要的地方,只要不引起歧義:

//Swift代碼
import Foundation
class Student {
    var name = "";
    init(name: String) {
        self.name = name;
    }
}
var string = "Hello World"
let data = string.data(using: String.Encoding.utf8)!
let encodeString = data.base64EncodedString()
print(encodeString)

作為對(duì)比,Swift比Java 10在類(lèi)型推斷方面更加靈活,同時(shí)二者也有共同點(diǎn)——它們都是強(qiáng)類(lèi)型語(yǔ)言,任何變量必須具有某種類(lèi)型,所謂的類(lèi)型推斷只是一種語(yǔ)法上的精簡(jiǎn)。例如你不能像Python一樣在形參列表中也不使用參數(shù)類(lèi)型,或者直接省略返回值類(lèi)型,這些類(lèi)型還都是必須的:

#Python代碼
def printNumber(num):
    print(num)
    return 1

retCode = printNumber(4)
print(retCode)
//Swift代碼
func printNumber(num: Int) -> Int {
    print(num)
    return 1
}
let retCode = printNumber(num: 2)
print(retCode)
//Java代碼
import java.util.Base64;
class Untitled {
    public static int printNumber(int num) {
        System.out.println(num);
        return 1;
    }
    public static void main(String[] args) {
        var retCode = printNumber(3);
        System.out.println(retCode);
    }
}
0x05 總結(jié)

經(jīng)過(guò)簡(jiǎn)單的體驗(yàn),基本清楚了Java 10的類(lèi)型推斷功能。以后在局部范圍定義對(duì)象,可以有了更簡(jiǎn)略的寫(xiě)法:

//Before Java 9
MessageDigest md = MessageDigest.getInstance("SHA-512");
//Java 10
var md = MessageDigest.getInstance("SHA-512");

顯然這種代碼不兼容早期版本的Java,即使你將Java 10的代碼編譯為字節(jié)碼,也不能在低版本的JVM上運(yùn)行。這種新語(yǔ)法也不能用于Android開(kāi)發(fā)等用途。比如我使用OpenJDK 1.8來(lái)測(cè)試我們前面編碼base64的代碼,就出現(xiàn)了異常:

$ java -version
java version "10" 2018-03-20
Java(TM) SE Runtime Environment 18.3 (build 10+46)
Java HotSpot(TM) 64-Bit Server VM 18.3 (build 10+46, mixed mode)
$ java Main
SGVsbG8gV29ybGQ=
# java -version
openjdk version "1.8.0_111"
OpenJDK Runtime Environment (IcedTea 3.2.0) (suse-33.1-x86_64)
OpenJDK 64-Bit Server VM (build 25.111-b14, mixed mode)
# java Main
Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.UnsupportedClassVersionError: Main has been compiled by a more recent version of the Java Runtime (class file version 54.0), this version of the Java Runtime only recognizes class file versions up to 52.0
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:763)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:467)
    at java.net.URLClassLoader.access$100(URLClassLoader.java:73)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:368)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:362)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:361)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:495)

所以說(shuō)這種新語(yǔ)法還是不夠靈活,同時(shí)兼容性也堪憂(yōu),但是聊勝于無(wú)。同時(shí)也會(huì)一定程度上減少Java代碼的長(zhǎng)度,讓編程更加優(yōu)雅一些。同學(xué)們?nèi)绻塍w驗(yàn)一下新語(yǔ)法,可以升級(jí)到Java 10,不過(guò)好多Java應(yīng)用都不兼容,所以升級(jí)還是需慎重啊!

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/71177.html

相關(guān)文章

  • Java 10 特性解密,引入類(lèi)型推斷機(jī)制,2018 年 3 月 20 日發(fā)布

    摘要:目標(biāo)發(fā)布目前有兩個(gè)主要功能針對(duì)局部變量類(lèi)型推斷這將刪除大部分對(duì)象實(shí)例化所需的冗長(zhǎng)的包含手動(dòng)類(lèi)型信息整合源樹(shù)的庫(kù)即不同的庫(kù)將被合并成一個(gè)單一的存儲(chǔ)庫(kù)。特別是,承諾為局部變量實(shí)例化引入類(lèi)型推斷機(jī)制,并將現(xiàn)有的存儲(chǔ)庫(kù)合并到一個(gè)存儲(chǔ)庫(kù)中。 JDK 10 何時(shí)發(fā)布? JDK 10 是 Java 10 標(biāo)準(zhǔn)版的部分實(shí)現(xiàn),將于 2018 年 3 月 20 日發(fā)布,改進(jìn)的關(guān)鍵點(diǎn)包括一個(gè)本地類(lèi)型推斷、一...

    caspar 評(píng)論0 收藏0
  • Java 1010個(gè)特性,將徹底改變你寫(xiě)代碼的方式!

    摘要:的新特性說(shuō)了這么多,看都會(huì)有哪些特性來(lái)改變我們寫(xiě)代碼的方式呢局部變量類(lèi)型推斷局部變量類(lèi)型推斷可以說(shuō)是中最值得注意的特性,這是語(yǔ)言開(kāi)發(fā)人員為了簡(jiǎn)化應(yīng)用程序的編寫(xiě)而采取的又一步,如下圖所示。 showImg(https://segmentfault.com/img/remote/1460000015356980); Java 9才發(fā)布幾個(gè)月,很多玩意都沒(méi)整明白,現(xiàn)在Java 10又快要來(lái)了...

    ityouknow 評(píng)論0 收藏0
  • Java 10 實(shí)戰(zhàn)第 1 篇:局部變量類(lèi)型推斷

    摘要:就等于局部變量類(lèi)型推斷使用示例既然叫局部變量類(lèi)型推斷,以只能用在局部變量中,下面給出更多使用示例。,本次局部變量類(lèi)型推斷實(shí)戰(zhàn)文章就到這里了,后續(xù)帶來(lái)更多的的實(shí)戰(zhàn)方面的文章。 現(xiàn)在 Java 9 被遺棄了直接升級(jí)到了 Java 10,之前也發(fā)過(guò) Java 10 新特性的文章,現(xiàn)在是開(kāi)始實(shí)戰(zhàn) Java 10 的時(shí)候了。 今天要實(shí)戰(zhàn)的是 Java 10 中最重要的特性:局部變量類(lèi)型推斷,大家...

    HollisChuang 評(píng)論0 收藏0
  • Java 11 正式發(fā)布,這 8 個(gè)逆天特性教你寫(xiě)出更牛逼的代碼

    摘要:美國(guó)時(shí)間月日,正式發(fā)布了,這是據(jù)以后支持的首個(gè)長(zhǎng)期版本。加強(qiáng)是中的新特性,開(kāi)始對(duì)增加了以下個(gè)新方法。結(jié)束語(yǔ)現(xiàn)在許多人還在使用或者,不過(guò)在年初就會(huì)結(jié)束免費(fèi)更新。 美國(guó)時(shí)間 09 月 25 日,Oralce 正式發(fā)布了 Java 11,這是據(jù) Java 8 以后支持的首個(gè)長(zhǎng)期版本。 為什么說(shuō)是長(zhǎng)期版本,看下面的官方發(fā)布的支持路線(xiàn)圖表。 showImg(https://segmentfaul...

    AlienZHOU 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<