问题源自知乎问答:
做过五年对日外包,接触过一点Java,提供一些观察同事搞Java项目而得到的看法(本人主要在UNIX下写C和Shell):
语言本身:
Java语言是不是繁琐呢?手头有一本《Thinking in Java》中文第四版,数了一下正文共22章856页。随手翻一下,示例代码和讲解正文大概比例在1.5 : 1这样。没有真正用Java干过项目的人肯定会大为惊叹:我勒个去,这么多知识点!此为“繁”;
绝大部分搞编程的人,事实上,都是在使用一门语言的某个子集。该子集的形成由项目主导者发起、开发活动参与者共同决定,且相对长期稳定。每一个即将参与该项目的人肯定会先把语言学个大概(其难度参考前一条),然后再根据项目学习该语言子集,最后固化下来。不断使用该子集固然能提升开发效率,但代价不菲,极容易就变成了项目中的一颗镙丝钉(“专家”);
一门语言的设计肯定不会一蹴而就,一步步改良。没记错的话,Java诞生于1995年左右,到今天已经快满20年。在当时那种IT环境和条件下设计出来的语言,必然存在许多妥协、限制与错误,既不能随便将之抹除(可能还有很多工程依赖着),也不能随便更正,只能通过添加新语法、新类库来打补丁,导致语言更“繁”。举个例子,非内建容器类库是一个典型硬伤,再举个例子,时间日期类没见有多好用,也没见有更新过,连替代品都没见过(恕我不写Java,的确没见过);
类库(框架)丰富是好事还是坏事,要看针对同一个任务能找到多少替代品。如果有三到四个,那么肯定是好事,既不会造成单点故障,也不至于造成理解和记忆上的负担。但是类库太多,选择太多,人的幸福感反而会下降,高效率也就无从谈起;
框架真的可以保证快速开发吗?熟悉的话是可以的,专家编程嘛!但是a)熟悉之前要花非常多时间学习使用吃闷亏,b)框架只能免除掉一部分开发工作量,c)框架跟业务总是存在“不合缝”的差异,d)只不过将复杂度从开发转移到了部署运维,e)依赖性极强;
IDE可以提高开发效率吗?仅仅一部分罢了。IDE本身就是个非常复杂的东西,将之调校到符合个人开发步调的进程可能会持续很久,事实上大部分人也只是用一些常用功能罢了。而且a)基于图形界面意味着自动化不容易(需要编写额外插件),b)出了问题查找原因不易,c)依赖性极强;
Java本身是面向系统(机器)的,不是面向开发人员的。这种强设计保证有助于提升目标系统的可靠性,却牺牲了开发人员的幸福感。既然设计得如此严谨规范,为什么不能自动生成Java程序,而非得找一大票北大青鸟的人来写?
工程管理:
Java已经发展太久,太多项目依赖于它,“还在运行中的系统就不要去改动”,所以如果要选的话,后继项目可能还是会用Java。积累下来的项目资源不复用将是巨大的浪费,但同时也会将原有的设计错误、补丁、复杂度一并继承下来(能大赚一票当然好,但更好的是可以持续赚若干票);
Java的强系统可靠性保证影响了IT经理们的技术判断和选型。有些业务第一要求是“稳”,第二要求才是“快”。如果这类业务可以分解成细小任务并行执行,没有理由不用Java,硬件方面花钱买就是了;
IT经理们的技术选型影响着人才市场的供应。既然如此之多的公司和项目选择Java,那么对于人力资源供应异常丰富的中国而言,想借助初级IT能力就业那实在太容易了。反过来,人才供应丰富又进一步强化巩固Java的地位,因为能替换的人力部件实在太多了,还便宜(真的,学Java除非能跟业务搭上关系,否则用个五年十年都是白搭);
Java语言是“业界最佳实践”,意味着出错了不能责怪选它和用它的人,而得责怪整个业界捧错了它(参考《黑客与画家》)。
其它:
- 创业公司还是不要上Java,做快速原型这玩意确实不合适,做稳定业务则可以认真考虑;
- Java该革新了;
- 如果没有Sun和Oracle,Java又当如何?
1.完全同意。真挺“繁”的;2.正是因为绝大多数搞编程的都使用一门语言(某个子集),所以他们也不愿意去学另外一种语言(这个跟文化有关,像那些老外的老头子们好多不同范式的语言都写过,而且写得都挺好),不愿意去学(开阔眼界),所以也看不到java的优劣;3.你说的非常有道理,从另一个角度反映出java当初的设计很拙劣,像同时代的ruby,借大家优点集于一身;4.完全同意;5.大部分写java的程序员并没有用到IDE所能提供的代码重构功能,而IDE除了能够给java提供好的代码重构和代码提示外(这个代码重构和提示也是严重依赖于java语言本身,如果是动态语言,根本上就不可能出现那么精确的重构功能),其它的全是鸡肋;7.头一次遇到这种观点,基本同意,不同意的那部分还没想出来
工程管理:
1.完全同意;2.完全同意;3.完全同意,唉...;4.完全同意
其它:
1.完全同意,如果用java带来的好处没那么明显,那就不要用java
2.早该革新了,不过说了这么多年,没啥起色,所以.....java该死了
3.呵呵,有了Sun和Oracle,java又能怎的?
熟悉了一套技术,靠这个吃饭,吃完饭,玩玩兴趣爱好。
对于语言不做评论,各有千秋,否则微软也不会仿效。
2. 支持工具多,周围的生态系统很完善,效率更高,质量也容易保障。
3. 内存管理比C/C++方便,容易上手。
一看就没玩儿过C++