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,确保第一次进入第二关时正确初始化坐标。

相关推荐
进击的圆儿20 小时前
高并发内存池项目开发记录 - 02
开发语言·c++·实战·项目·内存池
YXXY31320 小时前
二叉树进阶
c++
夜晚中的人海20 小时前
【C++】使用双指针算法习题
开发语言·c++·算法
怀旧,20 小时前
【Linux系统编程】3. Linux基本指令(下)
linux·开发语言·c++
艾莉丝努力练剑20 小时前
【C++STL :stack && queue (三) 】优先级队列的使用以及底层实现
linux·开发语言·数据结构·c++·stl
earthzhang20211 天前
【1028】字符菱形
c语言·开发语言·数据结构·c++·算法·青少年编程
AA陈超1 天前
虚幻引擎5 GAS开发俯视角RPG游戏 P05-08 UI 部件数据表
c++·游戏·ue5·游戏引擎·虚幻
纵有疾風起1 天前
C++——类和对象(3)
开发语言·c++·经验分享·开源
承渊政道1 天前
动态内存管理
c语言·c++·经验分享·c#·visual studio
孤独得猿1 天前
聊天室项目开发——etcd的安装和使用
linux·服务器·c++·etcd