分享
 
 
 

Java无用论

王朝java/jsp·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

1. 写这篇文章的目的

学了一些关于Java的东西,个人认为它很不好用。为了减少上当人数 特写此文。

尽管 java 宣称它是100%面向对象,而C++不是。但是宣称100%面向 对象本身就不是什么面向对象的思想。面向对象的本质目的是提高生 产率。讨论一种语言是否100%面向对象就似乎讨论我们的社会性资性 社一样滑稽。其实学习面向对象不一定非要使用java不可。我反而认 为120%面向对象的C++是不错的选择。

Java号称跨平台,其实这是只一个梦想,也不妨用骗局这个词来形容 。软件的移植性仅仅和虚机相关吗?照此理论是不是可以说符合IA32 体系的软件在任何IA32体系上都能正常运行。那我怎么没看见SCO: :lf 在 NT上运行?显然,除了虚机,软件二进制规范(执行文件格 式、连接方法)、运行时间库和系统调用也是软件移植问题因素。而 java规范中显然不包括完整的运行时间库和系统调用,甚至二进制规 范也有不兼容的地方(比如本原接口和固有接口)。软件总不能脱离 它的运行环境,不兼容就从这里开始。

要提高软件生产效率。应当认认真真的研究系统结构、二进制规范、 系统调用结构才是解决问题的方法。靠概念游戏这种投机取巧的方法是行不通的。

我说java不好,甚至不必对其侧目,你信吗?我估计信的人不多。我 只是想说"上当之后别怪我没说"。 另外假如您在Java中发现了甜头也不妨告诉我。互相学习吗:)。

2. Java究竟是什么?

Java是一种虚拟硬件系统结构,是一种软件二进制规范,是一种编程语言。当我们看到Java一词时,它可能表达上述三个含义钟的任何一 个。尽管这三个东西可以独立存在,不过实际上他们总是在一起出现 。所以也很少有人分的那么明确。使用Fortran语言编写Java虚机上的代码理论上是可行的。但是有谁乐意做这件事呢?

作为虚拟硬件体系结构, Java虚机和ALPHA、PowerPC、SPARC、IA32、51、960是同一概念上的 东西。也许您会希奇?他们怎是同样的东西呢?IA32不就是PIII、PI V那一大块吗?其实不然、我们知道386、P5、P6、P7的内部结构非常 不同。属不同的微体系。但是他们实现了相同的IA32指令集合。IA32 也不一定非要通过硬件实现,通过软件也可以。这种软件CPU产品广 泛出现在操作系统和CPU密集软件的开发、调试工具上。主要用于在C PU出现之前调试软件。Java指令集同样也可以通过硬件实现。只是在 半导体工业激烈竞争的时代,没有大公司(含SUN)愿意把这么做。 SUN经常说M$很害怕java。他们之间的确存在很强的竞争关系。倒不 是Java高级语言的问题,我认为是Java二进制规范和 Windows操作系 统存在竞争。不妨考察Java中的(.class文件格式、装入方法、执行 过程、JDBC接口、J3D接口)和Windows中的(PE文件格式、DLL文件格 式、装入、连接方法、ODBC、Direct3D)。就知道竞争多么强烈。和N T/IA不同。Java.exe执行程序包含虚机规范和二进制规范。在NT/IA 中是分离的产品。

人们总喜欢把Java高级语言和C++类比,他们之间的确存在很过相似的地方。不过我认为C++和Java不存在什么竞争。它们使用在不同的场合。他们的区别(内存治理、对象类型、线程规范)决定他们的用途。用形似而神不似来形容C++和Java吧。仅从高级语言方面来看。J ava真正竞争来自ECMAScript 。也就是JScript和VBScript。

3. Java虚机和IA32比较

Java VM和IA32最大的区别是Java VM的主要实现不考虑效率问题。由此派生出寄存器少,指令结构简单(同样功能生成的程序代码长),寻址空间小,寻址方法少、数据类型少等。除了上述问题,Java VM 没有涉及指令(显式或隐式)并行问题。

3.1. 基本特性差别

3.1.1. 数据类型比较

Java VM

IA32

整数类型

byte

short(16bit) char(UnionCode)

int

long (64bit)

{不存在无符号算术运算指令,另外注重这里没有boolean类型}

byte

Word(16bit)

DoubleWord(32bit)

QuotaWord(64bit)

DoubleQuotaWord(2*64bit)

BCD/PackedBCD

BitField

{存在有符号和无符号两种运算指令}

浮点类型

float(32bit)

double(64bit)

float(32bit)

double(64bit)

long double(80bit)

Packed double(2*64bit)

地址

returnAddress*

8bit , 16bit , 32bit , 48bit都有

没有显示的看到returnAddress 类型的宽度,不过。通过指令goto(0xa7)和goto_w(0xc8)来看。retu rnAddress是可以是16位或32位的。

关于double和Long的原子问题:在目前的java规范中,double和long 作为两个独立的32 位数据独立存取。这样可能产生同步问题。历史 上Intel的CMPXCHG8B(Pentum pro以上CPU提供)指令就存在过类似 问题,一度被指责是CPU设计问题。好在CMPXCHG8B很少使用,没有造 成什么事故。

3.1.2. 指令集

指令类型

JavaVM

IA32

Load/Store

1) 数据和运算栈之间单个移动

2) 常数移入运算栈

1) MOVE

2) CMOVEXX

3) 交换,琐操作

4) PUSH/POP

5) PUSHA/POPA

6) IN/OUT

元算指令

add , sub , mul , div , neg , rem , shl , or , and , xor

比Java多多了,主要多在显式并行上 类型转换 基本类型之间可以互相转换 有(由于类型很多,转换指令也有很多) 方法调用 4条指令 一大堆,主要多在权限切换(调用门)、长短跳传不同上。

3.1.3. 异常

虽然JavaVM有异常的支持,不过很简单。它不区分中断、陷阱和故障 。也不能明确指出出错代码的PC,并返回那里重新执行。

3.1.4. 执行态

Java VM没有用户态和系统态执行区分。当然也没有MMU(治理内存分 页、分段的内存治理单元).除非被Java高级语言限制,java VM汇编 代码也能完成一些恶意操作。

3.1.5. 小结

总而言之,Java VM很简单。SUN总是认为通过编译优化Java可以达到 C++速度。显然是谎言。假如要编译成本地代码,显然要丢失移植性 。假如不编译成本地代码,效率问题如何解决?有一种及时编译的设 计。对于很小的应用也许可行。对于规模的应用呢?要知道优化编译 很费CPU和内存。像IA64体系的优化方案,要编译很多遍才能优化完 成。要运行时刻编译是不是天方夜谭。

4. Java高级语言和C++、JScript比较

4.1. 效率,谎言

很多书上写Java是很快的语言。这时一定要看清楚是比谁快。语句传 了几本书难免有些误差,比较对象经常有意无意丢失。一般认为Java 比JScript快。的确快很多,不只十倍。我也承认Java比JScript快。 但有人说Java和C++效率接近。这就是骗人了。他们也能做出试验证 明,试验结果似乎也能证实结论。他们的实验大概都是形如这样。

Java, C++测试代码:

for ( I = 0 ; I<100 ; I++ )

{

RemoteCall( I ); //外部调用,调用一次用1s。

结果:

Java 102s , C++ 100s。

结论:

Java达到了C++ 98.0%的效率。

这种测试违反了测量学中要把测试对象放到主要矛盾上这一基本原 理。方法的不正确当然带来了测试结果的不正确。有本事比比

for ( I = 0 ; I<10000; I++)

{

y = x * z;//由Java语言或C++语言实现执行体

}

我的结果是170倍。也就是PIII变成了286。假如使用指令并行优化 ,C++和Java的速度差异可以达到千倍以上。想用一下8088吗?

4.2. 功能缺失导致代码膨胀

简单的说,Java比C++缺少编译预处理、缺少运算符重载、多继续和类模板。我认为取消这些概念很粗暴。和C++不同。对于大规模编程来说,Java的代码量不会比C少多少。甚至由于类型约束太强。有可 能比C的代码量还大。

Java常称多继续比较困难,所以要取消。而且使用实现接口的方法可 以代替C++的多继续。但是,实现接口要自己写所有的接口实现代码 。不嫌烦就慢慢写吧。

为什么要取消运算符重载?真是不可理解,既简单又好用。它居然说 难,且轻易造成混乱。

总之,处理这几个大方向的问题,还有很多小问题。据说AWT不好用, 感觉他们为了完成任务写程序。

4.3. 简单的骗局

自古便宜没好货。Java总是宣扬Java如何简单,主要宣扬的好处是垃 圾自动收集和线程同步。其实不然,由于Java没有释放要害字。使得 不能及时释放或定时释放不必的数据。要知道能够分配的不只是内存 ,还有数据库句柄、文件句柄、结果集等。这样不得不绕来绕去的完 成这些任务。其实C++的析构函数是自动调用的,也不用自己手动掉 用。碰到一些非凡情况,C++也能很好的解决。

也许java的线程比较简单吧,不过C++中也可以继续线程类。由于本 人没有涉及线程编程。这里不好乱说。

5. Java的兼容性

相对本地代码来说,Java程序的确移植性比较好。归其原因不外有二。一来Java虚机只一种(不像天下有很多种CPU),二来Java二进制 规范只有一种(不像这么多种操作系统)。但是,Java代码真的可以随 心所欲的移植吗?其实不然,上述两条中的任何一种不再满足,都会 影响ByteCode的移植性。

现在,Java的主要版本已经有1.0 , 1.1.7 , 1.2(2.0)三个。更残酷 的是1.1.7和1.2不兼容。一个很闻名的例子。Websphere不能在Java1 .2上运行。另外WebLogic不能在1.0上运行。

java的二进制规范呢?jview( MS java)就自立门户。他的.class装 入方法就和java for win32不同。另外它提出了其他的本地代码连接 方法。显然这里也会造成不兼容。

除了上述两条重要的原因,还有就是程序的运行环境。比如操作系统 是否区分文件名的大小写。数据库是否中调用都能返回执行成功。EJ B的代码是否有EJB 的运行服务器。等等。

6. 在精通Java之前否定Java

本人只是对Java略知一二。为什么就非要否定java呢。其实,从一般 科学观点审阅java。就会发现其中的问题。

6.1. Java代码不符合从简单到复杂的熟悉规律

代码比较:

Java Code Example:

import java.applet.*;

import java.awt.Gaphics;

public class HelloWorldApplet extends java.applet.Appple

{

public void init(){

resize( 200 , 150 );

}

public void paint( Graphics g){

g.drawString("Hello World" , 50 , 100);

}

}

C++ Code Example:

#include

class Hello :public Applet

{

public void init();

public void paint(Graphics g);

};

Hello::init()

{

resize( 200 , 150 );

}

......

我们看到,java开始就要求写函数的实现。而C++先要描述轮廓。再 写函数实现。

6.2. Java对从一般到非凡的思维方法支持的不好

从一般到非凡,是重要的思维方法。对应到计算机学科就是继续。而 今多继续的概念已经广为流传。比如我们说"小花猫",就是继续" 小"、"花"、"猫"三个概念。假如在字典上看到小花猫这个词, 它一定不再描述"小"、"花"、"猫"这三个概念,而是继续他们 。但是java只能继续其中的一个。对另外连个还要仔细的描述。写起 来是不是很烦。

6.3. Java设计不尊重"任何事物都有产生、发展、消亡的过程"这 一自然规律

Java没有析构函数。这一点很讨厌。我只想重复一遍"对象不都在内存空间中"。

6.4. Java 不能表达少数类之间的紧密相关

java要求每个类使用一个文件。这种实现可能和它的自动编译执行方 式有关。注重这种限制不是实现上问题,而是规范中的语句。但是这种方法合适吗?请看下面C++的例子。将这两个类分开为两个文件是

否真的好读?

strUCt menuitem{

StringstrX;

intiIndex;

};

class menu{

menuitem item[100];

... ...

};

和这种情况类似,javadoc也不能对紧密相关的数据进行描述。 至于类模板。java更是不支持。自己一个一个的慢慢写吧。

6.5. 批判Java的批判

Java要诞生,必须批判原有C/C++语言的缺陷。列举其中一二。 "C/C++语言中的整形数据不限制长度。这样一来当程序从32位系统 移植到16 位系统时会造成错误"。可是仔细想想。这种移植的概率 究竟有多少?

"Java不像C/C++,它完全不支持指针"。按此理论,同样不支持指 针的Fortran77和basic是不是也很强壮。

"Java不答应隐式类型转换"。假如整形和浮点数据之间的转换都要 写一下,是不是很烦。

"联合体、全局变量他们都不是面向对象的东西"。面向对象一直就 没有什么定义。本着好用的东西就是好东西的原则,保留这些概念也 不错。像M_PI这类的常量或者项目中的确全局相关的准常量,使用全局变量是不是很方便?至于联合体,是优化存储效率用的,像 Java 这种不考虑效率的语言自然不会支持。

"java存在比C++多的运算符"。似乎是多一些,他们是(字符串 +), > >> , (boolean)& and , instanceof。但是我们分析一下。由 于java不支持运算符重载,只好单独实现(字符串 +)。由于java 不 区分有符号和无符号数据,所以使用>>>来表达无符号右移、由于jav a中的boolean和整形之间没有联系,又不支持运算符重载,所以对bo olean类型单独实现& and 。至于instanceof的确是Java 独创,不 过这个运算符的用处还要考虑。我在引用某变量时居然能不知道它的类型?

6.6. 兼容以不兼容为代价使用java 必须一切从头开始。java不能继续原有的工作。而且它也 不能很好的和其他语言混合编程。这就和C++区别大了。首先C++继续了大部分C语言代码。其次,C++可以和Pascal , Fortran , Basic, T-SQL等其他语言方便混合。尤其方便的是ASM语言和 C++混合。发挥 不同语言的优点。俗话说"朋友多,天地宽"吗。而 java只能孤军 奋战了。

7. 结束语

写这篇文章用了一天半的时间。又在Java上花了这么多时间,真是心 痛。但愿有些效果。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有