[code]// db table primary key private int id;[/code]很常见吧,但是我在实际工作中遇到过不少的同事,系统定义一个名称可能为[code]BaseModel[/code]或者[code]RootModel[/code]的类,把上面的属性[code]id[/code]放在里面,然后整个项目中所有的model都继承这个BaseModdel类。不知道你们是否遇到过这样的同事?你们觉的这样写能有什么好处和坏处呢? 先说好处吧,如果非要说能带来什么好处的话,除了少敲几下键盘,在子类中少些了这些属性以外,没看见有啥[b]实质性[/b]的好处。但是却为项目后续的维护带来了很麻烦的事情。 然后说这种写法的潜在问题吧: [quote] 某一天,因为一些原因,你想找子类A(继承了BaseModel)中的属性[code]id[/code]在项目中的哪些地方使用 [/quote] 机智的你熟练的使用起了IDE中的[code]find usages[/code],然后你就会发现你找到的使用位置非常的多,而且好多压根不是你关心的。但是没办法,你也搜索到了其他的继承了BaseModel的类的属性id的使用位置。如果项目不大,可能搜索到的熟练比较少,如果项目大了一点呢?当搜索熟练超过了50处,你接下来会怎么做? [list] [*]一个一个看搜索出来的代码,看了十几二十个开始喷,然后继续一个一个往下找?[/*] [*]直接开始喷,然后在一个一个看搜索出来的代码?[/*] [/list] 如何避免出现这种情况呢,那就是不要使用类似这种[code]BaseModel[/code]的方式来使用属性继承。当然为了严谨期间,我还是需要详细说一下这个意思,我并没有完全反对属性继承哦,明确一下: [b]我反对的是整个项目所有的model继承一个BaseModel,然后把公用属性放在BaseModel中[/b] 的这种想法,注意是整个项目的 后记 上面的反面教材的例子我个人经常会碰见,所以单独拿出来说一下,我不确定在大家的项目中是否出现过这种情况。反正我已经被同事的这种写法坑过好多回了。 至于「组合」和「继承」其他相关的常见错误,我暂时还没想好(至少我觉的应该没人会犯),如果我后续想清楚了,或者读者朋友们有其他的建议希望可以留言交流一下哈。
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有