自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

觀點 | 我為什么使用Java

開發(fā) 后端
根據你的工作需要,可能有比 Java 更好的語言,但是我還沒有看到任何能把我拉走的語言。

[[277000]]

根據你的工作需要,可能有比 Java 更好的語言,但是我還沒有看到任何能把我拉走的語言。

我記得我是從 1997 年開始使用 Java 的,就在 Java 1.1 剛剛發(fā)布不久之后。從那時起,總的來說,我非常喜歡用 Java 編程;雖然我得承認,這些日子我經常像在 Java 中編寫“嚴肅的代碼”一樣編寫 Groovy 腳本。

來自 FORTRANPL/1、Pascal 以及最后的 C 語言 背景,我發(fā)現(xiàn)了許多讓我喜歡 Java 的東西。Java 是我面向對象編程的第一次重要實踐經驗。到那時,我已經編程了大約 20 年,而且可以說我對什么重要、什么不重要有了一些看法。

調試是一個關鍵的語言特性

我真的很討厭浪費時間追蹤由我的代碼不小心迭代到數(shù)組末尾而導致的模糊錯誤,特別是在 IBM 大型機上的 FORTRAN 編程時代。另一個不時出現(xiàn)的隱晦問題是調用一個子程序時,該子程序帶有一個四字節(jié)整數(shù)參數(shù),而預期有兩個字節(jié);在小端架構上,這通常是一個良性的錯誤,但在大端機器上,前兩個字節(jié)的值通常并不總是為零。

在那種批處理環(huán)境中進行調試也非常不便,通過核心轉儲或插入打印語句進行調試,這些語句本身會移動錯誤的位置甚至使它們消失。

所以我使用 Pascal 的早期體驗,先是在 MTS 上,然后是在 IBM OS/VS1 上使用相同的 MTS 編譯器,讓我的生活變得更加輕松。Pascal 的強類型和靜態(tài)類型是取得這種勝利的重要組成部分,我使用的每個 Pascal 編譯器都會在數(shù)組的邊界和范圍上插入運行時檢查,因此錯誤可以在發(fā)生時檢測到。當我們在 20 世紀 80 年代早期將大部分工作轉移到 Unix 系統(tǒng)時,移植 Pascal 代碼是一項簡單的任務。

適量的語法

但是對于我所喜歡的 Pascal 來說,我的代碼很冗長,而且語法似乎要比代碼還要多;例如,使用:

  1. if ... then begin ... end else ... end

而不是 C 或類似語言中的:

  1. if (...) { ... } else { ... }

另外,有些事情在 Pascal 中很難完成,在 C 中更容易。但是,當我開始越來越多地使用 C 時,我發(fā)現(xiàn)自己遇到了我曾經在 FORTRAN 中遇到的同樣類型的錯誤,例如,超出數(shù)組邊界。在原始的錯誤點未檢測到數(shù)組結束,而僅在程序執(zhí)行后期才會檢測到它們的不利影響。幸運的是,我不再生活在那種批處理環(huán)境中,并且手頭有很好的調試工具。不過,C 對于我來說有點太靈活了。

當我遇到 awk 時,我發(fā)現(xiàn)它與 C 相比又是另外一種樣子。那時,我的很多工作都涉及轉換字段數(shù)據并創(chuàng)建報告。我發(fā)現(xiàn)用 awk 加上其他 Unix 命令行工具,如 sort、sedcut、joinpaste、comm 等等,可以做到事情令人吃驚。從本質上講,這些工具給了我一個像是基于文本文件的關系數(shù)據庫管理器,這種文本文件具有列式結構,是我們很多字段數(shù)據的保存方式?;蛘撸幢悴皇沁@種格式,大部分時候也可以從關系數(shù)據庫或某種二進制格式導出到列式結構中。

awk 支持的字符串處理、正則表達式關聯(lián)數(shù)組,以及 awk 的基本特性(它實際上是一個數(shù)據轉換管道),非常符合我的需求。當面對二進制數(shù)據文件、復雜的數(shù)據結構和關鍵性能需求時,我仍然會轉回到 C;但隨著我越來越多地使用 awk,我發(fā)現(xiàn) C 的非?;A的字符串支持越來越令人沮喪。隨著時間的推移,更多的時候我只會在必須時才使用 C,并且在其余的時候里大量使用 awk。

Java 的抽象層級合適

然后是 Java。它看起來相當不錯 —— 相對簡潔的語法,讓人聯(lián)想到 C,或者這種相似性至少要比 Pascal 或其他任何早期的語言更為明顯。它是強類型的,因此很多編程錯誤會在編譯時被捕獲。它似乎并不需要過多的面向對象的知識就能起步,這是一件好事,因為我當時對 OOP 設計模式毫不熟悉。但即使在剛剛開始,我也喜歡它的簡化繼承模型背后的思想。(Java 允許使用提供的接口進行單繼承,以在某種程度上豐富范例。)

它似乎帶有豐富的功能庫(即“自備電池”的概念),在適當?shù)乃缴现苯訚M足了我的需求。最后,我發(fā)現(xiàn)自己很快就會想到將數(shù)據和行為在對象中組合在一起的想法。這似乎是明確控制數(shù)據之間交互的好方法 —— 比大量的參數(shù)列表或對全局變量的不受控制的訪問要好得多。

從那以后,Java 在我的編程工具箱中成為了 Helvetic 軍刀。我仍然偶爾會在 awk 中編寫程序,或者使用 Linux 命令行實用程序(如 cut、sortsed),因為它們顯然是解決手頭問題的直接方法。我懷疑過去 20 年我可能沒寫過 50 行的 C 語言代碼;Java 完全滿足了我的需求。

此外,Java 一直在不斷改進。首先,它變得更加高效。并且它添加了一些非常有用的功能,例如可以用 try 來測試資源,它可以很好地清理在文件 I/O 期間冗長而有點混亂的錯誤處理代碼;或 lambda,它提供了聲明函數(shù)并將其作為參數(shù)傳遞的能力,而舊方法需要創(chuàng)建類或接口來“托管”這些函數(shù);或,它在函數(shù)中封裝了迭代行為,可以創(chuàng)建以鏈式函數(shù)調用形式實現(xiàn)的高效數(shù)據轉換管道。

Java 越來越好

許多語言設計者研究了從根本上改善 Java 體驗的方法。對我來說,其中大部分沒有引起我的太多興趣;再次,這更多地反映了我的典型工作流程,并且(更多地)減少了這些語言帶來的功能。但其中一個演化步驟已經成為我的編程工具中不可或缺的一部分:Groovy。當我遇到一個小問題,需要一個簡單的解決方案時,Groovy 已經成為了我的首選。而且,它與 Java 高度兼容。對我來說,Groovy 填補了 Python 為許多其他人所提供的相同用處 —— 它緊湊、DRY(不要重復自己)和具有表達性(列表和詞典有完整的語言支持)。我還使用了 Grails,它使用 Groovy 為非常高性能和有用的 Java Web 應用程序提供簡化的 Web 框架。

Java 仍然開源嗎?

最近,對 OpenJDK 越來越多的支持進一步提高了我對 Java 的舒適度。許多公司以各種方式支持 OpenJDK,包括 AdoptOpenJDK、Amazon 和 Red Hat。在我的一個更大、更長期的項目中,我們使用 AdoptOpenJDK 來在幾個桌面平臺上生成自定義的運行時環(huán)境

有沒有比 Java 更好的語言?我確信有,這取決于你的工作需要。但我一直對 Java 非常滿意,我還沒有遇到任何可能會讓我失望的東西。

 

責任編輯:龐桂玉 來源: Linux中國
相關推薦

2015-11-11 13:35:15

2012-05-24 09:13:20

2023-04-04 19:14:40

Linux發(fā)行版Alpine

2012-06-04 10:35:55

FirefoxChrome瀏覽器

2020-12-24 18:46:11

Java序列化編程語言

2019-02-22 08:46:05

2025-01-15 09:06:58

CSSRegEx前端

2020-08-10 11:20:59

索引MySQL數(shù)據庫

2012-02-28 09:11:51

語言Lua

2020-07-17 14:06:36

Scrum敏捷團隊

2012-04-04 22:07:12

Android

2022-08-17 14:35:27

智慧城市物聯(lián)網社區(qū)

2021-05-17 11:30:08

Linuxls命令

2021-06-03 08:45:44

Linuxls命令

2020-03-03 15:31:47

ReactVue前端

2020-06-19 08:01:48

Kotlin 協(xié)程編程

2022-03-20 18:29:38

爬蟲反爬蟲代理

2013-10-22 15:18:19

2014-01-09 09:24:40

2014-01-17 14:39:18

12306 搶票
點贊
收藏

51CTO技術棧公眾號