У меня есть два типа полезных данных, поступающих из восходящего потока: это либо PayloadA
, либо PayloadB
. PayloadA
имеет много полей по сравнению с PayloadB
, но есть некоторые общие поля между PayloadA
и PayloadB
. Чтобы сделать пример проще, я добавил только несколько полей.
Ниже приведен класс построителя для PayloadA
:
public final class PayloadA {
private final String clientId;
private final String langid;
private final String deviceId;
private final Map<String, String> applicationPayload;
// other fields as well
private PayloadA(Builder builder) {
this.clientId = builder.clientId;
this.langid = builder.langid;
this.deviceId = builder.deviceId;
this.applicationPayload = builder.applicationPayload.build();
}
public static class Builder {
protected final String deviceId;
protected String clientId;
protected String langid;
protected ImmutableMap.Builder<String, String> applicationPayload = ImmutableMap.builder();
public Builder(String deviceId) {
this.deviceId = deviceId;
}
public Builder setClientId(String clientId) {
this.clientId = clientId;
return this;
}
public Builder setLangid(String langid) {
this.langid = langid;
return this;
}
public Builder setPayload(Map<String, String> payload) {
this.applicationPayload.putAll(payload);
return this;
}
public PayloadA build() {
return new PayloadA(this);
}
}
// getters and to string here
}
Ниже приведен класс для PayloadB
:
public final class PayloadB {
private final String clientid;
private final String type;
private final String payId;
// other fields as well
private PayloadB(Builder builder) {
this.clientid = builder.clientid;
this.type = builder.type;
this.payId = builder.payId;
}
public static class Builder {
protected final String type;
protected String payId;
protected String clientid;
public Builder(String type) {
this.type = type;
}
public Builder setPayId(String payId) {
this.payId = payId;
return this;
}
public Builder setClientId(String clientid) {
this.clientid = clientid;
return this;
}
public PayloadB build() {
return new PayloadB(this);
}
}
// getters and to string here
}
Теперь я создал еще один класс, который является классом Payload
, в котором у меня есть все общие поля как для PayloadA
, так и для PayloadB
, поэтому мне также нужно как-то установить эти поля, и я не уверен, как использовать класс ниже:
public abstract class Payload {
private long createTimestamp;
private String key;
// some other fields are here
// getters and setters here
}
Вопрос:
Теперь из приведенного ниже кода я делаю либо PayloadA
, либо PayloadB
в зависимости от того, что передается.
private void run(String name) {
// .. some code here
if (name.equalsIgnoreCase("PayloadA")) {
Payload payload =
new PayloadA.Builder(getDeviceId()).setClientId("someid").setLangid("anotherid")
.setPayload("some map").build();
DataProcessor.getInstance().process(payload);
} else {
Payload payload =
new PayloadB.Builder(getType()).setPayId("someid").setClientId("anotherid").build();
DataProcessor.getInstance().process(payload);
}
}
И в методе DataProcessor
process
:
private void process(Payload payload) {
// 1) here I need to set createTimestamp and key variables on payload bcoz they are common
// fields.
// 2) Also how can I figure out whether payload is PayloadA or PayloadB here?
}
Теперь, как я могу установить переменные createTimestamp
и key
, которые находятся в классе Payload
, в методе process
? Прямо сейчас у меня есть метод запуска, в котором я различаю его, но в целом у меня будет другой исходный код для PayloadA и другой восходящий код для PayloadB, поэтому в зависимости от этого мы будем использовать любой из классов Payload.
Также я должен иметь здесь двух разных строителей или одного большого строителя, который будет делать все?