我在餐饮哲学家问题上工作。为了使用我发现的这个循环分发叉子:
int philosophersNumber=5;
for (int i = 0; i < philosophersNumber; i++) {
philosophers[i] = new Philosopher(
i,
forks[i],
forks[(i + 1) % philosophersNumber]
);
}
- i : 哲学家的号码
- forks[i]:右手的叉子。
- forks[(i + 1) % phthalsNumber] : 左手的前叉。
如果我在循环中添加一些打印,输出如下所示:
----- PHILOSOHPER 0 ------
Right fork: 0
Left fork: 1
----- PHILOSOHPER 1 ------
Right fork: 1
Left fork: 2
----- PHILOSOHPER 2 ------
Right fork: 2
Left fork: 3
----- PHILOSOHPER 3 ------
Right fork: 3
Left fork: 4
----- PHILOSOHPER 4 ------
Right fork: 4
Left fork: 0
好吧,我的疑问很简单:为什么 (i+1) % 5 的结果总是与 i+1 相同,直到 i+1 为 5,即结果为 0?我想这与变量的类型有关,但我真的不知道。