----------------解决方案--------------------------------------------------------
用在这里是否是杀鸡用了牛刀了啊???
----------------解决方案--------------------------------------------------------
哇,有点长,
不是一时半会看的出来滴.
----------------解决方案--------------------------------------------------------
while(!feof(fp))
{
load_point=(struct card*)malloc(sizeof(struct card));
fread(load_point,sizeof(struct card),1,fp);
load_point->next_point=now_point->next_point;
load_point->front_point=now_point;
now_point->next_point=load_point;
now_point=load_point;
}
fclose(fp);
while(!feof(fp))
{
load_point=(struct card*)malloc(sizeof(struct card));
if(fread(load_point,sizeof(struct card),1,fp))
{
load_point->next_point=now_point->next_point;
load_point->front_point=now_point;
now_point->next_point=load_point;
now_point=load_point;
}
else
{
free(load_point);
}
}
fclose(fp);
还有一个小的问题需要解决,虽然不会造成致命错误,但是培养好的习惯总是好的:)
在save()的函数内,结束部分最好加上 fclose(fp);
关于你的程序出现的问题,我的个人理解:
1.错误发生在load阶段,因为整个链表是通过从文件中读取然后再在内存中构造的,并且文件中不需要存储head,end节点
2.存储过程就不说明了。
3.在读取过程中的终止条件是 feof(fp),这个也没有错。关键问题在于fread()和feof()的结合上面,由于文件的实际大小会比所存储的数据稍大,而且当读到最后一个数据后似乎还有一段存储空间(可能是预留的)。所以导致 出现这种情况:
当所存储数据已经全部读出来,而判定条件仍然成立。从而导致每次load都会在文件末尾添加一个空数据
为了避免该情况发生,我们可以利用fread()本身特性,通过判定其返回值来进行进一步的判定,当读取到空数据部分时 其返回值为0。
PS:free(load_point)只是为了减少碎片,不加上else一段也是不会出错的,但是好习惯希望人人都能养成:)
共同进步,很喜欢这种解决无法解释的问题的瞬间快感。。。。哈哈
[此贴子已经被作者于2006-8-8 11:21:11编辑过]
----------------解决方案--------------------------------------------------------
仔细读了一遍,受教了!
难道编程高手都是半夜工作?^_^
----------------解决方案--------------------------------------------------------
在此想请教
神和knocker一个问题。目前还不知道该问题是怎么一回事。。。。
#include <iostream>
#include <string>
using namespace std;
int main(int argc, char* argv[])
{
char *a[5]; //最初申明的数组指针
int n;
cout<<"请输入字符串数目:";
cin>>n;
cout<<"请输入"<<n<<"个字符串:"<<endl;
for(int i=0;i<n;i++)
{
a[i]=new char[10]; //分配10个字符的输入空间,这里可以视情况自己改 ;
cin>>a[i];
}
for(i=0;i<n;i++)
{
cout<<a[i]<<endl; //观察输入数据的输出情况;
}
for(i=n-1;i>-1;i--)
{
delete []a[i]; //释放内存空间;
}
return 0;
}
我想此问题应该是属于空间声明的再分配问题,但是为什么n+1的情况在为1的时候就不成立?
想不明白。。。。。
#include <iostream>
#include <string>
using namespace std;
int main(int argc, char* argv[])
{
char *a[5]; //最初申明的数组指针
string s; //注意这里,只是声明(分配了空间)。但是不明白为什么S的空间怎么可以对char *a[5]照成影响。。。。。。
int n;
cout<<"请输入字符串数目:";
cin>>n;
cout<<"请输入"<<n<<"个字符串:"<<endl;
for(int i=0;i<n;i++)
{
a[i]=new char[10]; //分配10个字符的输入空间,这里可以视情况自己改 ;
cin>>a[i];
}
for(i=0;i<n;i++)
{
cout<<a[i]<<endl; //观察输入数据的输出情况;
}
for(i=n-1;i>-1;i--)
{
delete []a[i]; //释放内存空间;
}
return 0;
}
CPU:AMD 3000+
操作系统:MS windows2000 pro
编译环境:VC6.0英文版
----------------解决方案--------------------------------------------------------
不是需要大家对其进行修改。。。我是想知道为什么加上一个string就能解决所遇到的溢出的问题。。。
----------------解决方案--------------------------------------------------------
这种问题不必讨论,不同编译器会有不结果.
----------------解决方案--------------------------------------------------------
多谢
----------------解决方案--------------------------------------------------------