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

