下面的obj操作是线程安全的吗?我知道方法级别的变量和实例放在每个线程的堆栈上-但我不确定当局部变量是单例时会发生什么。foo()在foo服务调用中调用。我很好奇这是不是线程安全的?
public void foo() {
SomeObject obj = getSomeObject();
obj.doSomething(); // Would this be thread safe?
}
private SomeObject getSomeObject() {
// returns singleton
SpringContext.getBean("someObject");
}
class SomeObject {
int x;
...
// Not synchronized
public void doSomething() {
}
}发布于 2012-09-06 02:22:06
这取决于你所谓的“线程安全”是什么意思。如果SomeObject.doSomething()以不安全的方式改变实例,那么不,它是不安全的。两个不同的线程可以获得对同一对象的引用。
基本上,除非将SomeObject设计为可从多个线程并发使用,否则不应将其设置为单例。
发布于 2012-09-06 02:21:23
只有当SomeObject本身是线程安全的时,它才是线程安全的。例如,如果您在doSomething()调用中读取并可以更改x的值,那么它就不是线程安全的,除非它被适当地锁定。
如果不了解更多关于SomeObject的知识,就不可能准确地判断您是否会遇到问题。
发布于 2012-09-06 02:24:02
在进行任何静态引用时,方法/线程的局部性可能会完全丢失。由于引用是静态的,指向静态引用的本地字段不在线程堆栈上,因此它实际上可能会被其他线程引用。
如果对象是全局赋值的,而不是线程局部赋值的,则具有相同的线程安全效果。
final SomeObject obj = getSomeObject();
public void foo() {
obj.doSomething();
}
private SomeObject getSomeObject() {
// returns singleton
SpringContext.getBean("someObject");
}https://stackoverflow.com/questions/12287478
复制相似问题