setter方法进行依赖注入

setter方法依赖注入

LoginController.java

public void setUserService(UserService userService) {
    this.userService = userService;
}

/**
 * 以前:耦合度太强,要降耦合
 */
//public LoginController() {
//    this.userService = new UserServiceImpl();
//}

为什么要用setter方法,用其他方法不行吗?

解耦合: 通过setter方法注入依赖,避免了在 LoginController 内部直接创建 UserService 实例,从而降低了类之间的耦合度。这使得 LoginController 类更加灵活,可以更容易地与不同的 UserService 实现进行替换或测试。

为什么是一个公共的方法?

在Java中,setter方法通常需要是公共的(public),以便能够在其他类或外部代码中访问和设置属性。Spring框架需要通过反射机制来调用setter方法来实现依赖注入,因此setter方法必须是公共的才能被Spring框架正确调用和设置属性。

设置setter和getter的方法快捷键

设置快捷键:FN + Alt + F12


applicationContext.xml

<bean class="cn.edu.guet.controller.LoginController" id="loginController">
    <property name="userService" ref="userService"/>
</bean>

<bean class="cn.edu.guet.service.impl.UserServiceImpl" id="userService"/>

怎么知道LoginController.java有没有调通UserServiceImpl.java?

在LoginController.java中编写测试方法:

public void login(String username, String password) {
    userService.login(username, password);
}

在SpringDemo.java中调用测试方法,如果能调用UserServiceImpl.java中的login方法说明依赖注入成功:

LoginController loginController = (LoginController) beanFactory.getBean("loginController");
loginController.login("1111", "1111");
<think>嗯,用户问的是枚举enum的setter方法。首先,我需要确认用户的问题背景。可能他们在使用Java或者其他支持枚举的编程语言时,想要修改枚举实例的值,但发现直接设置有问题,所以想知道如何正确实现setter方法。 首先,我得回忆一下枚举的特性。枚举在Java中是单例的,每个实例都是预定义的,通常设计为不可变的。所以直接给枚举字段加setter方法可能不太对,因为这会破坏不可变性。但用户可能确实有需求要动态改变枚举实例的状态,这时候可能需要考虑不同的设计方式。 接下来,我需要整理可能的解决方案。比如,如果枚举需要可变属性,可以在枚举中定义非final的字段,并提供setter方法。但得提醒用户注意线程安全和一致性问题,因为枚举实例本质上是静态的,多个线程修改可能导致问题。 另外,可能用户误解了枚举的用途,正确的做法应该是使用枚举作为常量,如果需要可变状态,或许应该用普通类代替。或者,采用包装类的方式,将可变状态封装在另一个对象中,枚举实例持有该对象的引用。 还要考虑线程安全的问题,如果多个线程同时调用setter,是否需要同步机制,比如synchronized方法或者使用原子类。 需要举例说明,比如定义一个带有setter的枚举,并指出潜在的问题。同时,给出更推荐的模式,比如使用不可变枚举,或者替代方案。 最后,总结使用setter的注意事项,强调枚举设计的最佳实践,确保用户明白在大多数情况下枚举应该是不可变的,而setter方法可能带来的问题,以及替代方案。</think>关于枚举(enum)的setter方法实现,以下是分步说明: 1. **基本特性理解** - 枚举类型本质是final类 - 每个枚举值都是类的单例实例 - 常规设计应为不可变对象 2. **可变字段实现步骤**(需谨慎使用) ```java public enum Status { OPEN("可用"), CLOSED("禁用"); private String description; // 非final字段允许修改 Status(String description) { this.description = description; } // Setter方法定义 public void setDescription(String description) { this.description = description; } public String getDescription() { return description; } } ``` 3. **使用时注意事项** ```java // 示例调用 Status.OPEN.setDescription("系统开启状态"); // 但会产生全局影响: System.out.println(Status.OPEN.getDescription()); // 输出"系统开启状态" // 所有使用Status.OPEN的地方都会受影响 ``` 4. **推荐替代方案** - **不可变设计**(最佳实践) ```java public enum Status { OPEN("可用"), CLOSED("禁用"); private final String description; // final字段 Status(String description) { this.description = description; } // 仅提供getter public String getDescription() { return description; } } ``` - **状态包装模式** ```java public class StateWrapper { private Status status = Status.OPEN; public void setStatus(Status newStatus) { this.status = newStatus; } } ``` 5. **线程安全警告** - 若必须使用setter,建议添加同步控制 ```java public synchronized void setDescription(String description) { this.description = description; } ``` 6. **设计原则建议** - 优先保持枚举不可变 - 需要动态属性时考虑组合设计 - 若必须修改状态,确保做好文档说明 - 考虑使用配置类承载可变状态 总结:虽然技术上可以实现枚举的setter方法,但会破坏枚举的常量特性。建议仅在特殊场景下谨慎使用,多数情况下应通过重构代码结构来满足需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值