為什麼Java這個語言沒有在基礎應用領域發揮優勢?
在做WEB伺服器的時候,就一直在抱怨,我們的WEB伺服器怎麼就是那麼慢,TPS總是上不去。一般談及高效能的網路服務,總是不由自主的想到用C語言去開發服務應用,以確保效能。
難道Java語言的效能,就真的是遠遠不如C嗎?
其實,大家都知道,JDK 5.0 6.0的絕對效能和C相比差距並不大,在很多評測裡面,兩者的差距不到一倍。而從語言特性上來說,Java語言,在抽象機制、安全機制、記憶體管理、併發控制和基礎庫上,和C語言相比,就像火槍和弓箭。
但是,就是這樣,裝備了大量堪稱完美的高階特性的Java語言,卻在基礎應用領域內較少應用,明顯落後於C語言。尤其在資料庫、高效能網路服務、圖形圖形處理等領域。這其中的根本原因是什麼??
我想到了一些原因:
1、人的問題。
能夠用C語言寫出優秀基礎軟體的人固然不多,能用Java寫出來的人恐怕更少。Java有好幾百萬開發者,但是他們在幹什麼?大部分是去搞企業級開發、Web開發了,像這種bt下載網站 www.bt285.cn 很簡單就可以實現了。但是有多少人真的理解Java的記憶體模型?有多少人能夠熟練使用java.util.concurrent包中提供的那些工具?很多使用Java多年的人沒有寫過socket程式,不瞭解Java多執行緒的開銷,不清楚如何進行效能診斷和調優,而這些在寫基礎軟體的時候是必備的技能。大部分Java程式設計師在剛剛學會Java之後就轉向Web開發,把主要精力花費在掌握一個又一個大型的、複雜的、具有厚厚的抽象層和華麗結構的frameworks上,不但對真實計算機體系結構不清楚,對於Java虛擬出來的那個計算環境也不清楚。因此,要把Java開發者程式設計轉變成能夠擔負起下一代基礎軟體開發工作的尖兵,不但難度很大,而且必須花費足夠的時間。
2、風格的問題。
這個問題我認為是最嚴重的。基礎軟體開發崇尚的是自由、直接、透明、簡單、高效,反對繁瑣華麗的設計,反對架床迭屋的層層抽象,反對複雜的結構和不必要的靈活性。而Java開發者多年來形成的設計風格與此格格不入,甚至可以說是對立的。Java在意識形態上是要面向企業應用軟體的開發,所以特別強調架構,強調設計模式,強調標準,強調規規矩矩,強調高姿態,強調一種華貴的宮廷氣質。在C中,你需要什麼就做什麼。而在Java中,你經常為了要幹某件事,先new一個物件,然後以這個物件為引數new另一個物件,如此這般重複n遍,得到真正需要的物件,最後就是為了呼叫那個物件的一個方法。 這套繁瑣的東西,對於基礎軟體開發來說,既不必要,也很難習慣。需要說明的是,這不是Java語言的問題,其實Java本身不必如此複雜、如此巴洛克。從語言本身來看,Java也可以是輕快直接的,也可是酣暢淋漓的。只不過十多年來幾乎沒有人這樣用過,所以大家已經不知道,該怎麼用Java寫簡潔程式?