flag使用错误出现bug

bug代码

cpp 复制代码
//第一关、第二关第一次进入的时候的标记变量
int flag1 = 1, flag2 = 1;

int main() {

	while (!gameOver) {

		if (level == 1 && flag1 == 1) {
			currentpr = rk[0][0];
			currentpc = rk[0][1];
			newpr = currentpr;
			newpc = currentpc;
			flag1 = 0;
		}
		/*
			出现bug的代码
		*/
		//else if (level == 2 && flag2 == 2) {

		/*
			
		*/
		else if(level == 2 && flag2 == 1){
			currentpr = rk[1][0];
			currentpc = rk[1][1];
			newpr = currentpr;
			newpc = currentpc;
			flag2 = 0;
		}

		system("cls");//清屏
		showMap();
		showMenu();

		if (isSuccess()) {
			if (level == 1) {
				cout << "逃出成功!" << endl;
				cout << "下一关" << endl;
				cout << "是否继续游戏?(Y/N)" << endl;
				cin >> direction;
				if (direction == 'Y') {
					level++;//下一关
					continue;
				}
				else {
					cout << "游戏结束,欢迎下次游玩。" << endl;
					break;
				}
			}
			else if (level == 2) {
				cout << "逃出成功!" << endl;
				break;
			}
		}

		input();
		move();
	}
	return 0;
}

Bug 原因分析

在第二关初始化逻辑中,flag2的判断条件错误,导致第二关的初始坐标未被正确设置,进而无法移动。

具体来看这段代码:

cpp 复制代码
else if (level == 2 && flag2 == 2) {  // 条件错误
    currentpr = rk[1][0];  // 第二关入口坐标(0,2)
    currentpc = rk[1][1];
    newpr = currentpr;
    newpc = currentpc;
    flag2 = 0;
}
  • 全局变量flag2初始值为1int flag2 = 1;),但判断条件写成了flag2 == 2,导致该分支永远不会执行。
  • 因此进入第二关时,currentprcurrentpc仍保留第一关结束时的坐标(而非第二关入口(0,2)),而该坐标在map2中可能是墙壁(非空格),导致move()函数中始终触发 "回退" 逻辑,表现为无法移动。

Bug 解决方案

修正第二关初始化的flag2判断条件,将flag2 == 2改为flag2 == 1,确保第一次进入第二关时正确初始化坐标。

相关推荐
Mr_WangAndy5 小时前
C++设计模式_创建型模式_原型模式Prototype
c++·设计模式·原型模式
奔跑吧邓邓子5 小时前
【C++实战㊷】C++ 原型模式实战:从概念到高效应用
c++·实战·原型模式
奔跑吧邓邓子5 小时前
【C++实战㊶】C++建造者模式:复杂对象构建的秘密武器
c++·实战·建造者模式
奔跑吧邓邓子6 小时前
【C++实战㊵】C++抽象工厂模式:解锁高效对象创建的密钥
c++·实战·抽象工厂模式
jf加菲猫6 小时前
条款11:优先选用删除函数,而非private未定义函数
开发语言·c++
怀旧,8 小时前
【C++】23. C++11(上)
开发语言·c++
小卡皮巴拉8 小时前
【笔试强训】Day1
开发语言·数据结构·c++·算法
初圣魔门首席弟子8 小时前
友元类和友元函数bug
bug
初圣魔门首席弟子8 小时前
switch缺少break出现bug
c++·算法·bug