- 相關(guān)推薦
C語言與C++和JAVE的區(qū)別
很多人不明白C語言與C++和JAVE之間的區(qū)別,為此,百分網(wǎng)小編就為大家收集整理了下面的內(nèi)容,歡迎閱讀!
Java程序中的每個變量要么是基本數(shù)據(jù)類型(boolean, char, byte, short, int, long, float, double),要么是對對象的引用。
C++有許多種基本類型,額外還有struct, union, enum, 數(shù)組和指針,C++指針可以指向?qū)ο,也可以不指向(qū)ο蟆?/p>
Java沒有枚舉、聯(lián)合類型,因為Java認為沒有必要。將可有可無的語言元素去掉是Java對C/C++做出的一大改變,因此,普遍認為Java較C++更輕便,更精簡。
Java采用Unicode字符集,C++通常用ASCII字符集。但ASCII是Unicode的子集,對于習慣于ASCII的程序員感覺不到區(qū)別。
Java中的boolean類型不能轉(zhuǎn)換成其他類型,反之亦然。C++最近引進了bool類型,代表布爾類型,整型也作為邏輯判斷。
模板是一種“泛型編程思想”,它有別于“面向?qū)ο缶幊趟枷?rdquo;。C++在很大程度上已經(jīng)支持了這種新型編程方法,特別是STL的出現(xiàn)。
Java目前仍未支持泛型編程,不過據(jù)說Sun公司有在Java中引入模板的計劃。
C++支持“運算符的重載”,這是它的一個很重要的多態(tài)特征,是數(shù)據(jù)抽象和泛型編程的利器。它允許直接對對象進行四則運算,正像基本數(shù)據(jù)類型那樣。
Java不支持這種多態(tài)機制,也是為降低復雜性。
兩種語言都支持方法重載(overloading)。
在C++中,為了允許運行時動態(tài)決定哪個函數(shù)被調(diào)用,一個函數(shù)必須用virtual修飾。virtual關(guān)鍵字被自動繼承,用以支持多態(tài)。
凡是沒有用virtual修飾的成員函數(shù)(包括static)都是靜態(tài)綁定的,即在編譯時決定調(diào)用哪個版本。
而在Java中,除了static、final、private是靜態(tài)綁定以外,所有方法一律按動態(tài)綁定處理。
C++中有“拷貝構(gòu)造函數(shù)”的概念,在三種情況下,自動調(diào)用它。
用一個對象初始化另一對象。
對象作實參進行函數(shù)調(diào)用。
對象作函數(shù)的返回值。
通常,當一個對象需要做“深拷貝”(錢能:《C++程序設(shè)計教程》)時,我們需要為它事先定義“拷貝構(gòu)造函數(shù)”、“賦值運算符的重載函數(shù)”和“析構(gòu)函數(shù)”;否則編譯器將以“按位copy”的形式自動生成相應(yīng)的缺省函數(shù)。倘若類中含有指針成員或引用成員,那么這三個默認的函數(shù)就隱含了錯誤。
Java則沒有這種語法結(jié)構(gòu)和語義邏輯。
C++支持inline函數(shù),可以避免函數(shù)的堆棧調(diào)用,提高運行效率。
Java無這種語義
C++中,構(gòu)造函數(shù)的初始化列表是這樣使用的:首先按繼承順序調(diào)用基類的構(gòu)造函數(shù)構(gòu)造基類對象,然后按聲明順序調(diào)用成員對象的構(gòu)造函數(shù)構(gòu)造成員對象,最后對列表中出現(xiàn)的成員變量做初始化。
Java不采用初始化列表這種構(gòu)造機制。
它們的構(gòu)造順序基本一致。
靜態(tài)變量初始化
靜態(tài)初始化塊(Java)
調(diào)用基類的構(gòu)造函數(shù)構(gòu)造基類對象。
實例變量的初始化
構(gòu)造函數(shù)的其余部分
Java使用abstract關(guān)鍵字修飾抽象方法或抽象類。
C++的對等語法是“純虛函數(shù)”和“抽象類”
兩者都使用抽象類作為繼承層次中的基類,提供一般概念,由子類實現(xiàn)其抽象方法,且抽象類都不能被直接實例化為對象。
Java中有final關(guān)鍵字,修飾類、方法或變量。
final類不能被繼承
final方法不能被子類覆蓋
final變量就是常量
C++中沒有這個關(guān)鍵字,常量可以使用const或#define定義。
const還可以修飾成員函數(shù),即“常成員函數(shù)”,當一個const成員函數(shù)修改成員數(shù)據(jù),或調(diào)用非const成員函數(shù)時,編譯器會報錯。
我們應(yīng)將不修改成員數(shù)據(jù)的函數(shù)聲明為const。
Java和C++中的static關(guān)鍵字語法和語義基本相同。
static成員變量又叫類變量,被類的所有對象共享。
A::x (C++):必須在類體外初始化
A.x (Java):必須在類體內(nèi)初始化
static成員方法又叫類方法,訪問static變量。
A::f( ) (C++)
A.f( ) (Java)
兩者都有內(nèi)部類和局部類的語法和語義
Java中沒有友元函數(shù)和友元類的概念,嚴格支持封裝,不允許外部方法訪問類的私有成員。
而C++支持friend關(guān)鍵字,允許外部方法訪問類的私有成員,因此不是一種純面向?qū)ο蟮木幊陶Z言。
Java中類或interface可以用public修飾,也可以不修飾;而C++類不能修飾。
三種訪問權(quán)限的語義相同,語法略有差別。
C++中還有繼承權(quán)限修飾符,Java則沒有。
class A: protected B, public C (C++)。
class A extends B (Java)。
Java有super關(guān)鍵字,指代父類對象,通常被用于調(diào)用父類的構(gòu)造方法或一般方法。
C++則沒有super關(guān)鍵字
兩者都有this,指代當前對象。
Java有package的概念,可以將類組織起來,便于打包和部署,也有利于類的安全。C++沒有這個概念,一個類可以被任意類訪問。
Java applet可以被嵌入HTML文檔中,然后由Web瀏覽器下載和執(zhí)行。
Java API有對網(wǎng)絡(luò)通訊的特別支持。
C++則無內(nèi)置網(wǎng)絡(luò)功能
C++程序員必須顯式地實現(xiàn)動態(tài)內(nèi)存管理,在析構(gòu)函數(shù)中用delete運算符或free( )函數(shù)釋放對象和其他動態(tài)分配的數(shù)據(jù)空間,否則會造成“內(nèi)存泄露”。
而在Java中,垃圾收集是自動的。當對象的最后一個引用變量被釋放掉,這個對象就成為垃圾收集器的候選對象了。
因此Java不支持析構(gòu)函數(shù)。
finalize( )方法主要被用來釋放先前打開的非內(nèi)存資源,如文件句柄。
Java源代碼被編譯成字節(jié)碼(.class文件),字節(jié)碼是一種只有JVM才能識別的二進制低級代碼,它與具體的處理器無關(guān),要由安裝在OS之上的JVM解釋執(zhí)行,轉(zhuǎn)換成相應(yīng)平臺的機器碼,因此Java是體系結(jié)構(gòu)中立和跨平臺的。
而C++直接被編譯成底層平臺的二進制機器碼,由CPU執(zhí)行,是平臺相關(guān)的。
因此,當解釋執(zhí)行時,Java程序速度更慢。
Java語言支持多線程,允許并發(fā)線程的同步與互斥操作。
C++則沒有這種內(nèi)在機制
Javadoc.exe可以將Java程序的內(nèi)容和結(jié)構(gòu)轉(zhuǎn)換成HTML格式的文檔。
【C語言與C++和JAVE的區(qū)別】相關(guān)文章:
淺談c語言和c++和VB的區(qū)別07-04
C語言和C++的區(qū)別09-19
C語言和C++的區(qū)別精選10-16
c語言、c++語言兩者的區(qū)別和聯(lián)系06-17
c語言和c++和VB有什么區(qū)別07-16
C++、C語言和JAVA開發(fā)的區(qū)別06-28
Java與C/C++的區(qū)別06-18
JAVA和C++有何區(qū)別09-07
C語言和C++有什么區(qū)別05-19