-
类方法调用设计为类属性还是传参好?
1.从封装角度看。这样的方法签名,表达能力不强,没交代清楚输入,调用者需要了解被调用代码细节,才能知道需要给哪些属性赋值。如果不同程序集,不同人员一同开发会有不小沟通障碍,一旦被调用方法参数有变要通知调用方,否则可能出现bug。2.从接口角度看。基于第一点,很难形成接口,因为接口功能之一是定义输入输出的规范。3.从维护角度看。首先,代码是你自己写的,自然觉得问题不大,但是如果别人来做代码的维护,单看调用不看被调用方法的代码细节,确实不知道怎么改。其次,如果被调用方法所需参数数量发生变化时,那么调用代码的对象实例的属性需要相应的新增和修改,这个做不到自动重构,需要查找引用,然后手工一个个改,可能存在漏改;如果不改,多余的属性赋值显然会影响以后阅读。如果是指明参数个数和类型,起码编译的时候可以报错。4.从隐藏Bug角度看。基于第三点,如果被调用方法体内部对参数使用个数等的修改,然后,调用没有同步修改,可能隐含造成bug(方法体新增参数的时候,调用没有同步新增属性的赋值)。5.从泛型编程角度看。这样子的设计,难用泛型来编程,因为你需要给具体类型的具体属性赋值后才调用方法。如果按照这样的思路,我一般更倾向于使用实体类作为参数。例如://以下DAOpublic IDAO<TEntity> where TEntity : EntitieBase, new(){Add(TEntity);Update(TEntity);}public abstract class DAOBase<TEntity, TDataContext> : IDAO<TEntity> where TEntity : EntitieBase, new() where TDataContext : DbContext, new(){protected TDataContext dataContext;public TDataContext DataContext { get { return dataContext; } }Add(TEntity){ DataContext.Add(TEntity);TEntity.ID = Guid.newd.tos();}}public class DaoUser : DAOBase<User, EFEntities>//以下BOpublic abstract class BOBase<TEntity, TIDAO> where TEntity : EntitieBase where TIDAO : IDAO<TEntity>{protected ICacheManager CacheManager;protected ILogManager LogManager;protected ITranstionManager TranstionManager;protected <T>ServiceLocator{//ioc容器} private TIDAO dao; public TIDAO Dao { get set }Add(TEntity){Dao.Add(TEntity);}}public class BoUser : BOBase<User, DaoUser>
-
相关阅读:
170322操作系统定义、功能、位置与历史
java 多线程
java 网络编程TCP程序设计
java 事件处理机制
java GUI编程
170321php3第4章 PHP5的基本语法+作业九九乘法表
170320网络编程 udpclient udpGroupClient
二叉树线索化
哈希表
二叉搜索树
-
原文地址:https://www.cnblogs.com/caryfang/p/5000446.html
Copyright © 2020-2023
润新知