目前位置:首页 > 学习园地 > 教学文章
 
  在职人员我要充电
    大学生摆脱低薪困扰
  高中毕业我要就业
 女孩子做IT白领
学习园地
教学文章
学员作品
 

开班信息
 
 

免费讲座
 

名企专家青鸟讲坛之十
主题:一次选择 一生精彩
主讲:北大青鸟资深职业规划师

时间:2008年5月17号
      下午2:00
电话:025-84200066       025-84200236

 

友情链接
  北大青鸟集团
印度APTECH公司
北大青鸟APTECH公司
北京大学
中兴软创
中国软件开发网
南京市科技技术局
江苏人事人才网
南京市人才市场
中国南京软件
青鸟教育e-Learning
 
 ◆ 教学文章
对比C++和Java

作为一名C++程序员,我们早已掌握了面向对象程序设计的基本概念,而且Java的语法无疑是非常熟悉的。事实上,Java本来就是从C++衍生出来的。

然而,C++Java之间仍存在一些显著的差异。可以这样说,这些差异代表着技术的极大进步。一旦我们弄清楚了这些差异,就会理解为什么说Java是一种优秀的程序设计语言。本附录将引导大家认识用于区分JavaC++的一些重要特征。

(1)
最大的障碍在于速度:解释过的Java要比C的执行速度慢上约20倍。无论什么都不能阻止Java语言进行编译。写作本书的时候,刚刚出现了一些准实时编译器,它们能显著加快速度。当然,我们完全有理由认为会出现适用于更多流行平台的纯固有编译器,但假若没有那些编译器,由于速度的限制,必须有些问题是Java不能解决的。

(2)
C++一样,Java也提供了两种类型的注释。

(3)
所有东西都必须置入一个类。不存在全局函数或者全局数据。如果想获得与全局函数等价的功能,可考虑将static方法和static数据置入一个类里。注意没有象结构、枚举或者联合这一类的东西,一切只有Class)!

(4)
所有方法都是在类的主体定义的。所以用C++的眼光看,似乎所有函数都已嵌入,但实情并非如何(嵌入的问题在后面讲述)。

(5)
Java中,类定义采取几乎和C++一样的形式。但没有标志结束的分号。没有class foo这种形式的类声明,只有类定义。
class aType()
void aMethod() {/*
方法主体 */}
}

(6) Java
中没有作用域范围运算符“::”Java利用点号做所有的事情,但可以不用考虑它,因为只能在一个类里定义元素。即使那些方法定义,也必须在一个类的内部,所以根本没有必要指定作用域的范围。我们注意到的一项差异是对static方法的调用:使用ClassName.methodName()。除此以外,package(包)的名字是用点号建立的,并能用import关键字实现C++“#include”的一部分功能。例如下面这个语句:
import java.awt.*;
#include并不直接映射成import,但在使用时有类似的感觉。)

(7)
C++类似,Java含有一系列主类型Primitive type),以实现更有效率的访问。在Java中,这些类型包括booleancharbyteshortintlongfloat以及double。所有主类型的大小都是固有的,且与具体的机器无关(考虑到移植的问题)。这肯定会对性能造成一定的影响,具体取决于不同的机器。对类型的检查和要求在Java里变得更苛刻。例如:
条件表达式只能是boolean(布尔)类型,不可使用整数。
必须使用象X+Y这样的一个表达式的结果;不能仅仅用“X+Y”来实现副作用

(8) char
(字符)类型使用国际通用的16Unicode字符集,所以能自动表达大多数国家的字符。

(9)
静态引用的字串会自动转换成String对象。和CC++不同,没有独立的静态字符数组字串可供使用。

(10) Java
增添了三个右移位运算符“>>>”,具有与逻辑右移位运算符类似的功用,可在最末尾插入零值。“>>”则会在移位的同时插入符号位(即算术移位)。

(11)
尽管表面上类似,但与C++相比,Java数组采用的是一个颇为不同的结构,并具有独特的行为。有一个只读的length成员,通过它可知道数组有多大。而且一旦超过数组边界,运行期检查会自动丢弃一个异常。所有数组都是在内存里创建的,我们可将一个数组分配给另一个(只是简单地复制数组句柄)。数组标识符属于第一级对象,它的所有方法通常都适用于其他所有对象。

(12) 对于所有不属于主类型的对象,都只能通过new命令创建。和C++不同,Java没有相应的命令可以在堆栈上创建不属于主类型的对象。所有主类型都只能在堆栈上创建,同时不使用new命令。所有主要的类都有自己的封装(器)类,所以能够通过new创建等价的、以内存为基础的对象(主类型数组是一个例外:它们可象C++那样通过集合初始化进行分配,或者使用new)。

(13) Java
中不必进行提前声明。若想在定义前使用一个类或方法,只需直接使用它即可——编译器会保证使用恰当的定义。所以和在C++中不同,我们不会碰到任何涉及提前引用的问题。

(14) Java
没有预处理机。若想使用另一个库里的类,只需使用import命令,并指定库名即可。不存在类似于预处理机的宏。

(15) Java
用包代替了命名空间。由于将所有东西都置入一个类,而且由于采用了一种名为封装的机制,它能针对类名进行类似于命名空间分解的操作,所以命名的问题不再进入我们的考虑之列。数据包也会在单独一个库名下收集库的组件。我们只需简单地“import”(导入)一个包,剩下的工作会由编译器自动完成。

(16)
被定义成类成员的对象句柄会自动初始化成null。对基本类数据成员的初始化在Java里得到了可靠的保障。若不明确地进行初始化,它们就会得到一个默认值(零或等价的值)。可对它们进行明确的初始化(显式初始化):要么在类内定义它们,要么在构建器中定义。采用的语法比C++的语法更容易理解,而且对于static和非static成员来说都是固定不变的。我们不必从外部定义static成员的存储方式,这和C++是不同的。

(17)
Java里,没有象CC++那样的指针。用new创建一个对象的时候,会获得一个引用(本书一直将其称作句柄)。例如:
String s = new String('howdy');
然而,C++引用在创建时必须进行初始化,而且不可重定义到一个不同的位置。但Java引用并不一定局限于创建时的位置。它们可根据情况任意定义,这便消除了对指针的部分需求。在CC++里大量采用指针的另一个原因是为了能指向任意一个内存位置(这同时会使它们变得不安全,也是Java不提供这一支持的原因)。指针通常被看作在基本变量数组中四处移动的一种有效手段。Java允许我们以更安全的形式达到相同的目标。解决指针问题的终极方法是固有方法(已在附录A讨论)。将指针传递给方法时,通常不会带来太大的问题,因为此时没有全局函数,只有类。而且我们可传递对对象的引用。Java语言最开始声称自己完全不采用指针!但随着许多程序员都质问没有指针如何工作?于是后来又声明采用受到限制的指针。大家可自行判断它是否的是一个指针。但不管在何种情况下,都不存在指针算术

(18) Java
提供了与C++类似的构建器Constructor)。如果不自己定义一个,就会获得一个默认构建器。而如果定义了一个非默认的构建器,就不会为我们自动定义默认构建器。这和C++是一样的。注意没有复制构建器,因为所有自变量都是按引用传递的。

(19) Java
中没有破坏器Destructor)。变量不存在作用域的问题。一个对象的存在时间是由对象的存在时间决定的,并非由垃圾收集器决定。有个finalize()方法是每一个类的成员,它在某种程度上类似于C++破坏器。但finalize()是由垃圾收集器调用的,而且只负责释放资源(如打开的文件、套接字、端口、URL等等)。如需在一个特定的地点做某样事情,必须创建一个特殊的方法,并调用它,不能依赖finalize()。而在另一方面,C++中的所有对象都会(或者说应该)破坏,但并非Java中的所有对象都会被当作垃圾收集掉。由于Java不支持破坏器的概念,所以在必要的时候,必须谨慎地创建一个清除方法。而且针对类内的基础类以及成员对象,需要明确调用所有清除方法。

(20) Java
具有方法过载机制,它的工作原理与C++函数的过载几乎是完全相同的。

(21) Java
不支持默认自变量。

网站导航  使用帮助  招聘信息  联系我们  中心地图  在线留言
   
  ©版权所有2007 北大青鸟APTECH(南京迅超)授权培训中心
地址:南京市白下区建邺路66号3层
电话:025-84200066
传真:025-84200239 
网址:www.njaccp.com
邮箱:accp@njaccp.com