前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >java最困扰你的那些事?又将如何解决?

java最困扰你的那些事?又将如何解决?

作者头像
IT架构圈
发布2018-06-01 11:28:29
7780
发布2018-06-01 11:28:29
举报
文章被收录于专栏:IT架构圈

没有,没有,还是没有

没有无符号的×××。

没有操作符重载。

没有对象属性。

没有代理 (尽管我听说 Java 8 中可能引入了代理或类似机制,但我还没细看)。

我同样痛恨很多 Java 库中引入模块的方式(比如根据名称加载模块)。相对而言,我更希望在编译时就能检查我需要的依赖库是否已经加载了。

找不到爱…

我恨 Java,就是单纯的恨。负责任地说,我从不使用 Java 写程序的最大因素就是因为我恨它。还有一点就是JRE糟糕的模块化。就算你用了一些加载工具比如Launch4j,你仍然需要让用户安装一个超过200 MB 的框架来运行程序。

没有getter、setter

Java还缺少getter和setter注解。这样可以更简单的添加和移除模板代码。

缺乏亮点

Java 缺少一些杀手级的模块。虽然听说一些不错的模块将被加入到Java 9.x 中,但目前为止这是我最大的槽点了。

非暴力不合作

我遇到的最大的麻烦就是如何一起使用基本元素和对象。例如, 把一个char[] 类型的变量转换成一个列表别提有多费劲了,而且我感觉这种操作根本没必要这么麻烦。

给大家推荐一个java内部学习群:725633148,进群找管理免费领取学习资料和视频。没有错就是免费领取!大佬小白都欢迎,大家一起学习共同进步!

心愿单

我最想要的就是像 Perl 中那种上下文相关的函数了,以及当处理真正的异常时,这些函数可以在一个语言中所扮演的角色。

我还希望 Java 可以支持智能打包返回值,这样我们就可以像在Perl中那样返回一个包含多个值的列表了。

我希望使用异常的标准库还可以在不适合抛出异常的场景下使用并能够处理失败。

还有,另一个烦人的地方就是我在用 StringWriter 时候还要处理 IO 异常。

还缺些什么

缺少宏对我来说使 Java 减分不少(我并不说在 C/C++ 中使用的预处理器宏,而是在Lisp/Scheme 中使用的那种宏)。

不论做什么事情你都需要定义一个类,尽管你可能根本不需要一个类。比方说,我想把一段经常使用的代码提取出来,然后在需要地方使用——为了达到这个目的,我必须要把这段代码封装成一个final static的方法,并放在一个类中。这样一来我还得费劲去给类取一个方便理解的名字……本来这事儿可以很简单(这确实很简单, 尤其是当你可以定义宏的时候)。

有没有搞错

缺乏对泛型的支持。C++ 中的模板要强大的多。

事实上,在Java 中你根本不能在泛型中实例化一个类,除非你把这个类作为参数来声明一个泛型。

你很难给一个类加上结构函数并让它销毁这个类。RAII(一种资源管理模式,见 C++)却一直非常有用。

没有操作符重载。C++ 允许你是将 == 操作符用于比较字符串。同样的,大整数运算因为同样的原因变的很难使用。

呃, 好吧

没有无符号的基础类型。这尼玛是闹哪样啊!

还是getter、setter

1、null(最大槽点)。

2、没有getter和setter注解(例如,没有属性)。

3、Java 只支持位置参数。我喜欢像Smalltalk 那种支持多样化的参数形式,或者是强制使用关键字参数的Python 3。

比如在 Samlltalk 中调用一个具有两个参数的函数,可以这样做:

myInstance myMethodWithFoo: arg1 Bar: arg2

在 Python中你可以使用下面的语法来调用函数并给函数参数赋值:

my_inst.my_method(foo=arg1, bar=arg2)

4、……不支持多分派(Multiple Dispatch)?

这些是我最先想到的,不过觉得应该还有更多。认真地说,使用回调函数一直是一个大问题,因为它太麻烦了。不过Java 8 中解决了这个问题,我还是很开心的 =)

愚蠢的默认值

默认的可见性。如果没有给变量或方法一个修饰符,那么这个方法应该是私有的,而不是包内可见。

默认的修改能力。最终类型(在所有情况下)应该是默认的,并用“var”作为修饰符。目前的情况是,程序员很少会把一个方法的参数设置为最终类型,因为那样会让变量很快变得不可读。同时,在一个方法中重写参数也是很少见的情况。

集合接口。Java 中应该提供一个可写的集合接口,现在集合继承自这个可写的接口,只是把所有改变集合内容的方法屏蔽掉。这样就会减少现在你会在Collections.unmodifiable……() 和一些第三方的API中见到的那些令人困惑的历史遗留方法。有了可写的集合接口,Java 将会变得更加类型安全。

缺少表达能力。在用过Scala (或是最新的PL)之后, 你会觉得Java 非常的繁琐。这是最常见的关于Java 的吐槽,但它这就是事实。

说说异常

被强迫的处理异常——真主保佑你。谁能告诉我为什么我非要用try-catch 来包裹每一个Thread.sleep() ……?我从来就没有真正见过那个我被要求去处理的InterruptedException。

我知道我要说的可能不是一个广泛认可的问题,但是我真的同意checked exception(应被检查的异常)很烦人。这些异常让代码变得面目全非还让重构变得不可能。我明白他们为什么存在(而且理论上也说的通),但是他们没为开发者带来什么实质好处。不论你做什么,都不要留一个空的catch 块,就算你认为这个异常永远不会发生。你大可以把这个checked exception用RuntionException(运行时异常)重新封装一下,再抛出去。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-03-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 编程坑太多 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档