中文字幕 日本 在线 高清,精品久久久久久久久久久国产字幕,漂亮人妻洗澡被公强日日躁,西西4444wwww大胆视频

低代碼核心:代碼生成還是模型解釋?(低代碼原理)

2020年第一屆低代碼研討會上, Jordi Cabot發(fā)表了一篇文章(或者說觀點),對比了低代碼和模型驅(qū)動開發(fā)的關(guān)系,認(rèn)為低代碼等于模型驅(qū)動開發(fā)。但實際上,不少低代碼系統(tǒng)并不是使用模型驅(qū)動的,而是采用另一個策略,即代碼生成。那這兩者區(qū)別是什么,各有什么優(yōu)勢, 本文會詳細(xì)介紹。

低代碼核心:代碼生成還是模型解釋?(低代碼原理)

關(guān)于代碼生成和模型解釋

在模型驅(qū)動開發(fā)中,代碼生成用于從更高級別的模型生成代碼,以創(chuàng)建可運行的應(yīng)用程序。讓我們考慮下面這個使用領(lǐng)域特定語言(Domain-Specific Language, DSL)創(chuàng)建的領(lǐng)域模型

Customer { Name: String; Address: String;}

如果我們想為這個小模型生成Java代碼,我們可以使用模板引擎。模板包含Java代碼和一些Token,這些Token將根據(jù)模型來填充。例如,我們可以為域模型中的每個實體使用模板。模板代表一個Java類,實體的名稱作為類名(例如客戶)。對于每個屬性,將生成一個私有字段。

在模型解釋的情況下,我們不會通過生成代碼的方式來從模型中創(chuàng)建一個可運行軟件應(yīng)用程序。在模型解釋中,我們會使用一個(比如)Java實現(xiàn)的通用引擎用,模型直接由這個引擎來解釋。例如,這個通用的Java程序中包含一個帶有屬性name的類Entity和一個包含該實體屬性(name-value對)的hashmap。在這種情況下,客戶實體不是由Java類表示的,而是由一個帶有屬性名稱的Entity對象表示的,該屬性name的值是Customer。這些實體對象是根據(jù)模型中的信息創(chuàng)建的。

代碼生成和模型解釋都在實踐中使用。讓我們來看看這些方法相互比較的優(yōu)勢。

低代碼核心:代碼生成還是模型解釋?(低代碼原理)

代碼生成的優(yōu)勢

與模型解釋相比,代碼生成具有以下優(yōu)點:

  • 它保護你的知識產(chǎn)權(quán):通過代碼生成,你可以為特定的客戶端生成一個應(yīng)用程序。當(dāng)使用模型解釋時,你必須給把整個運行時引擎給客戶,這樣才能實現(xiàn)整個應(yīng)用。例如,如果要構(gòu)建一個網(wǎng)站,你可以把運行網(wǎng)站所需的所有代碼給到客戶即可。而如果使用解釋器,你必須給他們整個系統(tǒng)來解釋任何可以用你的DSL描述的網(wǎng)絡(luò)應(yīng)用。當(dāng)您的產(chǎn)品有大量客戶的時候,這一點尤其重要。
  • 它可以適應(yīng)您的客戶架構(gòu):當(dāng)使用模型解釋時,您必須按照自己選擇的架構(gòu)實現(xiàn)解釋器。在代碼生成的情況下,您可以根據(jù)客戶的要求來生成代碼。
  • 生成的實現(xiàn)更容易理解:您可以查看生成的代碼并直接理解應(yīng)用程序的行為。在模型解釋的情況下,您必須理解解釋器的通用實現(xiàn)和模型的語義。
  • 容易上手:如果您已經(jīng)手工構(gòu)建了一個應(yīng)用程序,您可以開始使用代碼生成,方法是將現(xiàn)有代碼轉(zhuǎn)換為模板,并用token替換部分代碼,token將被模型信息替換。如果您為同一個領(lǐng)域構(gòu)建了多個應(yīng)用程序(例如,為不同的客戶),您可以開始分析這些應(yīng)用程序。靜態(tài)代碼(即所有應(yīng)用程序的代碼都是相同的)可以放在域框架中,只需要生成可變代碼即可(即您需要創(chuàng)建域特定語言來建??勺冃裕?。
  • 它更容易迭代:正如前面所解釋的,您可以通過將現(xiàn)有代碼轉(zhuǎn)換為代碼生成模板來開始使用代碼生成。當(dāng)然,您可以通過迭代的方式做到這一點。首先,您只生成代碼的一部分,其他部分將手動實現(xiàn),稍后,您可以擴展代碼生成器以生成代碼的更多部分。您的DSL也是如此。起初,它可以是初級的,以反映將要生成的代碼。以后,您可以通過提高抽象級別來提升領(lǐng)域?qū)I(yè)能力。
  • 編譯器為它提供了的附加的檢查能力:當(dāng)您生成代碼時,需要編譯該代碼。這個編譯步驟是一個附加的檢查,因為編譯器將檢查生成的代碼是否有錯誤。如果有解釋器,您需要在模型解釋期間自己進行這些檢查,或者您需要在建模環(huán)境和解釋器之間創(chuàng)建一個緊耦合。
  • 調(diào)試生成器本身比調(diào)試解釋器更容易:如果您需要調(diào)試解釋器,則始終需要條件斷點,因為解釋器代碼是通用的。
  • 模板的變化更容易跟蹤:代碼生成模板只是文本文件,因此變化很容易跟蹤(例如通過使用版本控制系統(tǒng))。解釋器代碼的變化也是如此,但是,這段代碼是通用的,不容易搞清楚到底發(fā)生了什么變化。

模型解釋的優(yōu)點

與代碼生成相比,模型解釋具有以下優(yōu)點:

  • 它支持快速變更:模型中的更改不需要再次代碼生成、編譯、測試和重新部署。這將縮短上線時間。
  • 它支持在運行時進行更改:因為模型在運行時可用,所以甚至可以在不停止運行應(yīng)用程序的情況下更改模型。
  • 更容易移植:解釋器原則上創(chuàng)建一個獨立于平臺的目標(biāo)來執(zhí)行模型。創(chuàng)建一個運行在多個平臺(例如多個操作系統(tǒng)、多個云平臺)上的解釋器很容易。在代碼生成的情況下,您需要確保您生成的代碼符合平臺要求。在模型解釋的情況下,解釋器是一個黑匣子,只要它能在目標(biāo)平臺上運行,如何實現(xiàn)并不重要。
  • 更容易部署:當(dāng)使用代碼生成時,您經(jīng)常會看到您需要在EclipseVisual Studio中打開生成的代碼,并構(gòu)建它來創(chuàng)建最終的應(yīng)用程序。在模型解釋的情況下,您只需啟動解釋器并將模型放入其中。代碼不再是必要的了。因此,對領(lǐng)域?qū)<襾碚f, 部署和運行應(yīng)用程序比僅僅建模要容易得多。
  • 更容易升級和縮放:更改解釋器并用相同的模型重新啟動它更容易。您不必使用更新的生成器再次生成代碼??s放也是如此:縮放應(yīng)用程序意味著初始化解釋器的更多實例,執(zhí)行相同的模型。尤其是在云環(huán)境中,這可以給你帶來優(yōu)勢。
  • 它更安全:例如,在云平臺上,你只需要上傳你的模型,就不需要訪問文件系統(tǒng)或其他系統(tǒng)資源。只有解釋器中的代碼可以訪問系統(tǒng)庫。解釋器在基礎(chǔ)設(shè)施之上提供了一個額外的層,下面的一切都被抽象掉了。這本質(zhì)上是平臺即服務(wù)(PaaS)的想法。
  • 它比代碼生成更靈活:基于模板的代碼生成是有限制的。在這種情況下,您將需要幫助文件來擴展基于模板的代碼生成的可能性。在這種情況下,解釋器可能不那么復(fù)雜,通常需要更少的代碼來完成相同的結(jié)果。
  • 在運行時調(diào)試模型:雖然模型在運行時可用,但可以通過在運行時遍歷模型來調(diào)試模型(也就是說,您可以在模型上添加斷點)。這僅適用于操作語言,而不適用于聲明性語言(在那里您需要靜態(tài)分析)。當(dāng)可以在模型級別調(diào)試時,域?qū)<铱梢哉{(diào)試自己的模型,并根據(jù)此調(diào)試調(diào)整應(yīng)用程序的功能行為。這在使用復(fù)雜的過程或狀態(tài)模型時非常有幫助。

低代碼核心:代碼生成還是模型解釋?(低代碼原理)

結(jié)論

比較這兩種方法的優(yōu)勢,我們可以得出結(jié)論,最終這完全取決于構(gòu)建和/或使用模型驅(qū)動軟件工廠的人員的領(lǐng)域、用例和技能集(或舒適性)。

當(dāng)我們討論代碼生成和模型解釋之間的區(qū)別時,很快就會帶來更多的問題:代碼生成和模型解釋之間有什么區(qū)別?這兩種方法之間的界限是什么?如果我們在生成代碼時有一個內(nèi)存文件系統(tǒng)呢?如果我們通過編譯模型的一部分來優(yōu)化我們的解釋器呢?如果解釋器為瀏覽器生成數(shù)據(jù)庫結(jié)構(gòu)和網(wǎng)絡(luò)內(nèi)容呢?

好了,今天的文章分享到這就結(jié)束了,要是喜歡的朋友,請點個關(guān)注哦!–我是簡搭(jabdp),我為自己“帶鹽”,感謝大家關(guān)注。

版權(quán)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻,該文觀點僅代表作者本人。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如發(fā)現(xiàn)本站有涉嫌抄襲侵權(quán)/違法違規(guī)的內(nèi)容, 請發(fā)送郵件至 舉報,一經(jīng)查實,本站將立刻刪除。

(0)
上一篇 2024年5月13日 上午11:06
下一篇 2024年5月13日 上午11:18

相關(guān)推薦

  • 主持100萬的科研項目

    主持100萬的科研項目 近年來,隨著科技的飛速發(fā)展,科研項目已經(jīng)成為推動科技進步的重要力量。在科技領(lǐng)域,科研項目的主持者不僅要具備深厚的專業(yè)知識和豐富的經(jīng)驗,還需要具備出色的領(lǐng)導(dǎo)能…

    科研百科 2025年3月30日
    4
  • 東莞市科研項目

    東莞市科研項目 東莞市是一個充滿活力和機遇的城市,吸引了來自世界各地的企業(yè)和人才。在這個城市中,有許多科研機構(gòu)和大學(xué),為經(jīng)濟發(fā)展和社會進步提供了強大的支持。其中,東莞市政府高度重視…

    科研百科 2025年3月19日
    5
  • 開源辦公系統(tǒng)

    開源辦公系統(tǒng):讓工作變得更加簡單高效 隨著數(shù)字化時代的到來,越來越多的公司開始采用開源辦公系統(tǒng)來簡化工作流程,提高生產(chǎn)效率,降低成本。開源辦公系統(tǒng)是指使用開源軟件和技術(shù)實現(xiàn)的辦公軟…

    科研百科 2024年10月2日
    2
  • 六年三個SaaS項目后的感觸:給客戶一個“無法拒絕”的SaaS(saas系列產(chǎn)品)

    編輯導(dǎo)語:SaaS作為一個工具類產(chǎn)品,在這幾年發(fā)展的十分迅速,不少企業(yè)都開始著手SaaS產(chǎn)品;SaaS提供商為企業(yè)搭建信息化所需要的所有網(wǎng)絡(luò)基礎(chǔ)設(shè)施及軟件、硬件運作平臺,并負(fù)責(zé)所有…

    科研百科 2024年6月11日
    51
  • 科研項目參與證明模板

    科研項目參與證明模板科研項目參與證明模板安排的科學(xué)性和專業(yè)性都很強,但研究的方法和單位相關(guān)的科學(xué)性并不全面。調(diào)查的結(jié)果一般表明,高水平研究的科學(xué)性和研究的方法和研究的科學(xué)性是科學(xué)性…

    科研百科 2024年11月26日
    1
  • 中央財政科研項目專家咨詢

    中央財政科研項目專家咨詢 近年來,中央財政科研項目的啟動和實施已經(jīng)成為國家科技創(chuàng)新的重要支撐。這些項目旨在通過資助高水平科學(xué)家和研究團隊,推動科學(xué)技術(shù)的發(fā)展和應(yīng)用,為國家的經(jīng)濟發(fā)展…

    科研百科 2024年10月8日
    3
  • 黨的體系建設(shè)報告怎么做的

    黨的體系建設(shè)報告怎么做 黨的體系建設(shè)是中國共產(chǎn)黨的重要任務(wù)之一,關(guān)系到黨的長期執(zhí)政和健康發(fā)展。一份好的黨的體系建設(shè)報告應(yīng)該具備以下幾個方面的內(nèi)容。 一、完善組織結(jié)構(gòu) 黨的組織結(jié)構(gòu)是…

    科研百科 2024年11月20日
    3
  • 成果完成單位意見

    成果完成單位意見 隨著科技的不斷進步,我們?nèi)〉昧嗽S多令人矚目的成果。這些成果的完成離不開各個單位的支持和配合。在此,我們對各個單位在成果完成過程中所提出的意見和建議表示衷心的感謝。…

    科研百科 2024年10月29日
    2
  • 通陽利水法對老年心衰患者心臟舒張功能及心率變異性的影響(通陽利水方劑)

    [摘要] 目的 探討老年慢性心力衰竭(CHF)患者采用通陽利水法治療對其心臟舒張功能及心率變異性(HRV)的影響。方法 選擇我院2018年1月至2019年10月收治的老年CHF患者…

    科研百科 2024年5月7日
    47
  • 黨建信息化管理平臺正式上線運行(黨建信息化綜合管理平臺)

    本報訊 近日,三門峽職業(yè)技術(shù)學(xué)院黨建信息化管理平臺正式上線運行,這是該院探索“智慧黨建”模式的又一創(chuàng)新舉措。 今年以來,三門峽職業(yè)技術(shù)學(xué)院認(rèn)真貫徹落實《三門峽市黨支部標(biāo)準(zhǔn)化規(guī)范化建…

    科研百科 2023年6月17日
    246