我目前正在编写贪吃蛇游戏。简单来说,我遇到了一个关于if语句的问题。让我困扰的部分是检查蛇是否与自身碰撞的方法。
if语句如下:
public void checkCol(){
for(int i = 0; i < snake.getLength(); i++){
if((snake.getXPosArray()[snake.getLength() - 1] == snake.getXPosArray()[i])
&& (snake.getYPosArray()[snake.getLength() - 1] == snake.getYPosArray()[i])){
gameOver();
}
}
}
请耐心阅读以下的文字。这段代码的意思是,如果蛇头与蛇身的任何其他部分具有相同的坐标,则游戏结束。
最初,蛇的长度为3,并由坐标数组控制。因此,在循环的第一轮中将检查:
xPos[2] == xPos[0] and the same with yPos[2] == yPos[0]
xPos[2] = 88 , xPos[0] = 66 , yPos[2] = 55 , yPos[0] = 55.
当我运行程序时,蛇立即停止。这很奇怪,因为我检查了方法将要获取的值。上面显示的值是我的if语句检查的值。现在我相信88和66不相等。
我在论坛上寻找更好的关于"&&"运算符的解释,并且一篇帖子告诉我,如果第一个语句为true,"&&"仅会检查两个语句。而单个"&"将检查是否两个参数都为true。但我使用"&"和“&&”得到了相同的结果。
我是否忽略了某些微小的东西?我太累了吗?您能否看出这个语句有什么问题?并告诉我它为什么认为88 == 66?
谢谢您抽出时间!