java开发牢骚

1.关于解耦

这个词自从接触设计模式以来,便整天萦绕耳边,以前觉得不错,但是最近越来越觉得像苍蝇了,能多恶心你就多恶心你.

本来解耦无可厚非,高内聚,低耦合谁都懂的道理,但是现在,这个词真的被滥用了.


解耦不过是一个用来迷糊人的手段,是追求过度设计的人显摆的工具

只有真正的内聚,没有绝对解耦,但凡你在某个地方切断联系,那么你必然会在另一个地方重新产生联系

通常来说,切断联系的地方就在于方法的调用(或者对象的实例化),而重新产生联系的地方就在于框架

物体被打碎以后,需要重新黏合在一起才能使用

代码被解耦以后,同样需要再次耦合起来完成功能

物体的黏合除了人还需要粘合剂

而对于代码来说,同样需要粘合剂,这里的粘合剂就是配置文件或者注解


本来嘛,不变的东西,用基类实现,不同的行为用子类复写,对于外界的调用,可以定义一个接口

现在倒好,搞一大堆配置文件,声称是解耦,可是配置文件改动的地方没有十分之一

把一个功能拆分到五六个方法里面,声称是为了代码复用,除了你用,别人根本不知道在什么地方

一个包含了全部逻辑的方法,拿到哪里都能用,现在呢,解耦了,复用去吧,离开框架你屁都不是,还解耦呢!


以前代码的整体感没有了,现在就是把一个完整的躯体给直接给肢解了,把关注的部分留下来,其他的都送给框架了,

送些衣服可以,可是如果连肉都送了,那么你的代码还真解不了藕,因为没有了血肉就是死


比较Struts1和Struts2两种框架,我承认后者配置更简单,但是谁要跟我说它有优点,简直是TMD的放屁:

1)与Web容器完全解耦

解个屁耦,难道Struts不是一个Web框架么?哪里能少得了Servlet API?没有Servlet,Struts屁都不是,

敢问有几个利用Struts而不是做Web开发的?

就算你解耦又如何?我还不是需要Request对象和Response对象?我使用了ContextUtil也能算解耦呢?

做Web开发又去和Web解耦,真是闲得蛋疼!

2)更容易测试,Web工程里面的逻辑有几个是脱离了Web环境来测试的?

不需要Web环境的代码段我可以单独放一个方法里定义,用得着使用Struts2来解耦?

3)Struts2比Struts1更容易理解,完全是放屁

不看文档,鬼知道从哪里获取Request对象和Response对象!

而且一个action又做M又做C,干脆你连V也做了,不更省事?不过话说这样的话,我还用得着框架?


2.关于接口

接口无非一种规范,我可以实现,也以不实现,我可以实现你想要的,也可以实现你不想要的;

不过用来约束的一种玩意儿,可是某些人却认为接口优于一切,没有接口就意味着不规范

于是,凡是逻辑处理类,一律xXXXX和xXXXXImpl,神马都是接口

接口是挺好,但是真的需要到处都用么?你的逻辑永远都不会改变,你整个接口到底是为什么?

仅仅是为了规范么?但是没有接口就不规范么?


3.关于IOC

自从Spring将IOC发扬光大以后,便言必称IOC,因为有了IOC,连接口都可以不用了

现在的Java已经走火入魔了,当C++返璞归真趋于平淡的时候,Java不知何事开始流行起奇技淫巧来了

仿佛学Java如果你不懂IOC,如果你不懂DI,如果你不懂AOP,如果你不懂Annoation,如果你不懂AspectJ,如果你不懂cglib,你就out了

IOC离不开配置文件,现在或者可以说离不开注解

真的很方便么?效率的低下尚且不说,调试的麻烦姑且不论,但是代码的理解还有可读性么?

你不跳出框架来看,你永远搞不明白它的逻辑

本来简单的几行代码就可以搞定,现在却要不停地在代码和配置文件直接跳来跳去

或者从一堆堆Annoation中找出你所需要的那几行.

4.关于Annoation

本来很反感XML的配置文件,仿佛和我一样的人大有人在,所有现在Annoation开始盛行

不过现在看来我倒是有点觉得XML没有那么反感了

至少,XML能让我感觉到代码的清爽,可是那么多的Annoation,真是惨不忍睹啊?

XML可以避免重新编译,而Annoation呢?

答案就是避免XML,直接写代码也能避免XML,需要Annoation干嘛呢?

又是为了俗不可耐的解耦?算了吧?即使解耦你就不需要写代码了?

改一段逻辑清晰的代码,比改一个个完全不明所以的注解容易多了

除非你去看注解的源码,或者相信注解的注释文档
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值