Lombok的构建器线程安全吗?

时间:2018-03-08 08:28:29

标签: multithreading thread-safety builder lombok

我有一个简单的对象

@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"

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个线程的测试方法。