Java 项目中的 service 分层和工程结构 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
cheava
V2EX    问与答

Java 项目中的 service 分层和工程结构

  cheava 2018-07-05 08:51:00 +08:00 2950 次点击
这是一个创建于 2660 天前的主题,其中的信息可能已经有所发展或是发生改变。

问下大家关于工程上的问题: service 层有没有必要分成接口和 impl ?

(项目没有对外系统提供服务)

我以前也是一直有分的,但是就以前项目来说,也确实感觉没有什么用处

能举一些例子说明吗?可能做的项目不是很大型,所以没感觉

15 条回复    2018-07-06 08:41:19 +08:00
zjp
    1
zjp  
   2018-07-05 09:00:52 +08:00 via Android
如果用到了动态代理就必须分接口和实现,其他的情况下没有强制的要求
micean
    2
micean  
   2018-07-05 09:04:37 +08:00
一般情况用不上
但也就 ctrl+左键 2 次的事
所以我不喜欢
cheava
    3
cheava  
OP
   2018-07-05 09:07:21 +08:00
@zjp #1 我能想到的也就是,aop 和事务管理需要
VoidChen
    4
VoidChen  
   2018-07-05 09:24:30 +08:00
除了以上,补充一个,为了找方法的时候好看一点(直接看接口)
ddbullfrog
    5
ddbullfrog  
   2018-07-05 09:26:25 +08:00
One of the main interests of using Spring is AOP. This is the technology that allows Spring to add new behaviours on top of your Beans: for instance, this is how transactions or security work.

In order to add those behaviours, Spring needs to create a proxy on your class, and there are two ways of creating a proxy:

If your class uses an interface, Spring will use a standard mechanism provided by Java to create a dynamic proxy.

If your class doesn ’ t use an interface, Spring will use CGLIB to generate a new class on the fly: this is not a standard Java mechanism, but it works as well as the standard mechanism.
ioc
    6
ioc  
   2018-07-05 09:29:03 +08:00 via Android
@ddbullfrog 意思就是没差咯
misaka19000
    7
misaka19000  
   2018-07-05 09:29:51 +08:00
感觉没有用处就不分
Cbdy
    8
Cbdy  
   2018-07-05 09:30:48 +08:00
不分,需要的时候再分。从实现抽象出接口不是一条命令的事情吗?不要过度设计
cheava
    9
cheava  
OP
   2018-07-05 09:36:29 +08:00
@Cbdy #8 我们目前内部定的规范就是,外部调用定接口,内部调用省略接口
JRay
    10
JRay  
   2018-07-05 09:45:31 +08:00
我也有过这种想法,一直没理解到接口和 impl 的用处在哪儿
swim2sun
    11
swim2sun  
   2018-07-05 09:48:28 +08:00
直接写成 class,如果有多个实现再抽象成接口也不晚啊,Java 重构起来很方便
Guozi1989
    12
Guozi1989  
   2018-07-05 09:53:57 +08:00
我这边是强制要求写接口,虽然我个人是及不愿意。逃~
li1215101
    13
li1215101  
   2018-07-05 13:55:30 +08:00
小项目不分,大项目分,方便看代码,Java service 的逻辑有时候写得比较乱,对外接口和逻辑搞一起很难看懂
tairan2006
    14
tairan2006  
   2018-07-05 16:30:16 +08:00 via Android
没啥球用,真有需要再重构
nl101531
    15
nl101531  
   2018-07-06 08:41:19 +08:00 via Android
重构的时候就会发现很实用了。另外接口的目的是制定协议,比较复杂的 service 我这边都会分开,比如订单流程,每一个类型订单都会有一个具体的 impl,而上层对外只需要一个接口就好了。
关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5389 人在线   最高记录 6679       Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 26ms UTC 08:27 PVG 16:27 LAX 01:27 JFK 04:27
Do have faith in what you're doing.
ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86