Java采用 Theaker & Brookes 提出的消息传递算法 实现“下棋模型”

// 读请求,等待可执行条件,然后回复

MySocket socket;

public Watcher(int role, Turn turn, MySocket socket) {

this.role = role;

this.turn = turn;

this.socket = socket;

}

private String toRole(int r) {

return r == 0 ? “黑方” : “白方”;

}

@Override

public void run() {

// 如果到达流的末尾,则返回-1 。

while (true) {

// 受到客户端请求下棋的请求

try {

if (socket.receive() == -1) {

System.out.println(“通信结束”);

break;

}

} catch (IOException e) {

e.printStackTrace();

}

// System.out.println(“受到”+toRole(role)+“请求; 当前是”+toRole(turn.role)+“阶段”);

try {

synchronized (turn){

// 1 表示许可; 0 表示拒绝

if (role == turn.role) {

System.out.println("服务器 ———————— "+

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值