1 回答
TA贡献1780条经验 获得超4个赞
ZooKeeper 是服务器而不是 DTO
也许你想用 DTO 配置做一个 json
我的提议
public static void main(String[] args) {
ZooKeeper zoo;
try {
ZooKeeperConfDTO conf = new ZooKeeperConfDTO("localhost:2182", 5000, null);
zoo = runZoo(conf);
String json = new Gson().toJson(conf);
System.out.println(json); //---->{"connectString":"localhost:2182","sessionTimeout":5000}
} catch (Exception e) {
e.printStackTrace();
}
}
private static ZooKeeper runZoo(ZooKeeperConfDTO conf) throws IOException {
return new ZooKeeper(conf.connectString, conf.sessionTimeout, conf.watcher);
}
并创建了班级
import org.apache.zookeeper.Watcher;
public class ZooKeeperConfDTO {
public String connectString;
public int sessionTimeout;
public Watcher watcher;
public ZooKeeperConfDTO(String connectString, int sessionTimeout, Watcher watcher) {
this.connectString = connectString;
this.sessionTimeout = sessionTimeout;
this.watcher = watcher;
}
}
版本 2:
为 ClientCnxn 创建你的 TypeAdapter
import java.io.IOException;
import org.apache.zookeeper.ClientCnxn;
import com.google.gson.TypeAdapter;
import com.google.gson.stream.JsonReader;
import com.google.gson.stream.JsonWriter;
public class ClientCnxnAdapter extends TypeAdapter<ClientCnxn> {
@Override
public void write(JsonWriter writer, ClientCnxn cnxn) throws IOException {
writer.beginObject();
writer.name("sessionId");
writer.value(cnxn.getSessionId());
writer.name("timeOut");
writer.value(cnxn.getSessionTimeout());
writer.endObject();
}
@Override
public ClientCnxn read(JsonReader in) throws IOException {
return null;
}
}
并使用它
public static void main(String[] args) {
ZooKeeper zoo;
try {
zoo = new ZooKeeper("localhost:2182", 5000, null);
Gson gson = new GsonBuilder().registerTypeAdapter(ClientCnxn.class, new ClientCnxnAdapter()).create() ;
String json = gson.toJson(zoo);
System.out.println(json); //---->{"cnxn":{"sessionId":0,"timeOut":0},"watchManager":{"dataWatches":{},"existWatches":{},"childWatches":{}}}
} catch (Exception e) {
e.printStackTrace();
}
}
添加回答
举报