我的程序出现 abort() 错误,但由于它是程序的加载部分,我无法调试它?
Posted
技术标签:
【中文标题】我的程序出现 abort() 错误,但由于它是程序的加载部分,我无法调试它?【英文标题】:My program gets an abort() error yet i cant debug it due to it being a loading part of the program? 【发布时间】:2016-08-19 04:18:58 【问题描述】:每次我启动这个应用程序时,它都会进入完美运行的菜单,但是在我点击 start() 之后它就中止了,我有一个理论认为它是 stoi,但我不确定。如您所见,我正在制作二十一点游戏,它使用数组然后 rand() 从数组中随机化,但随后必须将数组中的字符串转换为整数。但是你必须担心国王或数组中的 0,所以我必须考虑到这一点。
// Blackjack.cpp
#include "stdafx.h"
#include <iostream>
#include <string>
#include <cstdlib>
#include <Windows.h>
#include <ctime>
#include <string>
using namespace std;
int start(); // forward decleration
int main()
int menu = 0;
SetConsoleTitle(TEXT("BlackJack By Paul V 1.0"));
cout << "Welcome to BlackJack!" << endl;
cout << "1. Start the game!!" << endl;
cout << "2. Exit" << endl;
cout << "ENTER HERE:" << flush;
cin >> menu;
if (menu == 1)
start();
if (menu == 0)
cout << "Program Ending....." << endl;
return 0;
int start()
SetConsoleTitle(TEXT("LOADING....."));
srand((unsigned)time(NULL));
int menu = 0;
int yo1 = rand() % 13;
int yo2 = rand() % 13;
int yo3 = rand() % 13;
int yo4 = rand() % 13;
int yo5 = rand() % 13;
int yo6 = rand() % 4;
int yo7 = rand() % 4;
int yo8 = rand() % 4;
int yo9 = rand() % 4;
int yo = rand() % 4;
int card1 = 0;
int card2 = 0;
int card3 = 0;
int card4 = 0;
int card5 = 0;
string card_names[13] = "Ace", "2", "3", "4", "5", "6", "7", "8", "9", "10", "Jack", "Queen", "King" ;
string card_types[4] = "Diamonds", "Spades", "Clubs", "Hearts" ;
string goody = card_names[yo1];
string goddy2 = card_names[yo2];
string goddy3 = card_names[yo3];
string goddy4 = card_names[yo4];
string goddy5 = card_names[yo5];
if (yo1 == 10 || yo1 == 11 || yo1 == 12)
const int card1 = 10;
if (yo2 == 10 || yo2 == 11 || yo2 == 12)
const int card2 = 10;
if (yo3 == 10 || yo3 == 11 || yo3 == 12)
const int card3 = 10;
if (yo4 == 10 || yo4 == 11 || yo4 == 12)
const int card4 = 10;
if (yo5 == 10 || yo5 == 11 || yo5 == 12)
const int card5 = 10;
if (yo1 == 0)
const int card1 = 1;
if (yo2 == 0)
const int card2 = 1;
if (yo3 == 0)
const int card3 = 1;
if (yo4 == 0)
const int card4 = 1;
if (yo5 == 0)
const int card5 = 1;
else
int card1 = stoi(card_names[yo1]);
int card2 = stoi(card_names[yo2]);
int card3 = stoi(card_names[yo3]);
int card4 = stoi(card_names[yo4]);
int card5 = stoi(card_names[yo5]);
SetConsoleTitle(TEXT("BlackJack By Paul V 1.0"));
cout << "Your starting card is a " << goody << " of " << card_types[yo6] << endl;
return 0;
【问题讨论】:
你知道你的整个if
/else
链是没用的,对吧?
为什么没用?
哦,我明白为什么它没用了,因为我在通过链之前定义了变量!感谢您的修复。
【参考方案1】:
问题出在你的 stoi() 上。这是因为 yo'n' 的值会在代码的最后一个“else”部分出现,即使它们超出了 1 到 9 的范围。
在将所有 yo'n' 变量作为 card_names[yo'n'] 传递给 stoi 之前,您需要对它们进行范围检查。
正如 smead 所说,请编写更清晰的代码。如此多的 'if' 使它几乎不可读和可调试。
【讨论】:
【参考方案2】:stoi()
将字符串转换为数字,但前提是您的字符串可以有效地转换为数字 (see documentation)。您的数组card_names
包含多个非整数字符串(“Ace”、“Jack”等)。
我什至不确定您要在那里做什么:您的值 yo1
到 yo5
已经包含卡号,那么为什么需要将其转换为字符串并返回呢?
顺便说一下,请使用数组!看到yo1
到yo9
和card1
到card5
之类的东西让我的眼睛很痛:)
【讨论】:
以上是关于我的程序出现 abort() 错误,但由于它是程序的加载部分,我无法调试它?的主要内容,如果未能解决你的问题,请参考以下文章
dyld`__abort_with_payload:没有错误信息
iOS 应用程序在真实设备上崩溃。错误:dyld`__abort_with_payload