本篇内容介绍了“MonoState单一状态模式的实例用法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
MonoState 单一状态模式
public class SqlRequest {
private String sqlRequest;
public SqlRequest(String sqlRequest) {
this.sqlRequest = sqlRequest;
}
public String getSqlRequest() {
return sqlRequest;
}
public void setSqlRequest(String sqlRequest) {
this.sqlRequest = sqlRequest;
}
}public class DataBase {
private String name;
public DataBase(String name) {
this.name = name;
}
public void read(SqlRequest sqlRequest) {
System.out.println(name + " 接收到参数" + sqlRequest.getSqlRequest());
System.out.println(name + " 并读取数据 123");
}
public void write(SqlRequest sqlRequest) {
System.out.println(name + " 接收到参数" + sqlRequest.getSqlRequest());
System.out.println(name + " 并向数据库写入数据 456");
}
}public class DataBaseBalancer {
public DataBaseBalancer() {}
private static int lastServedId;
private static List<DataBase> dataBases = new ArrayList<>();
static {
dataBases.add(new DataBase("数据源1"));
dataBases.add(new DataBase("数据源2"));
}
public synchronized void serverRequest(SqlRequest request) {
if (lastServedId >= dataBases.size()) {
lastServedId = 0;
}
DataBase dataBase = dataBases.get(lastServedId++);
dataBase.write(request);
dataBase.read(request);
}
}public static void main(String[] args) {
DataBaseBalancer dataBaseBalancer1 = new DataBaseBalancer();
DataBaseBalancer dataBaseBalancer2 = new DataBaseBalancer();
dataBaseBalancer1.serverRequest(new SqlRequest("请求1"));
dataBaseBalancer2.serverRequest(new SqlRequest("请求2"));
}“MonoState单一状态模式的实例用法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注天达云网站,小编将为大家输出更多高质量的实用文章!