Mar*_*ret 5 java casting interface
我在课堂上有点挣扎.让我设置场景.我有使用服务和协调器层的java服务器代码.请求以bean格式(与前端视图对齐的java类)进入服务层,然后我有一堆domainBeanMapper类,它们采用bean格式对象并将其转换为域格式对象.例如,UserBean具有由字符串表示的dateOfBirth,而User具有由Date表示的dateOfBirth,因此UserMapper.java将日期字符串变为日期对象.因此,对于系统中的每个对象,我都有*.java,*Bean.java和*Mapper.java(User.java,UserBean.java,userMapper.java).
在applicationContext中,我保存从每个对象到它们的映射器的关系,如下所示:
<util:map id="domainBeanMappers">
<entry key="UserBean" value-ref="userMapper" />
<entry key="User" value-ref="userMapper" />
.....
Run Code Online (Sandbox Code Playgroud)
然后我定义映射器:
<bean id="userMapper" class="com.me.mapping.UserMapper" parent="baseDomainBeanMapper"/>
Run Code Online (Sandbox Code Playgroud)
我从我的服务层调用这样的域bean映射器:
UserBean userBean = (UserBean) getDomainBeanMapper().mapDomainToBean(user);
Run Code Online (Sandbox Code Playgroud)
在这段代码的运行中,我找到了我想要的mapper对象:
DomainBeanMapper mapper = findApplicableMapper(myObject.getClass().getName());
if (mapper == null) {
mapper = findApplicableMapper(myObject.getClass().getSimpleName());
}
Run Code Online (Sandbox Code Playgroud)
findApplicableMapper的工作方式如下:
private DomainBeanMapper findApplicableMapper(String string) {
return domainBeanMappers.get(string);
}
Run Code Online (Sandbox Code Playgroud)
在过去的几年里,这就像一个魅力.对于我想要在系统中的任何对象,我可以轻松地选择相关的映射器,然后根据任何实例的.getClass()调用从我的bean格式转换为域格式,反之亦然.
现在,我有一个新的要求,给我带来麻烦.我希望能够根据参数从我的User对象转换为多个子对象.所以对于一些调用,我只想要id,firstName和lastName.对于其他调用,我想要更多字段,但仍然不是整个对象,然后对于某些调用,我希望像以前一样返回整个对象.我不想沿着子对象路径走下去,最终得到UserLight,UserLightWithName,UserLightWithNameButNoAddress,......噩梦.
所以相反,我希望创建一堆代表"视图"的接口.因此,请求带有ViewType of Basic,这意味着我想要用户的个人详细信息和地址.所以我编写了一个名为UserBasic的接口,让User实现它,并添加了从UserBasic到UserBasicMapper的映射,以及从UserBasicBean到UserBasicMapper的映射,希望我可以像这样进行转换调用:
UserBasicBean restrictedUserReturn = (UserBasicBean) getDomainBeanMapper().mapDomainToBean((UserBasic)user);
Run Code Online (Sandbox Code Playgroud)
但是这不起作用,因为getClass()总是返回实例类,而不是它所转换的接口.我想我总是可以在mapDomainToBean调用中添加另一个参数,这是我想要使用的类,但代码库非常庞大,如果我进行了更改,我将需要触及每个调用.
所以基本上我正在寻找一种方法将实例转换为接口类型,然后找到该接口类型?这可能吗??
穿过手指 ......
与其制作用户实现的接口,为什么不制作代表有限版本的代理类呢?例如,
class UserBasic {
private User user;
public UserBasic(User user) {
this.user = user;
}
public String getFirstName() {
return user.getFirstName();
}
...
}
Run Code Online (Sandbox Code Playgroud)
然后您可以添加 agetUser() { return user; }以获取完整的实例。
这样,您应该能够保持其他所有内容相同,并通过接口对类进行权衡。
| 归档时间: |
|
| 查看次数: |
185 次 |
| 最近记录: |