我有一个简单的对象
@Data
@Builder
public class Address {
private Long id;
private String street;
}
我制作@Builder
注释的delombok,我看到下一个代码生成
@Data
public class Address {
private Long id;
private String street;
@java.beans.ConstructorProperties({"id", "street"})
Address(Long id, String street) {
this.id = id;
this.street = street;
}
public static AddressBuilder builder() {
return new AddressBuilder();
}
public static class AddressBuilder {
private Long id;
private String street;
AddressBuilder() {
}
public AddressBuilder id(Long id) {
this.id = id;
return this;
}
public AddressBuilder street(String street) {
this.street = street;
return this;
}
public Address build() {
return new Address(id, street);
}
public String toString() {
return "Address.AddressBuilder(id=" + this.id + ", street=" + this.street + ")";
}
}
}
看着这个我看到构建器是我的Address类的一些静态内部类。
让我们假设我有2个线程使用builder
并行执行。
第一个线程创建此局部变量
Address address = Address.builder()
.id(1L)
.street("street 1")
.build();
第二个创建本地的
Address address = Address.builder()
.id(2L)
.street("street 2")
.build();
期待使用静态类的lombok的实现是否可能并行运行我有时会在其中一个线程中有一个对象id=1L street="street 2"
或id=2L street="street 1"
?
答案 0 :(得分:4)
它是线程安全的。在方法构建器中,创建了一个新的AddressBuilder对象,因此它始终使用新对象。这些方法只使用局部变量,没有共享变量。
为了测试这个,我写下了wollowing单元测试:
import com.anarsoft.vmlens.concurrent.junit.ConcurrentTestRunner;
@RunWith(ConcurrentTestRunner.class)
public class TestLombok {
@Test
public void testOne()
{
Address address = Address.builder()
.id(1L)
.street("street 1")
.build();
}
@Test
public void testTwo()
{
Address address = Address.builder()
.id(2L)
.street("street 2")
.build();
}
}
使用vmlens,一种检测竞争条件的工具,并没有按预期找到任何种族。
单元测试中使用的ConcurrentTestRunner正在运行并行4个线程的测试方法。