问题描述
我正在做一个学校项目,我的老师希望它可以在Borland 5.5中进行编译。该代码在GNU GCC编译器中可以正常工作,但是这里很混乱。我跟踪了使用ifstream的错误(我用它来读取.txt文件),但是最让我困惑的是,即使实例化ifstream崩溃。我将张贴Entyre代码和我正在使用Ifstream测试的两段代码。
#include <iostream>
#include <fstream>
using namespace std;
ifstream arch_paises;
int main () {
cout << "End..." << endl;
return 0;
}
最后一行(打印“ End”)甚至没有执行。但是...如果我改变了ifstream的位置。
#include <iostream>
#include <fstream>
using namespace std;
int main () {
ifstream arch_paises;
cout << "End..." << endl;
return 0;
}
打印“结束”。无论如何,“返回的-1073741819”仍然存在。
在这里,我张贴了该项目的完整代码,正如我对GNU GCC编译器所说的那样,它可以完美地工作。它从文本文件中读取一些数据,并对流行病进行一些计算。
//------------------------------------------------------------------------------
// Librerias
#include <fstream>
#include <iomanip>
#include <iostream>
#include <string.h>
using namespace std;
//------------------------------------------------------------------------------
// Parametros de configuracion
const short MAX_PAIS = 200;
#define n_paises "Paises.txt"
#define n_partes "ParteDiario.txt"
//------------------------------------------------------------------------------
// Posibles titulos
const string titulo[] = {"Hisopados","Infectados","Recuperados","Fallecidos"};
//------------------------------------------------------------------------------
// Estructura con informacion mundial
struct tsGlobal{
short cp ; // Cantidad de paises
long poblacion ; // Poblacion mundial
long totales_globales[5]; // Hisopados(1),Infectados(2),Recuperados(3),Fallecidos(4)
};
//------------------------------------------------------------------------------
// Estructura utilizada para los calculos
struct datos_paises{
char pais[20];
char cont[10];
unsigned short habs ;
unsigned short mensual[5][13] ; // [Hisopados(1),Fallecidos(4)] [mes]
unsigned short totales[5] ; // Hisopados(1),Fallecidos(4)
};
//------------------------------------------------------------------------------
// Estructura utilizada para la lectura de los partes diarios
struct tsParDia{
char pais[20];
unsigned short mes;
unsigned short dia;
unsigned short ch;
unsigned short ci;
unsigned short cf;
unsigned short cr;
};
//------------------------------------------------------------------------------
// Prototipos de modulos
void Abrir_archivo(ifstream &paises,ifstream &partes);
void ProcPaises(tsGlobal &i,datos_paises* tsC,ifstream &paises);
bool LeerPaises(datos_paises* r,short index,ifstream &paises);
void ProcParteDiarios( datos_paises* ps,tsGlobal &tsg,ifstream &partes,tsParDia tsPart);
bool LeerParte(ifstream &partes,tsParDia &tsPart);
void Ordenar(datos_paises* ps,int cantidad,int criterio);
void IntCmb(datos_paises &elem1,datos_paises &elem2);
void Listado(tsGlobal tsg,datos_paises* ps);
void Generar_contenido_archivo(datos_paises* estructura,short tipo,tsGlobal tsg,datos_paises* ps);
void archivo_formato(short tipo,ofstream &outfile,datos_paises* ps);
void archivo_body(short cantidadPaises,datos_paises* ps);
void archivo_footer(short tipo,datos_paises* ps,tsGlobal tsg);
void Cerrar_archivo(ifstream &paises,ifstream &partes);
//+=============================================================================
// Bloque principal
//
int main() {
/*Declaracion de estructuras*/
datos_paises ps [MAX_PAIS];
tsParDia tsPartes;
tsGlobal tsGlb;
/*Archivos*/
ifstream arch_paises;
ifstream arch_partes;
/*Abro los archivos*/
Abrir_archivo(arch_paises,arch_partes);
/*Proceso la informacion del archivo de paises*/
ProcPaises(tsGlb,ps,arch_paises);
/*Proceso la informacion del archivo de partes diarios*/
ProcParteDiarios(ps,tsGlb,arch_partes,tsPartes);
/*Genero el listado*/
Listado(tsGlb,ps);
/*Cierro los archivos*/
Cerrar_archivo(arch_paises,arch_partes);
return 0;
}
//+=============================================================================
// Abro los archivos para lectura
//
void Abrir_archivo(ifstream &paises,ifstream &partes){
paises.open(n_paises);
partes.open(n_partes);
}
//+=============================================================================
// Proceso la linea y la almaceno en la posicion indicada de la struct
//
void ProcPaises(tsGlobal &i,ifstream &paises){
i.cp = 0;
while(LeerPaises(tsC,i.cp,paises)){
i.poblacion += tsC[i.cp].habs;
i.cp++;
}
}
//+=============================================================================
// Leo el archivo de paises y lo almaceno en la estructura interna
//
bool LeerPaises(datos_paises* r,short cp,ifstream &paises) {
paises.get(r[cp].pais,21,' ');
paises >> ws;
paises.get(r[cp].cont,11,' ');
paises >> ws;
paises >> r[cp].habs;
paises.ignore();
return paises.good();
} // Leer
//+=============================================================================
// Proceso la linea del parte y la almaceno en la posicion indicada de la struct
//
void ProcParteDiarios( datos_paises* ps,tsParDia tsPart){
while(LeerParte(partes,tsPart)){
for(int c = 0; c < tsg.cp; c ++){
if(!strcmp(tsPart.pais,ps[c].pais)){
ps[c].mensual[1][tsPart.mes]+= tsPart.ch;
ps[c].totales[1] += tsPart.ch;
tsg.totales_globales[1] += tsPart.ch;
ps[c].mensual[2][tsPart.mes]+= tsPart.ci;
ps[c].totales[2] += tsPart.ci;
tsg.totales_globales[2] += tsPart.ci;
ps[c].mensual[3][tsPart.mes]+= tsPart.cr;
ps[c].totales[3] += tsPart.cr;
tsg.totales_globales[3] += tsPart.cr;
ps[c].mensual[4][tsPart.mes]+= tsPart.cf;
ps[c].totales[4] += tsPart.cf;
tsg.totales_globales[4] += tsPart.cf;
}
}
}
}
//+=============================================================================
// Leo el archivo de partes y lo almaceno en la estructura interna
//
bool LeerParte(ifstream &partes,tsParDia &tsPart) {
/*Nombre del pais*/
partes.get(tsPart.pais,' ');
/*Descargo el mes*/
partes >> tsPart.mes;
/*Descargo el dia*/
partes >> tsPart.dia;
/*Descargo hisopados*/
partes >> tsPart.ch;
/*Descargo infectados*/
partes >> tsPart.ci;
/*Descargo fallecidos*/
partes >> tsPart.cr;
/*Descargo recuperados*/
partes >> tsPart.cf;
partes.ignore();
return partes.good();
} // Leer
//+=============================================================================
// Ordena el struct en funcion de un parametro especifico
//
void Ordenar(datos_paises* ps,int criterio){
bool cambios = true;
char grupos=cantidad/2;
while(grupos>1){
grupos = grupos/2;
cambios = true;
while(cambios){
cambios = false;
for (char i=0;i+grupos<cantidad;i++){
if(ps[i].totales[criterio] < ps[i+grupos].totales[criterio])
{
cambios=true;
IntCmb(ps[i],ps[i+grupos]);
}
}
}
}
}
//+=============================================================================
// Intercambia posiciones del Struct
//
void IntCmb(datos_paises &elem1,datos_paises &elem2){
datos_paises aux;
aux = elem1;
elem1 = elem2;
elem2 = aux;
}
//+=============================================================================
// Genero el listado de los distintos topicos y guardo en archivos
//
void Listado(tsGlobal tsg,datos_paises* ps){
for(int i = 1; i < 5; i++){
Ordenar(ps,tsg.cp,i); // Ordeno la estructura en funcion del parametro dado
Generar_contenido_archivo(ps,i,tsg,ps);
}
}
//+=============================================================================
// Genero el contenido de los archivos
//
void Generar_contenido_archivo(datos_paises* estructura,datos_paises* ps){
ofstream outfile;
string nombre = "Listado" + titulo[tipo-1] + ".txt";
outfile.open(nombre.c_str());
archivo_formato(tipo,outfile,ps);
archivo_body(tsg.cp,tipo,ps);
archivo_footer(tipo,tsg);
outfile.close();
}
//+=============================================================================
// Primera parte del archivo en donde plasmo el formato solicitado por el docente
//
void archivo_formato(short tipo,datos_paises* ps){
/*Titulo*/
outfile << setw(100) << endl;
outfile << setw(77) << "Listado de " + titulo[tipo-1] << endl;
/*Linea 1*/
outfile << left << setw(10)<< "Nro.";
outfile << left << setw(20)<< "Nombre";
outfile << left << setw(10)<< "Cant.Hab";
/*Linea2*/
string auxiliar = "---------- Cantidades de " + titulo[tipo-1] + " por mes ----------";
outfile << left << setw(47)<< auxiliar;
outfile << right << setw(6) << "Cant.";
outfile << right << setw(15)<< "Porcentajes" <<endl;
outfile << left << setw(10)<< "Ord.";
outfile << left << setw(20)<< "Pais";
outfile << left << setw(10)<< "";
outfile << left << setw(8) << "Ene";
outfile << left << setw(8) << "Feb";
outfile << left << setw(8) << "Mar";
outfile << left << setw(8) << "Abr";
outfile << left << setw(8) << "May";
outfile << left << setw(8) << "Jun";
outfile << left << setw(7) << "Jul";
outfile << left << setw(10)<< "Tot." << endl;
}
//+=============================================================================
// Cuerpo del archivo... Coloco la info por pais
//
void archivo_body(short cantidadPaises,datos_paises* ps){
for(int i = 0; i < cantidadPaises ; i ++){
outfile << left << setw(10) << i+1;
outfile << left << setw(20) << ps[i].pais;
outfile << left << setw(10) << ps[i].habs;
outfile << left << setw(8) << ps[i].mensual[tipo][1];
outfile << left << setw(8) << ps[i].mensual[tipo][2];
outfile << left << setw(8) << ps[i].mensual[tipo][3];
outfile << left << setw(8) << ps[i].mensual[tipo][4];
outfile << left << setw(8) << ps[i].mensual[tipo][5];
outfile << left << setw(8) << ps[i].mensual[tipo][6];
outfile << left << setw(7) << ps[i].mensual[tipo][7];
outfile << left << setw(10) << ps[i].totales[tipo];
double porcentaje = ((double)ps[i].totales[tipo] / (double)ps[i].habs) * 100;
char aux[50];
sprintf(aux,"%.2f",porcentaje);
outfile << right << setw(6) << aux << "%" << endl;
}
}
//+=============================================================================
// Coloco el footer del archivo
//
void archivo_footer(short tipo,tsGlobal tsg){
string foot1 = "Cantidad total de " + titulo[tipo-1] + " a la fecha actual:";
outfile << endl << endl << left << foot1 << tsg.totales_globales[tipo] << endl;
double porcentaje = ((double) tsg.totales_globales[tipo] / (double)tsg.poblacion) * 100;
char aux[50];
sprintf(aux,porcentaje);
string foot2 = "Porcentaje de " + titulo[tipo-1];
outfile << left << setfill('.') << setw(foot1.length()-1) << foot2;
outfile << right << ":" << aux << "%" ;
}
//+=============================================================================
// Cerramos los archivos de lectura
//
void Cerrar_archivo(ifstream &paises,ifstream &partes){
paises.close();
partes.close();
}
该代码编译时没有错误或警告,但无法使用 Boorland 正确/完整地运行。
谢谢。
解决方法
0xC0000005是用于内存访问冲突的Windows异常代码。 一个示例是写入NULL地址。
ifstream
是C ++标准库的一部分,每个编译器都提供自己的实现。
Borland C ++ 5.5是20 years old,并非设计用于Windows 2000或更高版本的操作系统。
由于根据您的问题,错误仅通过实例化ifstream
就会发生,因此我认为问题出在Borland的ifstream
实现中,与您正在运行的较新操作系统完全不兼容。
您可以尝试在兼容模式下运行生成的EXE(如果在您的Windows版本上仍然可用)。
另一种选择是避免使用ifstream
,而改用C API fopen
,fread
或使用WIN32 API CreateFile
和ReadFile
。
除非您当然可以说服老师更换编译器。