色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

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

3天內不再提示

開發人員有必要過度追求軟件靈活性嗎?

5RJg_mcuworld ? 來源:未知 ? 作者:胡薇 ? 2018-04-28 08:53 ? 次閱讀

代碼量少了不代表軟件的復雜度降低了,而是編程語言的表達力更強了。太多開發人員癡迷于框架,過度追求軟件靈活性、可組合性等等,而忘記自己是不是真的需要這些。

在有軟件之前,只有黑暗。自從時代的黎明到來后,一直存在一個不變的事實:企業想要構建價格更低、運行更快的軟件。

當然,這是可以理解并且值得稱贊的目標——尤其是你曾經花費時間跟軟件開發人員打過交道。每個工程師都應該全心支持此目標,并且在當前環境的約束下,應該始終努力盡可能有效率地創造產品

然而,事實上,我們經常做不到這一點。并非故意為之,只是隨著時間流逝,在構建軟件時會因為意料之外的復雜性而陷入困境,因此自我訓練以尋找邊界案例、差距分析以及所有可能起源于同一個需求要點的隱藏故障。

我們被大量的復雜度以及設計優雅解決方案的精神執念所迷惑:另一層抽象!干起來!分離相關量!繼承構成!這也是可以理解的,但是在這個過程中,我們經常忽略正在被解決的業務問題,忘記管理復雜度是軟件開發人員次重要的責任。

為什么會造成現在這樣的局面?

軟件在某些方面上已經變得更加簡單了

在過去的幾十年里,軟件產業非常成功地降低了編寫大多數軟件所需要的自定義代碼量。

這種減少大部分是通過使編程語言更有表現性來實現的。像 Python、Ruby 或 JavaScript 這些語言可以用不到C 語言三分之一的代碼來實現相似的功能。使用 C 語言取代匯編語言編寫程序也同樣帶來了類似的優勢。可以預見,在未來,語言設計不大可能帶來如同過去幾十年一樣的改進。

然而也有很多其他不需要讓語言更具有表現力的方法,可以精簡構建軟件的代碼總量。截止到現在,在過去的二十年里,我們最大的收獲是開源軟件(OSS)。如果沒有個人和公司將資金投入到他們為社區免費贈予的軟件中,沒有這么多的代價和努力,那么我們今天所構建的大部分軟件將不會實現。

這些項目使我們能夠站在巨人的肩膀上解決問題,利用工具讓我們更專注于解決業務問題,而不是花時間建設基礎設施。

也就是說,業務是復雜的。可笑的復雜,而且只會更多,開源軟件非常適合生成用以構建系統的框架和工具,但在很大程度上為了獲得關注,又必須解決大量人員共享的問題。因此,大多數開源項目要么是相對通用的,要么是處于非常受歡迎的領域。因此,這些工具中的大部分都是建立系統的絕佳平臺,但最終我們仍然需要在日益復雜且要求苛刻的系統中構建所有業務邏輯和接口

所以我們剩下的是一個看起來像這樣的棧(對于 web 應用程序)…

“Our Code”部分最終變得非常復雜,因為它反映了業務及其流程。如果我們有自定義的業務邏輯和自定義流程,那么我們只需編寫組建應用程序的接口、工作流程和邏輯即可。當然,我們可以嘗試用不同的方式來記錄該邏輯(記住業務規則引擎?),但最終,沒有其他人會為您的業務編寫業務邏輯。實際上似乎沒有辦法解決這個問題……至少是在機器人到來并將我們從工作中解救出來之前。

不喜歡代碼,那么低代碼(Low-Code)如何?

如果我們必須開發應用程序的接口、工作流程和邏輯,這聽起來像是難住我們了,對嗎? 在某種程度上,是的,但我們仍有幾個選擇。

對于大多數開發者來說,軟件等于代碼,現實并非如此。 開發軟件有許多方法,其中一種是使用可視化工具。 在網絡普及之前,視覺開發和 RAD 工具在市場上占有更大的地位。 諸如 PowerBuilder、visual Foxpro、Delphi、VB 和 Access 等工具都具有可視化設計功能,允許開發人員在不輸入任何代碼的情況下創建界面。

這些工具涵蓋了需要編寫的代碼,但總的來說,你可以直觀地設計應用程序,然后編寫大量代碼來實現應用程序的邏輯。 在很多情況下,你仍然用編程操作接口,因為使用這些工具構建的接口通常是靜態的。 但是,對于大量應用程序,這些工具通過舍棄其他性能獲得了巨大的生產力,主要是以靈活性為代價。

自從網絡興起后,這些工具可能已經不再流行,但公司對它們的渴望并沒有降低,尤其是因為勢不可擋的軟件需求仍然持續不斷。 整個行業最新趨勢是“低代碼”系統。 低代碼開發工具是最新一代拖放式軟件開發工具的現代術語。 這些工具和其他工具之間最大的區別在于,它們主要基于 Web(和移動端),并且通常被托管于云平臺。

許多公司正活躍于這些平臺上。Salesforce(App Cloud)、Outsystems、Mendix 以及 Kony 等廠商承諾能夠比“傳統”應用程序開發快許多倍。 雖然他們的很多說法可能很夸張,但也有一定的可信度。依賴類似上述平臺的所有弊端,可能的確導致某些類型的程序比使用 .NET 或 Java 的傳統程序開發更快。

那么,問題是什么呢?

的確有幾個問題。 首先,有經驗的開發人員經常討厭這些工具。 大多數嚴肅的開發人員? 喜歡使用真實代碼? 編寫真正的軟件?。 我知道這聽起來像我正在迎合一群嗚咽的嬰兒(也許我有點兒),但如果你傳遞的核心價值是技術,那么采用頂尖開發人員不喜歡使用的工具并非是個好主意。

其次,像我這樣的人看著這些被封裝的平臺,說“不,不要在這里構建應用程序”。這是合情合理的憂慮,也是最讓我困擾的事情。

如果你10 年前用 PHP 搭建了一個應用程序,那么這個應用程序可能會顯老,但它現在仍然可以嗡嗡作響。 語言和生態系統都是開源的,并由社區維護的。 你需要保持應用程序持續更新,卻不必擔心供應商斷定不再值得花時間支持。

像我這樣的人看著這些被封裝的平臺,說“不,不要在這里構建應用程序”。這是合情合理的憂慮,也是最讓我困擾的事情。

如果你 10 年前選擇了有自己平臺的供應商,那么如果他們關閉工具或頻繁更改工具(還記得 Parse 么?),你可能會被迫重寫程序。或者更糟,你的系統會停滯在一個停止更新、不再支持服務的平臺上。

有很多理由去警惕這類平臺,但對許多企業來說,以更少的付出來搭建軟件太具誘惑以至于不忍拒絕。 軟件的復雜性仍在持續,不幸的是軟件工程師幫不上任何忙。

什么需要改變?

有高效的平臺,可以讓我們用真實代碼? 構建真正的軟件?,但不幸的是,軟件行業太過擔心于跟隨科技巨頭地領導,以至于沒有意識到他們的工具并沒有對項目添加任何價值。

我無法告訴你有多少次,曾遇到開發人員跟我說,相比于僅僅渲染 HTML,構建單一頁面應用程序(SPA)類似的東西并不會增加開銷。我曾聽開發人員說過,所有應用都應該基于 NoSQL 數據庫來開發,而關系數據庫逐漸沒落了。也曾聽開發人員質疑為什么應用程序不是用 CQRS 和事件溯源編寫的。

正是這種思維過程和常規的開銷導致公司認為軟件開發過于昂貴。 你可能會說,“但事件溯源如此優雅!在微服務之上搭建 SPA 如此整潔!”當然,它可能是,但對你這種正在寫十個微服務的人來說不是這樣的。這種額外的復雜性往往是不必要的。

作為從業人員,我們需要找到各種方法來簡化搭建軟件的過程,并且不忽視業務的合理復雜性。 我們需要承認,并非每個應用程序都需要與 Gmail 相同層次的界面復雜性和運營擴展性。 有很多應用程序需要經過深思熟慮的界面、復雜的邏輯、堅實的體系結構、流暢的工作流程等。但不需要微服務、AI、chatbots、NoSQL、Redux、Kafka、Containers 或任何類似的工具。

如今很多開發人員似乎對技術能力非常著迷,以至于他們不能退后一步,問問自己是否真的需要這些。

就像 MasterChef 上的人一樣,他們以分子美食家的身份入場兜售自己。 他們將原料分成不同的組成部分,使用科學配對口味的方法,然后用大量的二氧化碳和液氮來制作你見過的最有創意的食物。 然后他們會在一兩集之后被踢開,因為他們忘記了大多數烹飪的核心原則,即食物需要口感好。 他們似乎真的很驚訝于沒有人喜歡他們發酵的茴香和芒果精華珍珠加上抹了鳀魚沫的鱈魚肉。

對靈活性、可組合性和機敏性的癡迷正在給我們帶來巨大的痛苦,并迫使公司遠離我們所喜愛的平臺和工具。 并不是說我上面列出的那些工具不會增加價值,盡管大公司在大規模操作系統時會遇到典型問題,工具也僅是為了解決真正的痛點而產生的。

我所說的是,我們需要回到簡單化的方向,并開始以更簡單的方式創造事物,而不是僅僅一直討論簡單性。 也許我們可以依靠更多的集成技術棧來提供開箱即用的模式和工具,以便軟件開發人員能夠更高效地創建軟件。

我們將把越來越多的業務添加到“低代碼”平臺和其他通過簡化、移除起初寫過的代碼來降低軟件成本的工具中。

我們需要停止假裝二十行的程序是一些需要認真手工縫制的獨特掛毯。

聚焦簡單性

寫完之后,我仿佛聽到一百萬位開發人員磨刀的聲音,但我相信如果我們繼續堅持如下方向:想寫所有東西、配置一切、編寫所有內容、無論多大規模的問題都使用相同的堆棧,那么我們將把越來越多的業務添加到“低代碼”平臺和其他通過簡化、移除起初寫過的代碼來降低軟件成本的工具中。

我們對業務日益復雜的回答不會增加開發過程的復雜性 – 無論它看起來多么優雅。

我們必須設法通過簡化開發流程來管理復雜性。 因為管理復雜性是次重要的責任,我們必須始終記住軟件開發人員最重要的責任:通過使用軟件來實現價值。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • C語言
    +關注

    關注

    180

    文章

    7614

    瀏覽量

    137477
  • 代碼
    +關注

    關注

    30

    文章

    4823

    瀏覽量

    68920

原文標題:太多開發人員過度追求軟件靈活性,但是我們真的需要嗎?

文章出處:【微信號:mcuworld,微信公眾號:嵌入式資訊精選】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    急需LABVIEW軟件開發人員

    我們是上海市國資委直屬研究所,目前項目急需LABVIEW軟件開發人員!主要做儀器和系統編程,需要會接口通訊軟件設計,會C語言。如果會數據庫更好!興趣的聯系我:cxxin888@163.com陳先生,謝謝!
    發表于 09-22 13:12

    RemoTI基本遠程開發人員指南

    `RemoTI基本遠程開發人員指南目錄`
    發表于 03-16 16:28

    誠聘兼職/專職LabVIEW軟件開發人員

    誠聘兼職/專職LabVIEW軟件開發人員要求: 1、熟練掌握LabVIEW編程,具有使用LabVIEW的項目經驗; 2、如果不是很熟悉,愿意從事LabVIEW開發,也非常歡迎。3、為人誠實,辦事踏實
    發表于 03-31 21:15

    嵌入式開發人員需要重點監控的五個重要特征

    `  創客學院嵌入式講師今天和讀者介紹嵌入式開發人員需要重點監控的五個重要特征哪些?現代系統擁有豐富的資源,監控這些特征有時看似價值不高或沒有必要,但目前為止在現場遇到的最大問題總是與這五個關鍵
    發表于 03-02 13:23

    MCU 集成式模數轉換器提供 MSP 應用靈活性

    你是不是感到奇怪,為什么MSP微控制器 (MCU) 在其集成式模數轉換器 (ADC) 中提供靈活性,比如說可編程分辨率或功率模式?這個靈活性程度通常不在單個的ADC中提供。開發人員可以將MSP MCU用于多個應用,借助
    發表于 04-26 15:33 ?943次閱讀

    開發人員看的視頻

    英特爾?軟件頻道旨在通過向開發人員提供示例,教程,提示,技巧以及如何將開發人員與影響者,創新者聯系起來,幫助他們。
    的頭像 發表于 11-01 06:26 ?2416次閱讀

    什么是英特爾開發人員專區

    什么是英特爾?開發人員專區? 觀看此視頻,了解正在使用工具和資源滿足編碼需求的軟件開發人員
    的頭像 發表于 11-12 06:55 ?2518次閱讀

    Intel開發人員專區

    Intel?開發人員專區
    的頭像 發表于 05-31 09:24 ?1645次閱讀

    英特爾64和IA-32體系結構軟件開發人員手冊

    英特爾64和IA-32體系結構軟件開發人員手冊
    發表于 07-01 09:27 ?5次下載

    Eclypse Z7開發板讓軟件開發人員了解FPGA

    Eclypse Z7 的軟件架構包括預構建的 Linux 映像以及軟件開發人員可以使用熟悉的編程語言訪問的高級 API。這使開發人員能夠利用 FPGA 硬件加速的優勢,而不必直接與 FPGA 本身進行交互。
    的頭像 發表于 06-06 09:46 ?2023次閱讀
    Eclypse Z7<b class='flag-5'>開發</b>板讓<b class='flag-5'>軟件開發人員</b>了解FPGA

    IzoT BACnet 開發人員指南

    IzoT BACnet 開發人員指南
    發表于 03-13 19:31 ?1次下載
    IzoT BACnet <b class='flag-5'>開發人員</b>指南

    UM-B-056:DA1468x 軟件開發人員指南

    UM-B-056:DA1468x 軟件開發人員指南
    發表于 03-14 20:09 ?0次下載
    UM-B-056:DA1468x <b class='flag-5'>軟件開發人員</b>指南

    IzoT BACnet 開發人員指南

    IzoT BACnet 開發人員指南
    發表于 07-04 20:48 ?0次下載
    IzoT BACnet <b class='flag-5'>開發人員</b>指南

    UM-B-056:DA1468x 軟件開發人員指南

    UM-B-056:DA1468x 軟件開發人員指南
    發表于 07-05 20:36 ?0次下載
    UM-B-056:DA1468x <b class='flag-5'>軟件開發人員</b>指南

    MSPDebugStack開發人員指南

    電子發燒友網站提供《MSPDebugStack開發人員指南.pdf》資料免費下載
    發表于 12-05 14:49 ?0次下載
    MSPDebugStack<b class='flag-5'>開發人員</b>指南
    主站蜘蛛池模板: 亚洲精品自在在线观看 | 一区二区三区内射美女毛片 | 四虎永久精品视频在线 | 欧美精品久久久久久久久大尺度 | 蜜芽亚洲欧美一区二区电影 | 国产成人拍精品免费视频爱情岛 | 欧美高清一区二区三 | 日本无修肉动漫在线观看 | 伊人久久中文字幕久久cm | 亚洲高清有码中文字 | 在线高清视频不卡无码 | 国产免费内射又粗又爽密桃视频 | 先锋影音 av | 国产人妖一区二区 | 国产亚洲视频中文字幕 | 九九大香尹人视频免费 | 日本久久高清视频 | 奇米色偷偷 | 伊人久在线观看视频 | 色怕怕 | 久久观看视频 | 亚洲精品中文字幕一二三四区 | 国产精品久久久久AV麻豆 | 接吻吃胸摸下面啪啪教程 | 强奷乱码中文字幕熟女免费 | 把腿张开JI巴CAO死你H教室 | 欧美特级午夜一区二区三区 | 蜜桃传媒一区二区亚洲AV | 黄色片中文 | 亚洲高清中文字幕免费 | 色多多污污在线观看网站 | 欧美人与禽zoz0性伦交app | 成年色黄APP下载 | jiizzyou欧美喷液 | 久久se视频精品视频在线 | 亚洲福利区| jiz中国zz| 久久国产精品免费网站 | 性啪啪chinese东北女人 | 欧洲另类一二三四区 | 人妻夜夜爽天天爽三区麻豆AV网站 |