chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Go語言的開發(fā)者正著手準備開發(fā)2.0版本,程序員有太多話要說

DPVg_AI_era ? 來源:未知 ? 作者:李倩 ? 2018-08-31 09:04 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

Go 2.0預(yù)計公布,在今天HackerNews引發(fā)眾多討論,眾多Bug即將填補,設(shè)計草案搶先預(yù)覽。

Go語言的開發(fā)者正著手準備開發(fā)2.0版本,并從以下三個方面發(fā)布了初步的設(shè)計方案(非官方正式版),以供社區(qū)開展討論:

泛型(generics)

錯誤處理(error handling)

錯誤值語義(error value semantics)

Go 2.0的總體目標是解決無法擴展到大型代碼庫以及無法滿足大型項目開發(fā)人員需求等問題。

泛型

改進目標

想必大多數(shù)用戶都對Go語言的泛型會表示無奈,很多網(wǎng)友甚至?xí)f“根本就沒有泛型支持”。

Go 2.0的目標是通過允許帶有類型參數(shù)的參數(shù)多態(tài)(parametric polymorphism)來解決編寫Go庫的問題。

除了預(yù)期的容器類型之外,還希望能夠編寫有意義的庫來操作任意的map和channel值,并理想地編寫能夠同時操作[ ]byte和string值的多態(tài)函數(shù)。

Go的泛型必須明確記錄對類型參數(shù)的約束,作為調(diào)用者和實現(xiàn)之間明確的強制協(xié)議。當調(diào)用者不滿足這些約束或?qū)崿F(xiàn)超出限制時,編譯器需將錯誤清楚地報告出來。

Go中的多態(tài)性應(yīng)該在編譯和運行時都可以實現(xiàn),這樣,有關(guān)實現(xiàn)策略的決策就可以留給編譯器來決定。這種靈活性將解決Go目前存在的一些難題。

草案設(shè)計

設(shè)計草案添加了一個新的語法,用于在類型或函數(shù)聲明中引入類型參數(shù)列表,例如:

1typeList(typeT)[]T23funcKeys(typeK,V)(mmap[K]V)[]K4

參數(shù)化聲明的使用,采用普通調(diào)用語法來提供類型參數(shù):

1varintsList(int)23keys:=Keys(int,string)(map[int]string{1:"one",2:"two"})

這些示例中的概括不需要T,K和V類型:任何類型都可以。 通常,實現(xiàn)可能需要約束可以使用的類型。例如,我們可能想要定義一個Set(T),以列表或映射的形式實現(xiàn),在這種情況下,類型T的值必須能夠進行相等的比較。為了表達這一點,設(shè)計草案引入了contract的概念。contract就像一個函數(shù)體,說明了類型必須支持的操作。例如,要聲明類型T的值必須是可比較的:

1contractEqual(tT){2t==t3}

錯誤處理

改進目標

Go 語言的錯誤處理是基于明確的目的而設(shè)計的。用戶應(yīng)該從函數(shù)中返回所有可能的錯誤,并且檢查/處理這些返回值。和其他語言相比,這一點可能看起來有些繁瑣和不人性化。

Go 2希望錯誤檢查更加輕量級,減少用于錯誤檢查的Go程序文本的數(shù)量。

還希望使編寫錯誤處理變得更方便,從而提高程序員花時間處理錯誤的可能性。

且錯誤檢查和錯誤處理必須保持顯式,即在程序文本中可見。

草案設(shè)計

草案設(shè)計引入了兩種新的句法形式。

首先,它引入一個檢查表達式來檢查f(x, y, z)或檢查err,并標記一個顯式錯誤檢查。

其次,它引入了一個定義錯誤處理程序的handle語句。當錯誤檢查失敗時,它將控制轉(zhuǎn)移到最內(nèi)層處理程序,該處理程序?qū)⒖刂妻D(zhuǎn)移到它上面的下一個處理程序,以此類推,直到處理程序執(zhí)行返回語句為止。例如:

1funcCopyFile(src,dststring)error{ 2handleerr{ 3returnfmt.Errorf("copy%s%s:%v",src,dst,err) 4} 5 6r:=checkos.Open(src) 7deferr.Close() 8 9w:=checkos.Create(dst)10handleerr{11w.Close()12os.Remove(dst)//(onlyifacheckfails)13}1415checkio.Copy(w,r)16checkw.Close()17returnnil18}

在不返回錯誤的函數(shù)中允許check/handle組合。例如,一下是一個有用卻很簡單的程序功能:

1funcmain(){ 2hex,err:=ioutil.ReadAll(os.Stdin) 3iferr!=nil{ 4log.Fatal(err) 5} 6 7data,err:=parseHexdump(string(hex)) 8iferr!=nil{ 9log.Fatal(err)10}1112os.Stdout.Write(data)13}

這么寫會更簡單、清晰:

1funcmain(){2handleerr{3log.Fatal(err)4}56hex:=checkioutil.ReadAll(os.Stdin)7data:=checkparseHexdump(string(hex))8os.Stdout.Write(data)9}

錯誤值語義

改進目標

也許用戶對于Go的程序化的err有許多問題:這是一個RPCError嗎?這是net.OpError嗎?它適應(yīng)net.Error的接口嗎?這是os.PathError嗎?

對于錯誤值,第一個問題,就是很難回答上述那些疑問。函數(shù)os.IsExist,os.IsNotExist,os.IsPermission和os.IsTimeout是主要問題。它們在通用性方面有兩個缺陷:每個函數(shù)僅測試一種特定類型的錯誤,第二,每個函數(shù)只能理解非常有限數(shù)量的包類型。

第二個問題看似沒什么,卻也很重要:深度嵌套錯誤(nested error)的報告太難以閱讀,并且沒有留給額外的細節(jié)空間,比如程序中的相關(guān)文件位置。

針對上述存在的兩個問題,Go 2首先希望能讓程序的錯誤檢查更容易,更不容易出錯,以提高實際程序的錯誤處理和魯棒性。其次,希望能夠以標準格式打印帶有附加細節(jié)的錯誤。

草案設(shè)計

這里有兩個主要問題:錯誤檢查和錯誤格式化,分別用兩個不同的方案解決。需要保持與現(xiàn)有代碼的互操作性,并允許包繼續(xù)定義自身的錯誤類型的約束,指向定義錯誤實現(xiàn)可以滿足的可選界面。

錯誤檢查(Error inspection)

對于錯誤檢查,設(shè)計草案遵循現(xiàn)有包(如github.com/pkg/errors)的規(guī)則,并為錯誤定義了一個可選接口,以返回錯誤包裝鏈中的下一個錯誤:

1packageerrors23typeWrapperinterface{4Unwrap()error5}

例如,上面假設(shè)的WriteError需要:

1func(e*WriteError)Unwrap()error{returne.Err}

利用這種方法,方案設(shè)計中添加了兩個新函數(shù)對錯誤打包:

1//Isreportswhethererroranyoftheerrorsinitschainisequaltotarget.2funcIs(err,targeterror)bool34//AscheckswhethererroranyoftheerrorsinitschainisavalueoftypeE.5//Ifso,itreturnsthediscoveredvalueoftypeE,withoksettotrue.6//Ifnot,itreturnsthezerovalueoftypeE,withoksettofalse.7funcAs(typeE)(errerror)(eE,okbool)8

錯誤格式(Error formatting)

對于錯誤格式,設(shè)計草案定義了根據(jù)錯誤來實現(xiàn)的可選接口:

1packageerrors23typeFormatterinterface{4Format(pPrinter)(nexterror)5}

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 編譯器
    +關(guān)注

    關(guān)注

    1

    文章

    1672

    瀏覽量

    51284
  • go語言
    +關(guān)注

    關(guān)注

    1

    文章

    159

    瀏覽量

    9713

原文標題:Go 2.0發(fā)布在即,程序員有太多話要說

文章出處:【微信號:AI_era,微信公眾號:新智元】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    2025華為開發(fā)者大賽暨開發(fā)者年度會議成功舉辦

    12月27日-12月28日,以“成就AI原生時代先鋒開發(fā)者”為主題的2025華為開發(fā)者大賽暨開發(fā)者年度會議在上海華為練秋湖研發(fā)中心舉辦。本次會議旨在匯聚先鋒開發(fā)力量,搭建開放共贏的生態(tài)
    的頭像 發(fā)表于 12-31 13:32 ?429次閱讀

    大理的AI野心藏不住了——風(fēng)花雪月中千名程序員探討人工智能

    2025 年12月4日至6日第二屆CCF程序員大會暨大理人工智能與應(yīng)用國際開發(fā)者大會在大理圓滿落幕。
    的頭像 發(fā)表于 12-24 17:45 ?609次閱讀
    大理的AI野心藏不住了——風(fēng)花雪月中千名<b class='flag-5'>程序員</b>探討人工智能

    程序員最常見謊言

    了。 28我已經(jīng)測試過了,這個功能沒問題,可以上線了。 29別擔(dān)心,這個問題很快就能解決。 30代碼快寫完了,已經(jīng)完成 90% 了 。 希望大家對程序員多一些容忍以及諒解! 各位程序員你們都被我說中了哪些?說說你們的觀點
    發(fā)表于 12-10 08:24

    2025開源鴻蒙開發(fā)者激勵計劃正式啟動

    11月21日,2025開放原子開發(fā)者大會盛大啟幕,聚焦“AI共智,開源共享”主題,吸引了來自全球的開發(fā)者、企業(yè)技術(shù)領(lǐng)袖、社區(qū)維護及高??蒲辛α繀W鳛榇髸闹匾M成部分,開源鴻蒙技術(shù)分論壇同期
    的頭像 發(fā)表于 11-27 14:44 ?597次閱讀

    奔赴熱AI,碼力全開!Talkweb House@1024程序員日系列活動圓滿收官

    1024程序員日”系列活動至此劃上了一個圓滿句號。本屆1024程序員節(jié)以“AI構(gòu)建世界,智能引領(lǐng)未來”為主題,廣邀技術(shù)大咖、產(chǎn)業(yè)領(lǐng)袖、企業(yè)代表與全球開發(fā)者齊聚星城
    的頭像 發(fā)表于 10-27 18:59 ?699次閱讀
    奔赴熱AI,碼力全開!Talkweb House@1024<b class='flag-5'>程序員</b>日系列活動圓滿收官

    2025開放原子開發(fā)者大會11月啟幕

    開發(fā)者年度盛會即將登場!2025開放原子開發(fā)者大會將于11月21-22日,在北京北人亦創(chuàng)國際會展中心盛大召開。大會以“一切為了開發(fā)者”為主題,匯聚全球開源智慧——國內(nèi)外優(yōu)秀開發(fā)者、學(xué)術(shù)
    的頭像 發(fā)表于 10-24 14:05 ?908次閱讀

    NVIDIA DRIVE AGX Thor開發(fā)者套件重磅發(fā)布

    這款由 NVIDIA DriveOS 7 驅(qū)動的開發(fā)者套件能夠幫助開發(fā)者們打造出更安全的智能汽車和交通解決方案。
    的頭像 發(fā)表于 09-04 11:20 ?1263次閱讀

    曙光網(wǎng)絡(luò)SugonRI開發(fā)者社區(qū)正式上線

    在人工智能與工業(yè)深度融合的大潮中,工業(yè)軟件正在成為推動產(chǎn)業(yè)升級的關(guān)鍵引擎。為了讓更多開發(fā)者快速掌握工業(yè)級編程技術(shù)、共享行業(yè)實踐成果,曙光網(wǎng)絡(luò)正式推出開發(fā)者社區(qū)——曙睿(SugonRI)開發(fā)者網(wǎng)站
    的頭像 發(fā)表于 09-04 09:58 ?882次閱讀

    NVIDIA Jetson AGX Thor開發(fā)者套件重磅發(fā)布

    開發(fā)者與未來創(chuàng)造們,準備好迎接邊緣AI的史詩級革新了嗎?NVIDIA以顛覆性技術(shù)再次突破極限,正式推出Jetson AGX Thor開發(fā)者套件!作為繼傳奇產(chǎn)品Jetson AGX O
    的頭像 發(fā)表于 08-28 14:31 ?1438次閱讀

    【HZ-T536開發(fā)板免費體驗】2 - 交叉編譯倉頡編程語言程序開發(fā)板運行

    對現(xiàn)代語言特性的集成、全方位的編譯優(yōu)化與運行時實現(xiàn),以及 IDE 工具鏈支持,為開發(fā)者締造友好的開發(fā)體驗和卓越的程序性能,便于開發(fā)者高效地完
    發(fā)表于 07-16 21:27

    匠芯創(chuàng)發(fā)布新版GUI開發(fā)工具 新增多國語言設(shè)置等功能

    、播放暫停、循環(huán)播放以及控制面板呼出等功能,為開發(fā)者在多媒體應(yīng)用開發(fā)方面提供了有力支持。 AiUIBuilder自2024年推出以來,憑借其強大的功能和易用性,受到了眾多開發(fā)者的青睞。V1.3.0
    發(fā)表于 07-16 13:54

    HDC 2025開發(fā)者主題演講精彩回顧

    日前,華為開發(fā)者大會(HDC 2025)進入第二天,行業(yè)領(lǐng)袖、技術(shù)專家、全球開發(fā)者齊聚現(xiàn)場,共同見證這場科技盛會。在開發(fā)者主題演講中,華為技術(shù)專家深入解析HarmonyOS的最新技術(shù)、體驗創(chuàng)新以及
    的頭像 發(fā)表于 07-09 11:20 ?1231次閱讀

    全志科技亮相OpenHarmony開發(fā)者大會2025

    近日,OpenHarmony開發(fā)者大會 2025(OHDC.2025,以下簡稱“大會”)在深圳舉辦。大會正式發(fā)布了開源鴻蒙5.1 Release版本,舉行了“開源鴻蒙應(yīng)用技術(shù)組件共建啟動、開源鴻蒙
    的頭像 發(fā)表于 06-04 09:16 ?2114次閱讀
    全志科技亮相OpenHarmony<b class='flag-5'>開發(fā)者</b>大會2025

    Java開發(fā)者必備的效率工具——Perforce JRebel是什么?為什么很多Java開發(fā)者在用?

    Perforce JRebel是一款Java開發(fā)效率工具,旨在幫助java開發(fā)人員更快地編寫更好的應(yīng)用程序。JRebel可即時重新加載對代碼的修改,無需重啟或重新部署應(yīng)用程序,就能讓
    的頭像 發(fā)表于 04-27 13:44 ?760次閱讀
    Java<b class='flag-5'>開發(fā)者</b>必備的效率工具——Perforce JRebel是什么?為什么很多Java<b class='flag-5'>開發(fā)者</b>在用?

    為何嵌入式開發(fā)者覺得 MCU 開發(fā)無趣,更傾向 MPU(Linux)?

    咱嵌入式圈子里,最近老能聽見有人念叨:“搞 MCU 開發(fā)越來越?jīng)]勁兒了,不如轉(zhuǎn) MPU(Linux)有意思?!?作為在這行摸爬滾打二十多年的老兵,我也算看明白了 —— 這事兒就像程序員從寫單片機裸機
    的頭像 發(fā)表于 04-25 10:48 ?752次閱讀
    為何嵌入式<b class='flag-5'>開發(fā)者</b>覺得 MCU <b class='flag-5'>開發(fā)</b>無趣,更傾向 MPU(Linux)?