使Spring bean的行为类似于ExecutorService的ThreadLocal实例

使Spring bean的行为类似于ExecutorService的ThreadLocal实例,第1张

使Spring bean的行为类似于ExecutorService的ThreadLocal实例

首先,放弃

ThreadLocal
-这个班级有些可怕。您需要的只是对象池。它不是一个众所周知的功能,但是Spring也支持此功能:

<bean id="engineProto"  scope="prototype" lazy-init="true"/><bean id="engine" >    <property name="targetSource">        <bean > <property name="targetClass" value="Engine"/> <property name="targetBeanName" value="engineProto"/> <property name="maxSize" value="3"/> <property name="maxWait" value="5000"/>        </bean>    </property></bean>

现在,当您注入时

engine
,您实际上将收到代理对象(
Engine
将需要一个接口),该代理对象会将所有调用委派给池中的空闲对象。池大小是可配置的。当然,没有什么阻止您使用
ThreadLocalTargetSource
哪个使用
ThreadLocal
代替Commons
Pool
。两种方法均保证对线程的独占,线程安全访问
Engine

最后,您可以手动使用池化(但是上面解决方案的优点在于它是完全透明的)或切换到按定义池化的EJB。



欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5501652.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-12-12
下一篇2022-12-12

发表评论

登录后才能评论

评论列表(0条)

    保存