1)java是解释性语言,java程序在运行时类加载器从类路经中加载相关的类,然后java虚拟机读取该类文件的字节,执行相应 *** 作.而C++编译的 时候将程序编译成本地机器码.一般来说java程序执行速度要比C++慢10-30倍.即使采用just-in-TIme compiling (读取类文件字节后,编译成本地机器码)技术,速度也要比C++慢好多.
2)java程序有要从网络上加载类字节,然后执行,这也是导致java运行速度慢的原因.
3)在程序运行过程中,java虚拟机要检测数组是否越界,在C++中则不检测.
4)java中所有的对象都创建在堆中,没有对象被创建在stack中,而C++有的对象和变量是创建在stack中的
5) java在运行过程中检测对象的引用是否为空,如果引用指向都空指针,且执行某个方法时会抛出空指针异常
6)java运行时对类型检测,如果类型不正确会抛出ClassCastExcepTIon异常.
7)java的垃圾回收机制较C++由程序员管理内存效率更低.
8) java中的原始数据类型在每个 *** 作系统平台长度都是相同,而C++这些数据类型长度是随 *** 作系统的不同而不同,所以java在不同 *** 作系统上执行时有个转化过程.
9)在java中String 是UNICODE.当java要 *** 作一个 ASCII string 时,比C++效率上相对要低一些.
10)java中采用的是动态链接
以下内容摘自《Java程序设计与问题解决:基础篇》附录
Java和C++看起来很类似,但两者之间的差别要多于粗略地查看这两种语言时所认为的那样。我们不会对所有的区别进行描述,但为了帮助从C++(或C)向Java过渡,会对两者的一些相似及不同之处进行介绍。
基本类型
Java中的基本类型基本上和C及C++中的一样(int、short、long、float、double和 char),但Java添加了byte和boolean类型。(近期的C++版本中也有了bool类型,对应于Java中的boolean类 型。)Java中没有名为long double的类型。与C和C++不同,在Java中,用字节表示的某些特定基本类型值的大小是完全确定的,与实现无关。细节请参见《Java程序设计与 问题解决:基础篇》的第2章。
字符串
与C和C++的某些版本不同,Java中的字符串不是特定类型的字符数组。在Java中有一个预定义的String类 型。(对String类的讨论是从《Java程序设计与问题解决:基础篇》的第2章开始的。)Java的String类与C++近期版本中的string 类有些类似。
控制流程
Java中的控制结构(if-else、switch、while、do-while和for)与C和C++一样。但是, 有一些差别会影响到对Java中控制结构的使用。具体来说,Java中没有逗号运算符,Java中的boolean类型既不是一个数字类型,也无法将其值 强制转换为一个数字类型,而且赋值运算符在Java中比在C和C++中表现得更好一些。
Java中没有逗号运算符。但是,Java中的for语句定义为可以使用逗号,就像下列代码这样:
for (n = 1, product = 1; n <= 10; n++)
product = product * n;
但这个“逗号运算符”只能在for语句中使用。
在Java中,boolean类型有两个值:true和false,无法将这两个值转换成数字值,用强制类型转换也不行。
C和C++中的一个典型错误就是用=取代了==,就像下列代码这样:
if ( n = 42 )
?
在C和C++ 中,表达式n=42会返回值42,根据所用的C或C++版本的不同,这个表达式可以是或将要被转换成一个布尔值。在Java中,n=42也会返回值42, 但42不是boolean类型的,它也不会被转换成boolean类型。因此,在Java中,这种错误会引发一个编译器错误消息。
相等性测试
在Java中测试一个类类型对象的相等性是很麻烦的。对基本类型的值来说,运算符==会如你所愿地对相等性进行测试。但 是,用==对两个类类型的对象进行比较时,测试的是对象是否处于同一个内存单元,而不是它们是否具有相同的数据。Java类通常会定义一个名为 equals的方法来测试两个对象是否是我们直觉意义上的相等。在Java中不能重载==运算符(或任何运算符)。
main方法(函数)及其他方法
在Java中,函数被称为方法(method)。main方法(函数)在Java中的功能与在C和C++中一样。在Java中,main方法头部通常如下所示。
public staTIc void main(String[] args)
在Java中,所有的方法—实际上,任意类型的所有代码—都是在类中定义的。
文件及包含文件
Java中没有#inlude指示。Java中确实有一个import语句,可以导入一整个包(库)以供
在一个类(或文件)中使用。
java 程序的总体布局是由很多类组成的,每个类都处于一个文件中。如果所有的类都位于同一个目录(文件夹)中,Java需要使用某个类(文件)的时候,就会自动 地找到它。通过使用import语句,也可以将不同目录中的类(文件)组合起来。细节请参见《Java程序设计与问题解决:基础篇》的5.7节(包)。
在Java中,一个类必须位于一个与类同名、但具有后缀.java的文件中。例如,一个名为MyClass的类必须位于一个名为MyClass.java的文件中。类的编译版本会被自动地放在一个名为MyClass.class的文件中。
类和方法(函数)定义
Java对方法的定义及声明不加区别(或者,如某些作者所述,Java对方法的原型和方法的定义不加区别)。 所有的方法(函数)都只有定义而没有前向引用。没有独立于方法定义的“头部”或“特征”或“原型”。所有的方法必须都是在某个类中定义的。所有的类定义都 完全是在一个文件中完成的,没有任何类型的前向引用或接口文件。尤其是,所有的方法定义全都是在它们的类定义中给出的。细节请参见《Java程序设计与问 题解决:基础篇》的第4章(定义类和方法)。
Java中没有指针
Java中没有指针类型。但Java是有指针的。实际上,所有的对象都是以指针的方式命名的。不过,指针被称为 引(reference),会被自动处理。例如,一个String类型的变量中会包含对一个字符串的引用(指针),但没有String指针类型。细节请参 见《Java程序设计与问题解决:基础篇》的4.3节。
方法(函数)参数
严格来讲,Java中只有一种参数传递机制,即,传值。但是,实际上,通常认为Java有两种类型的参数传递机 制:一种用于基本类型(比如int、double和char),另一种用于类类型。对基本类型,唯一的参数传递机制就是传值。对类类型,参数传递机制也被 称为传值,但传递的是类对象的引用(指针)。这就允许方法(函数)修改对象中的数据,因此,有些人认为这种机制应该被称为传引用机制。这并不符合大多数通 常的传引用(call-by-reference)定义,但在实现一些简单任务时,它的表现与传引用非常相似。细节请参见《Java程序设计与问题解决: 基础篇》的第4章和第5章。数组
Java数组与C或C++数组很类似,但它们还是有些区别的,Java数组的表现更好一些。Java中的数组“知道”它的范 围。如果a是一个数组,那么实例变量a.length中就包含了一个与数组可以承载的元素个数相等的整数。可以查看Java数组索引是否越界,如果代码试 图使用一个越界的数组索引(下标),就会抛出一个异常。细节请参见《Java程序设计与问题解决:基础篇》的第6章。
垃圾回收
Java中的内存管理和垃圾回收是自动进行的。Java使用了new运算符来创建一个类类型的新对象(因此这个过程就是一种内存分配形式),但Java中没有其他的内存分配形式了。Java中没有程序员可以用来进行垃圾回收的机制。垃圾回收是自动进行的。
其他的比较
Java和C++中的注释在本质上是完全一样的。
Java中没有全局变量。
Java中没有枚举类型。
Java中没有typedef。
Java中没有结构或联合。
可以像在C++中那样,在Java中对方法(函数)名进行重载,但在Java中不能对运算符进行重载。
Java中没有多重继承,但它确实通过接口恢复了多重继承的很多功能。更多关于接口的细节请参见《Java程序设计与问题解决:基础篇》的第7章。
Java中没有模板,但它确实通过泛型恢复了模板的很多功能。
在Java中,类可以有一个与类具有相同类型参数的构造器,但这个构造器没什么特殊的地位,不同于C++中的副本构造函数。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)