1、內存占用,C++占優:jvm的垃圾回收原理下,old區只有到70%才會回收,否則系統為了效率,不會強制做fullgc,因此假如一開始分配了 -xms = xmx = 2g, -xmn = 512m的情況下,整個服務占用內存很容易達到1g以上。 而C++寫的服務,由於上次應用自己控制內存,用完馬上釋放,因此內存占用非常小。 比如apache一個進程常常只占據幾十M內存。
2、底層功能應用,C++占優: C++通過調用操作系統底層API,可以很方便的利用系統提供的更多功能。Java由於為了跨平台,jdk API的限制,很多操作系統的功能被閹割了。
例如:
a、fork,對於C++寫的程序,fork是一個很又有的功能。例如redis通過fork出子進程,進行copy on write的數據持久化。apache通過動態fork和kill子進程,更彈性的提供高並發服務。並且通過fork,可以防止一個進程被殺後,立即fork出備份進程,防止服務在主機上整體crash。Java也可以通過Runtime.exec(cmd)執行命令生成新的Java進程,但是只是啟動了一個全新的Java進程,並不是fork,並不能復制父進程中的數據。
b、mmap, C++通過內存映射,可以很方便的在不同進程中通信。而Java則很難做到這點。Java只能走本地socket進行通信。
c、管道:C++進程通過管道機制,可以在不同進程間形成數據通道,很方便的相互通信和配合完成功能。
d、文件鎖:對於不同進程之間的共享鎖機制
e、還是fork,因為fork後,父子進程共享內存、文件描述符,所以多個apache才能監聽在一個端口上。這個對於jboss是不可能的。
總之,Java由於jdk API的限制,由於單進程的限制,上層應用無法獲取很多進程級別的功能。
3、開發,Java占優:Java的內存處理、越界異常監聽、指針地址不可見,使得整個語言非常的安全,程序員不用太過關注內存、指針問題導致整個進程crash的問題,更高效的關注上層業務邏輯的開發就好。Java語言的跨平台性不需要太多關注不同平台的函數差異性。Java的堆棧打印可以很方便的定位問題。
4、程序效率,C++占優:例如對ssl的處理,openssl明顯比jsse高效不止一個量級,並且jsse在處理ssl時會造成大量內存零時對象,占用大量內存,從而使得jvm因為高內存占用後不停做gc,消耗了jvm的系統資源。
5、反射, classloader。 Java的proxy機制,spring框架,最底層上必須依賴這些技術。 Java通過反射、classloader技術,將整個框架的靈活性和動態性大大超過了C++程序。理由是Java語言最終是編譯為bytecode到jvm容器中運行,所以還是語言可控的。而C++編譯,link完之後,就只是一個寫死的二進制程序了,最多通過lib技術將一些函數放到外面共用,但語言本身,程序本身,已經定死了,不可能像Java那樣,通過一個字符串動態創建一個類。