2017編程發(fā)展

在編程世界吁津,流行的是科學棚蓄,嚴謹和精確的準則。這不是說編程是一種缺乏趨勢的行業(yè)碍脏。不同的是梭依,由于編程重視的是高效,用戶化和使用方便典尾,因此編程技術(shù)需要不斷更新?lián)Q代役拴。那么,在即將到來的2017年和未來的幾年內(nèi)钾埂,會有哪些新技術(shù)出現(xiàn)河闰,成為新的潮流,又有哪些技術(shù)的熱潮會漸漸消退呢褥紫?下面所列出的10種技術(shù)姜性,摘自infoworld.com的一位編輯Peter Wayner撰寫的文章21 hot programming trends -- and 21 going cold。本文旨在與大家一起討論這個話題髓考。

1. JavaScript MV 框架成為熱門部念,JavaScript文件遇冷

很久以前,我們寫JavaScript代碼來彈出一個消息窗口或檢查表格中含有@符號的電子郵件地址。不過現(xiàn)在有了HTML Ajax應(yīng)用程序儡炼,它們非常精細妓湘,因此很少人從零開始寫代碼了。現(xiàn)在比較簡單的方法是:使用一個有詳細說明的框架和寫一點膠水代碼來執(zhí)行商業(yè)邏輯∥谘現(xiàn)在有很多框架多柑,如Kendo, Sencha,jQuery Mobile楣责,AngularJS竣灌,Ember, Backbone, Meteor JS等等,所有這些框架都是為了處理Web應(yīng)用程序以及頁面事件和內(nèi)容而準備的秆麸。另外初嘹,還有一些為智能手機和平板電腦提供的跨平臺框架,其中包括nativescript沮趣,PhoneGap和Sencha Touch等屯烦,它們可以用來創(chuàng)建源自HTML5技術(shù)的app。

在livecoding.tv上房铭,一位開發(fā)者使用Phonegap開發(fā)一款HTML5 App

2. SVG + JavaScript on Canvas受歡迎驻龟,F(xiàn)lash風光不再

Flash風光了很多年,很多有才華的編程大師建立了一個Flash代碼堆垛來處理復(fù)雜的過渡和動畫缸匪。不過翁狐,現(xiàn)在JavaScript層具有很多相同的能力。瀏覽器的制造商和開發(fā)者都在為Flash的結(jié)束而歡呼凌蔬。JavaScript可以與DOM層更好地整合在一起露懒,DOM層來自一些新的格式,例如SVG(可縮放矢量圖形)砂心。SVG和HTML包含了一大堆標簽懈词,Web開發(fā)者使用起來往往更方便,現(xiàn)在還有了大的APIs辩诞,讓你可以在畫布對象上詳細地繪畫圖形坎弯,通常還會提供視頻卡來幫助你使用。當把它們結(jié)合起來使用译暂,你還有什么理由要用Flash呢抠忘?

3. 游戲框架比本土游戲開發(fā)更受歡迎

以前,游戲開發(fā)意味著要請大量開發(fā)人員秧秉,他們從零開始用C語言寫所有代碼褐桌。這需要投入巨資。現(xiàn)在象迎,大多數(shù)游戲開發(fā)者放下了他們多年前的驕傲資本荧嵌,現(xiàn)在他們使用庫呛踊,如Unity, Corona, 或LibGDX來建立系統(tǒng)。他們不會再寫像庫說明那么多的C代碼了啦撮。我們的游戲不再是用手工寫代碼完成谭网,而是由相同的引擎來制作而成的。這也許讓人覺得慚愧赃春,不過愉择,大多數(shù)開發(fā)者都對此感到很欣慰,因為他們不需要被迫去處理細節(jié)织中,這樣他們可以專注于游戲玩法锥涕,情節(jié),人物和藝術(shù)狭吼。

Livecoding.tv 上的直播者使用 Unity 及其它庫來開發(fā)各種游戲

4. 單一網(wǎng)頁的Web apps盛行层坠,網(wǎng)站遇冷

制作傳統(tǒng)網(wǎng)站的時候,網(wǎng)站設(shè)計人員要花幾個小時來制作網(wǎng)站地圖刁笙,以令網(wǎng)站導航變得簡單破花。新的Web應(yīng)用程序是從前端到有大量內(nèi)容的大數(shù)據(jù)庫。當Web應(yīng)用程序需要信息時疲吸,它就從數(shù)據(jù)庫中提取信息并將信息注入到本地的模具中∽浚現(xiàn)在沒有必要使用Web附加設(shè)備所需要的所有東西來標記數(shù)據(jù),以便創(chuàng)建一個網(wǎng)頁了摘悴。數(shù)據(jù)層是完全獨立于演示和格式層峭梳。移動計算的興起是另一個因素:單頁的,響應(yīng)式設(shè)計的網(wǎng)頁烦租,它工作起來就像一個app——所有這些都更好晕城,以避免混亂的App商店筒繁。

5. 移動Web apps比本土移動Web apps更具競爭力

APP開發(fā)者可以寫不同版本的app來應(yīng)用于不同的系統(tǒng):Android,iOS眼姐,Windows 8者蠕,甚至BlackBerry OS或是其它任何一個系統(tǒng)窃祝。每一個版本的app需要由一個獨立的,懂得不同編程語言的團隊來開發(fā)踱侣。然而粪小,每一個平臺上的app商店在把app交到用戶手中之前,可能會提出種種合理不合情的要求抡句。這是開發(fā)者不希望看到的探膊。開發(fā)者可以創(chuàng)建一個HTML app,把它放在一個網(wǎng)站上待榔,在所有平臺上運行逞壁。如果出現(xiàn)了什么變化流济,你不需要返回app商店去請求獲得一個迅速的錯誤檢查和修復(fù)。現(xiàn)在腌闯,HTML層越來越快绳瘟,而且它在速度較快的芯片上運行,這種方法可以使移動Web app更好地與本土app競爭姿骏,甚至是與更復(fù)雜的交互式app競爭糖声。

6. Android大熱, iOS遇冷

幾年前,蘋果專賣店門前排起的“人龍”還記得吧分瘦?時代在改變蘸泻,雖然iPhone和iPad仍然擁有忠實粉絲,他們喜歡豐富嘲玫、復(fù)雜的用戶界面悦施,但原始銷售數(shù)據(jù)依然對Android有利。甚至有報道說趁冈,超過80%的手機是Android的歼争。原因可能很簡單,因為成本渗勘。當iOS的設(shè)備成本仍然很高的時候沐绒,Android正在以大量競爭洶涌而來,那就是用五分之一的價格來生產(chǎn)平板電腦旺坠。省錢永遠是一種誘惑乔遮。不過,另一個因素可能是開源的效果取刃。任何人都可以在市場上競爭蹋肮。

7. Web界面興起,IDEs熱潮消退

很久以前璧疗,人們用的是命令行編譯器坯辩,然后有人把編輯器和其它工具整合在一起,創(chuàng)造了IDE”老溃現(xiàn)在又輪到IDE的熱潮消退了漆魔,因為有了基于瀏覽器的工具出現(xiàn)。它們通常是一個工作系統(tǒng)却音,可以讓你編輯代碼改抡。如果你不喜歡WordPress的功能,它配備了一個內(nèi)置的編輯器系瓢,讓你可以即時更改代碼阿纤。微軟的Azure允許你在它的入口寫JavaScript膠水代碼。雖然這些系統(tǒng)不能提供最好的調(diào)試環(huán)境夷陋,并且在編輯生產(chǎn)代碼時可能會有一些危險欠拾,但這個創(chuàng)意是不錯的胰锌。

你可以嘗試Cloud9,Aptana清蚀,和Mozilla WebIDE匕荸,但要堅持探索。Web界面正在變得越來越強大枷邪。有可能會出現(xiàn)這樣的情況榛搔,在微軟的Azure網(wǎng)站上建立一個完整的大數(shù)據(jù)分析項目。

8. 大熱的是Node.js, 遇冷的是JavaEE, Ruby on Rails

服務(wù)器的世界一直在線程模型上長盛不衰东揣,它讓程序員在使用操作系統(tǒng)時可以有種種行為践惑,如固執(zhí),低效或是放任嘶卧。無論是由程序員編碼而造成的愚蠢的循環(huán)或是浪費的計算尔觉,操作系統(tǒng)都可以在線程之間切換來平衡性能。

Node連同JavaScript一起回調(diào)編程模型芥吟,它的代碼的確運行得很快侦铜,比任何人預(yù)期的還快。它曾經(jīng)可能是一種無實用價值的語言钟鸵,只是被用于警告消息框钉稍。但意外地,由于創(chuàng)建新線程的開銷變得明顯棺耍,Node.js騰飛了贡未。當程序員表現(xiàn)得不好時,問題就會出現(xiàn)了蒙袍,但責任在很大程度上是對他們有好處的俊卤。顯然,限制資源往往可以令程序員更快地寫代碼害幅。Node.js還有利于瀏覽器和服務(wù)器之間的和諧消恍。運行在瀏覽器和服務(wù)器上的相同代碼可以讓開發(fā)人員更方便地移動和復(fù)制功能。因此以现,Node.js層已經(jīng)成為互聯(lián)網(wǎng)上最熱門的棧哺哼。

9. PHP7.0速度提升,舊版PHP淡出

在過去叼风,PHP是一種簡單的方法來淘汰一些動態(tài)網(wǎng)頁。如果你需要一點點的變化棍苹,你可以在HTML標簽之間嵌入簡單的代碼无宿。Web開發(fā)者有了它就基本足夠了,但它的緩慢足以令程序員中的中堅分子看不起它枢里。一些喜愛PHP的程序員在Wordpress和Facebook等地方都在爭相利用即時編譯器孽鸡,這種曾創(chuàng)造出Java如此高性能解決方案的技術(shù)來執(zhí)行比以前更快的PHP代碼□逦纾現(xiàn)在的工具如HipHop,虛擬機和PHP7.0提供的速度可能是舊版本的2倍彬碱。這會給Node.js和java帶來挑戰(zhàn)豆胸。

10. 在線即時教育成趨勢,四年傳統(tǒng)教育不再是主流

以計算機為媒介的課程已經(jīng)不是新玩意了巷疼,每個人正在享受著觀看視頻講座的好處晚胡。但這不僅是教育的一種本質(zhì),網(wǎng)上課程技術(shù)的背后是它顛覆了教育產(chǎn)業(yè)技術(shù)的復(fù)雜性嚼沿;它還可以讓你靈活地支配自己的學習時間和地點估盘。這正在改變我們的生活動態(tài),因為我們不再需要投資四年的時間以及負擔高額的學費去學習一系列課程了骡尽。當你需要獲得新信息的時候遣妥,你的需要可以即時得到滿足

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市攀细,隨后出現(xiàn)的幾起案子箫踩,更是在濱河造成了極大的恐慌,老刑警劉巖谭贪,帶你破解...
    沈念sama閱讀 216,324評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件境钟,死亡現(xiàn)場離奇詭異,居然都是意外死亡故河,警方通過查閱死者的電腦和手機吱韭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來鱼的,“玉大人理盆,你說我怎么就攤上這事〈战祝” “怎么了猿规?”我有些...
    開封第一講書人閱讀 162,328評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長宙橱。 經(jīng)常有香客問我姨俩,道長,這世上最難降的妖魔是什么师郑? 我笑而不...
    開封第一講書人閱讀 58,147評論 1 292
  • 正文 為了忘掉前任环葵,我火速辦了婚禮,結(jié)果婚禮上宝冕,老公的妹妹穿的比我還像新娘张遭。我一直安慰自己,他們只是感情好地梨,可當我...
    茶點故事閱讀 67,160評論 6 388
  • 文/花漫 我一把揭開白布菊卷。 她就那樣靜靜地躺著缔恳,像睡著了一般。 火紅的嫁衣襯著肌膚如雪洁闰。 梳的紋絲不亂的頭發(fā)上歉甚,一...
    開封第一講書人閱讀 51,115評論 1 296
  • 那天,我揣著相機與錄音扑眉,去河邊找鬼纸泄。 笑死,一個胖子當著我的面吹牛襟雷,可吹牛的內(nèi)容都是我干的刃滓。 我是一名探鬼主播,決...
    沈念sama閱讀 40,025評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼耸弄,長吁一口氣:“原來是場噩夢啊……” “哼咧虎!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起计呈,我...
    開封第一講書人閱讀 38,867評論 0 274
  • 序言:老撾萬榮一對情侶失蹤砰诵,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后捌显,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體茁彭,經(jīng)...
    沈念sama閱讀 45,307評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,528評論 2 332
  • 正文 我和宋清朗相戀三年扶歪,在試婚紗的時候發(fā)現(xiàn)自己被綠了理肺。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,688評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡善镰,死狀恐怖妹萨,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情炫欺,我是刑警寧澤乎完,帶...
    沈念sama閱讀 35,409評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站品洛,受9級特大地震影響树姨,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜桥状,卻給世界環(huán)境...
    茶點故事閱讀 41,001評論 3 325
  • 文/蒙蒙 一帽揪、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧辅斟,春花似錦台丛、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,657評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至变汪,卻和暖如春侠坎,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背裙盾。 一陣腳步聲響...
    開封第一講書人閱讀 32,811評論 1 268
  • 我被黑心中介騙來泰國打工实胸, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人番官。 一個月前我還...
    沈念sama閱讀 47,685評論 2 368
  • 正文 我出身青樓庐完,卻偏偏與公主長得像,于是被迫代替她去往敵國和親徘熔。 傳聞我的和親對象是個殘疾皇子门躯,可洞房花燭夜當晚...
    茶點故事閱讀 44,573評論 2 353

推薦閱讀更多精彩內(nèi)容