- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的程序在标准内存分配下运行良好,但使用动态内存分配会使程序运行异常!它甚至不从主要功能打印任何东西。
在头文件中声明指向alist
的指针,并在类定义(构造函数)中使用new
动态分配内存。已指出女巫程序的代码工作正常。也用了很多couts做测试,无视。谢谢
头文件:
//Vehicle.h
//Author: Ankush Kaul
//Purpose: Declaration of Vehicle class
#ifndef VEHICLE_H
#define VEHICLE_H
#include <string>
#include <fstream>
using namespace std;
class Vehicle
{
public:
Vehicle(); //default constructor
Vehicle(ifstream&); //parametrized constructor
Vehicle(const Vehicle& other); //copy constructor
~Vehicle(); // destructor
//over loaded operators
Vehicle& operator=(const Vehicle& other); // assignment operator
bool operator==(const Vehicle& other); // relational operator
// accessors
int getVid();
string getManufact();
string getColor();
double getCost();
int getnumAccessories();
string getList();
// 3 functions to access accessory list
void startAcc();
string nextAcc();
bool hasNextAcc();
protected:
private:
int vId;
string manufact;
string color;
double cost;
int numAccessories;
string *alist; // acessory list
//string alist[10]; <- WORKS WITH THIS
int counter; // hidden object used for accessing accesory list
};
#endif // VEHICLE_H
类定义:
//Vehicle.h
//Author: Ankush Kaul
//Purpose: Implementation of Vehicle class
#include "Vehicle.h"
#include <cstdlib>
#include <fstream>
#include <iostream>
using std::atoi;
using std::atof;
using std::ifstream;
using std::cout;
//---------------------------
//Name: Vehicle
//Purpose: default constructor
//Parameters: None
//Return: None
//---------------------------
Vehicle::Vehicle()
{
vId = 999;
manufact = color = "";
cost = numAccessories = 0;
}
//---------------------------
//Name: Vehicle()
//Purpose: Parametrized constructor
//Parameters:
// fin : input file stream
//Return: None
//---------------------------
Vehicle::Vehicle(ifstream &fin)
{
string line;
getline(fin, line);
vId = atoi(line.c_str());
getline(fin, line);
manufact= line;
getline(fin, line);
color = line;
getline(fin, line);
cost = atof(line.c_str());
getline(fin, line);
numAccessories = atoi(line.c_str());
alist = new string[numAccessories]; <-- WORKS WITHOUT THIS
cout<<"**";
for (int i = 0; i < numAccessories; i++)
{
getline(fin, line);
alist[i] = line;
}
}
//---------------------------
//Name: ~Vehicle
//Purpose: Destructor
//Parameters: None
//Return: None
//---------------------------
Vehicle::~Vehicle()
{
}
//---------------------------
//Name: Vehicle()
//Purpose: Copy constructor
//Parameters:
// other : Vehicle object passed to copy
//Return: None
//---------------------------
Vehicle::Vehicle(const Vehicle& other)
{
this->vId = other.vId;
this->manufact = other.manufact;
this->color = other.color;
this->cost = other.cost;
this->numAccessories = other.numAccessories;
for ( int i = 0 ; i < other.numAccessories ; i++ )
this->alist[i] = other.alist[i];
}
//---------------------------
//Name: operator=
//Purpose: Overloading operator
//Parameters:
// other : Vehicle object passed to assign values
//Return: Vehicle
//---------------------------
Vehicle& Vehicle::operator=(const Vehicle& other)
{
this->vId = other.vId;
this->manufact = other.manufact;
this->color = other.color;
this->cost = other.cost;
this-> numAccessories = other.numAccessories;
for ( int i = 0 ; i < other.numAccessories ; i++ )
this->alist[i] = other.alist[i];
return *this;
}
//---------------------------
//Name: operator==
//Purpose: Overloading operator
//Parameters:
// other : Vehicle object passed to compare
//Return: bool
//---------------------------
bool Vehicle::operator==(const Vehicle& other)
{
if (this->vId == other.vId &&
this->manufact == other.manufact &&
this->color == other.color &&
this->cost == other.cost &&
this->numAccessories == other.numAccessories)
{
return true;
}
return false;
}
//---------------------------
//Name: getVid
//Purpose: gets vId attribute
//Parameters: none
//Return: int
//---------------------------
int Vehicle::getVid()
{
return vId;
}
//---------------------------
//Name: getManufact
//Purpose: gets manufact attribute
//Parameters: none
//Return: string
//---------------------------
string Vehicle::getManufact()
{
return manufact;
}
//---------------------------
//Name: getColor
//Purpose: gets color attribute
//Parameters: none
//Return: string
//---------------------------
string Vehicle::getColor()
{
return color;
}
//---------------------------
//Name: getCost
//Purpose: gets cost attribute
//Parameters: none
//Return: double
//---------------------------
double Vehicle::getCost()
{
return cost;
}
//---------------------------
//Name: getnumAccessories
//Purpose: gets numAccessories attribute
//Parameters: none
//Return: int
//---------------------------
int Vehicle::getnumAccessories()
{
return numAccessories;
}
// 3 functions to get accesory list
//---------------------------
//Name: startAcc
//Purpose: sets counter to zero
//Parameters: none
//Return: void
//---------------------------
void Vehicle::startAcc()
{
counter = 0;
}
//---------------------------
//Name: nextAcc
//Purpose: returns name of accesory
//Parameters: none
//Return: string
//---------------------------
string Vehicle::nextAcc()
{
return alist[counter++];
}
//---------------------------
//Name: hasNextAcc
//Purpose: checks if all accessory list is read
//Parameters: none
//Return: bool
//--------------------------
bool Vehicle::hasNextAcc()
{
if ( counter < numAccessories)
return true;
return false;
}
主文件:
//main.cpp
//Topic: Project 4 - Vehicle
//Author: Ankush Kaul
//Purpose: Read and display list of Vehicles
#include <iostream>
#include <fstream>
#include <string>
#include <cstdlib>
#include <iomanip>
#include "Vehicle.h"
using namespace std;
void printVehicle (Vehicle);
int main ()
{
ifstream fin; // holds input file stream
string file,line; // file - holds filename, line - holds line read from file
cout<<"Enter filename : ";
cout<<"()";
//cin>>file;
cout<<"11";
//fin.open(file.c_str());
fin.open("vehicle1.txt");
cout<<"^^";
// checking if file is sucessfully opened
if (!fin.is_open())
{
cout<<"Error opening file!";
return 1;
}
cout<<"@@";
//cin.ignore(1000, '\n');
cout<<"%%";
getline(fin, line); // reading the first line which contains number of vehicles in the file
cout<<"!!";
int count = atoi(line.c_str());
cout<<"&&";
Vehicle veh[count]; // defining a array of length = count
// loop to read details of vehicles from file and store it in the veh[] array
for (int i = 0; i < count; i++)
{
cout<<"##";
Vehicle newVeh(fin);
bool duplicate = false; // sets duplicate flag to false
// loop to check if a duplicate vehicle exists
for (int k = 0; k < i; k++)
if (newVeh == veh[k])
{
duplicate = true;
cout<<endl<<"Duplicate Vehicle detected --- ignored!"<<endl;
}
if (duplicate)
continue;
veh[i] = newVeh;
}
// print list of vehicles to the screen by calling printVehicle function
cout<<endl<<"Vehicle List";
for (int i = 0; i < count; i++)
{
//cout<<endl<<"in loop "<<i<<endl;
cout<<endl<<"-------------------------";
printVehicle(veh[i]);
}
return 0;
}
//---------------------------
//Name: printVehicle
//Purpose: prints the vehicle details
//Parameters: veh
//Return: void
//---------------------------
void printVehicle(Vehicle veh)
{
cout<<endl<<"Vin: "<<veh.getVid();
cout<<endl<<"Manufacturer: "<<veh.getManufact();
cout<<endl<<"Color: "<<veh.getColor();
cout<<fixed<<showpoint<<setprecision(2); // output modifier to print decimal with 2 point accuracy
cout<<endl<<"Cost: "<<veh.getCost();
cout<<endl<<"Accessory List:"<<endl;
// printing accessory list
veh.startAcc();
while(veh.hasNextAcc())
{
string nextAcc = veh.nextAcc();
cout<<" "<<nextAcc<<endl;
}
}
最佳答案
您的复制构造函数和赋值运算符已损坏。您没有为附件列表分配内存。您的复制构造函数应如下所示:
Vehicle::Vehicle(const Vehicle& other)
:
vId (other.vId),
manufact (other.manufact),
color (other.color),
cost (other.cost),
numAccessories (other.numAccessories),
alist (0),
counter (0)
{
alist = new string[numAccessories];
for ( int i = 0 ; i < other.numAccessories ; ++i ) {
alist[i] = other.alist[i];
}
}
你的赋值运算符应该在分配给它之前类似地分配 alist
。您没有解决的赋值运算符还有另一个问题,即自赋值问题。如果有人执行 vehicle = vehicle;
怎么办?
您的析构函数也不正确。您应该释放由构造函数或赋值运算符分配的内存。
您的比较运算符没有损坏,但它也可能不正确。据推测,您应该测试两辆车是否具有相同的配件,而不是仅仅测试它们是否具有相同数量的配件。
关于c++ - 在 C++ 中使用动态内存使程序崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20038228/
我有一段代码看起来像这样: void update_clock(uint8_t *time_array) { time_t time = *((time_t *) &time_array[0]
应用程序崩溃了 :( 请帮助我.. 在这方面失败了。我找不到错误?该应用程序可以连接到 iTunesConnect 但它会出错。 谁能根据下面的崩溃报告判断问题出在哪里? share_with_app
小二是新来的实习生,作为技术 leader,我给他安排了一个非常简单的练手任务,把前端 markdown 编辑器里上传的图片保存到服务器端,结果他真的就把图片直接保存到了服务器上,这下可把我气坏了,就
我正在创建一个函数,它将目录路径作为参数传递,或者如果它留空,则提示用户输入。 我已经设置了我的 PATH_MAX=100 和 if 语句来检查 if ((strlen(folder path) +
我已将“arial.ttf”文件(从我的/Windows/Fonts 文件夹中获取)加载到内存中,但是将其传递到 FT_New_Memory_Face 时会崩溃(在 FT_Open_Face 中的某处
我正在尝试在我的计算机上的两个控制台之间进行 rtsp 流。 在控制台 1 上,我有: ffmpeg -rtbufsize 100M -re -f dshow -s 320x240 -i video=
我正在尝试使用 scio_beast在一个项目中。我知道它还没有完成,但这并不重要。我已经设法让它工作得很好。 我现在正在尝试连接到 CloudFlare 后面的服务器,我知道我需要 SNI 才能工作
我有一个带有关联宏的下拉列表,如下所示: Sub Drop() If Range("Hidden1!A1") = "1" Then Sheets("Sheet1").Se
我对 bash 很陌生。我要做的就是运行这个nvvp -vm /usr/lib64/jvm/jre-1.8.0/bin/java无需记住最后的路径。我认为 instafix 就是这样做...... n
我在 Windows 上使用 XAMPP 已经两年左右了,它运行完美,没有崩溃没有问题。 (直到四个月前。) 大约四个月前,我们将服务器/系统升级到了更快的规范。 这是旧规范的内容 - Windows
我面临着一个非常烦人的 android 崩溃,它发生在大约 1% 的 PRODUCTION session 中,应用程序始终在后台运行。 Fatal Exception: android.app.Re
尝试使用下面的函数: public void createObjectType() { try { mCloudDB.createObjectType(ObjectTypeIn
由于我正在进行的一个项目,我在 CF11 管理员中弄乱了类路径,我设法使服务器崩溃,以至于我唯一得到的是一个漂亮的蓝屏和 500 错误.我已经检查了日志,我会把我能做的贴在帖子的底部,但我希望有人会启
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 10 个月前关闭。 Improve
我最近从 xcode 3.x 更新到 4.2,当我在 4.2 中运行应用程序时,我遇到了核心数据问题。我还更新到了 iOS 5,所以问题可能就在那里,我不太确定。 这些应用程序在 3.x 中运行良好,
我是一个相对较新的 iPhone 应用程序开发人员,所以我的知识有点粗略,所以如果这是一个微不足道的问题,请原谅我。 我有一个导航应用程序,它通过在navigationController对象上调用p
if ([MFMailComposeViewController canSendMail]) { MFMailComposeViewController *mailViewController
你能帮我吗? 我正在设置 UILocalNotification,当我尝试设置其 userInfo 字典时,它崩溃了。 fetchedObjects 包含 88 个对象。 这是代码: NSDi
为什么我的代码中突然出现 NSFastEnumeration Mutation Handler 崩溃。我很茫然为什么会突然出现这个崩溃以及如何解决它。 最佳答案 崩溃错误: **** 由于未捕获的异常
当我从表中删除行时,我的应用程序崩溃了。这是我检测到错误和堆栈跟踪的来源。谢谢! //delete row from database - (void)tableView:(UITableView *
我是一名优秀的程序员,十分优秀!