EMQ 團隊很高興正式向 IoT&5G 市場發佈開源函數編程語言 - Hamler!html
Hamler 是一門構建在 Erlang 虛擬機(VM)上的 Haskell 風格的強類型(strongly-typed)編程語言,獨特意結合了編譯時的類型檢查推導,與對運行時高併發和軟實時能力的支持。git
Hamler 編程語言將賦予行業,尤爲是 5G、IoT、雲計算和邊緣計算等潛力領域,構建下一代高可靠、可擴展、具有軟實時支持應用的能力。github
近十年來,咱們一直在開發基於 Erlang/OTP 的軟件系統,特別是咱們的核心產品可伸縮分佈式開源 MQTT 服務器 - EMQ X。咱們一直認爲 Erlang/OTP,尤爲是 Beam 虛擬機是工程學的傑做。它具備出色的併發性、分佈性和容錯性,是少數正確處理高併發和軟實時的通用語言平臺,是最適合開發 IoT 和 5G 應用的平臺之一。編程
從多年開發 Erlang 程序經驗來看,咱們一直期待解決兩個問題:編譯時類型系統與更友好的程序語法。編譯時強大的類型系統有助於咱們構建更可靠的軟件系統;更友好的語法有助於咱們建立一個繁榮的開發者社區。服務器
爲此學術界和產業界付出了近 20 年的努力。首先是 Philip Wadler 教授和 Simon Marlow 在 2000 年先後,爲 Erlang 引入了類型標註和 Dialyzer 靜態類型檢查工具。閉包
2008 年後,產業界有近 20 個項目,不斷地嘗試解決類型系統和友好語法的問題。elixir 項目引入了 Ruby 語法,吸引了部分 Ruby On Rails 社區開發者,卻沒有類型系統支持。Akka 項目在 JVM 上模擬實現了 Erlang/OTP ,但喪失了 Erlang/OTP 的軟實時特性。Well-Typed 公司的 Cloud Haskell 項目試圖在 Haskell 上模擬實現 Erlang/OTP,目前項目已經停滯。此外還有 lfe 引入了 Lisp 語法,alpaca、efene、elchemy、gleam 等項目試圖引入 ML 風格語法和靜態類型,目前大部分仍處於很早期的開發中。架構
今天,EMQ 團隊作出努力,採用新的語言架構設計方式再一次嘗試解決上述問題,正式向業界發佈 Hamler 語言 0.1 版本!併發
Hamler 做爲運行在 Erlang VM 上的類 Haskell 語法的編程語言,核心特性能夠歸納爲:app
結合咱們多年對函數式編程的理解與開發 Erlang、Haskell 程序的經驗,Hamler 語言支持函數編程大部分主要特性,咱們相信這些特性能夠幫助產業更好地迎接 5G、IoT 、邊緣計算與雲計算帶來的開發浪潮,並吸引更多的開發者使用 Erlang VM - BEAM。dom
Hamler 源碼通過詞法分析後生成 CST,而後通過 CST -> AST -> CoreFn 的語法樹變換、語法分析與類型檢查後,生成 CoreErlang 的 IR 代碼,而後由 Erlang 編譯器生成最終的二進制 Beam 文件。
Hamler 編譯器架構以下圖:
Hamler 0.1 編譯器最初嘗試基於 GHC 8.10.1 實現,後改成基於 Purescript 0.13.6 實現。
Hamler 函數編程語言從發起便是一個開源項目,目前核心開發者主要來自 EMQ 公司研發團隊:
Hamler 開源項目最終將與合做夥伴一塊兒,貢獻給歐盟 2049 開放源碼基金會 - 2049.Foundation。
EMQ - 杭州映雲科技有限公司致力於成爲全球領先的消息與流處理開源軟件企業,聚焦服務於新產業週期的 5G&IoT、邊緣計算(Edge)與雲計算(Cloud)市場。EMQ 研發團隊主要採用 Erlang、Haskell 等函數編程語言,開發高併發、高可靠、軟實時的大規模分佈式系統。
招聘職位:拉勾,或聯繫HR:hr@emqx.io
版權聲明: 本文爲 EMQ 原創,轉載請註明出處。
原文連接:https://www.emqx.io/cn/news/open-source-functional-programming-language-hamler