IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> C++学生信息管理系统(有头链表+文件存取) -> 正文阅读

[数据结构与算法]C++学生信息管理系统(有头链表+文件存取)

C++数据结构:有头链表+文件存取操作

  • 编译环境:vs2019;
  • 注意事项:点个关注吧;
  • 由于代码较多,不贴出完整代码,会挑出主要部分来叙述,我会将源文件上传CSDN,并在文末附上百度网盘链接,有需要可自行下载,若链接失效可评论获取;
  • 建议:各位小伙伴在阅读的时候可以一个函数一个函数的阅读,方便理解;
  • 注:文章仅作为自己成长的记录,不足之处还请多指教(师承大帅)。
运行截图:

在这里插入图片描述

项目分析
  • 有头链表就是通过一个头部指针来操作整个的数据,然后又通过指针互相连接,串在一起;大家可以联想老鹰捉小鸡时,母鸡和小鸡排在一起用手拉着对方的情形;

  • 有头链表也可参考下图:
    在这里插入图片描述

  • 结构体嵌套问题:
    在这里插入图片描述

初始化数据域:
p_Node initNode()
{
	p_Node pN = (p_Node)malloc(sizeof(Node));
	if (!pN)exit(OVERFLOW);
    //exit(OVERFLOW)是强行退出程序
    //这里就是如果指针内存分配失败,强行退出程序
	pN->age = 0;
	pN->number = 0;
   //指针通过动态内存申请可变为变量,SIZE是我定义的宏
	pN->name = (char*)malloc(sizeof(char) * SIZE);
	if (!pN->name)exit(OVERFLOW);

	return pN;
}
初始化指针域:
p_Data createHead()
{
	p_Data p_Head = (p_Data)malloc(sizeof(Data));
	if (!p_Head)exit(OVERFLOW);
	p_Head->next = NULL;
	return p_Head;
}
将节点变为数据:
p_Data createData(p_Node Node)
{
	p_Data p_NewData = (p_Data)malloc(sizeof(Data));
	if (!p_NewData)exit(OVERFLOW);

	p_NewData->next = NULL;
	p_NewData->node = initNode();
    //字符串不能直接赋值,要进行拷贝
	int strLeng = strlen(Node->name) + 1;
	//strlen计算的长度中没有算'/0',终止符,所以要加1;
	strcpy_s(p_NewData->node->name, strLeng, Node->name);
	p_NewData->node->age = Node->age;
	p_NewData->node->number = Node->number;

	return p_NewData;
}
保存函数
  • 文件写操作的一般步骤(读和写步骤一样):
  • 创建写文件流对象 ->打开文件 -> 判断文件是否打开 -> 写入文件 -> 关闭文件;
  • 这里 ios::app 是以追加的方式写文件,否则会覆盖原有文件;
int saveFile(p_Data p_Head)
{
	ofstream ofs;
	ofs.open(FILENAME, ios::binary | ios::out | ios::app);

	if (!ofs.is_open())
	{
		cout << "保存文件时,打开文件失败..." << endl;
		return Error;
	}

	p_Data pMove = p_Head->next;
	if (pMove == NULL)
	{
		cout << "未保存,链表没有数据..." << endl;
		ofs.close();
		return Error;
	}

	while (pMove != NULL)
	{
		ofs << pMove->node->name<<" "<< pMove->node->age<<" "
			<< pMove->node->number << endl;
		pMove = pMove->next;
	}
	ofs.close();
	cout << "保存成功..." << endl;
	return Ok;
}
读取文件:
int readFile(p_Data p_Head)
{
    
	p_Data curData = p_Head->next;
	if (curData != NULL)
	{
		free(curData);
		curData = NULL;
	}
	p_Head->next = NULL;
    //至于上面这里这样写的作用,大家可以注释后感受一下
    //注释快捷键(vs2019中):ctrl+k+c
	ifstream ifs;
	ifs.open(FILENAME, ios::binary | ios::in);
	if (!ifs.is_open())
	{
		cout << "读文件时打开失败..." << endl;
		return Error;
	}

	p_Node Node = initNode();
	//int num = 0;调试作用

	while (ifs >> Node->name >> Node->age >> Node->number)
	{
		insertHead(p_Head, Node);
		//num++;调试作用
	}
	//这里是我调试的时候写的
	/*cout << "循环了" << num << "次" << endl;
	cout << "文件读取完毕..." << endl;*/
	ifs.close();
	cout << "成功读入文件..." << endl;
	return Ok;
}
判断输入类型
  • 因为用户选择功能的方式是输入Int类型的数字,如果不对用户的输入做判断,当用户char类型或其他类型数据时,系统会崩掉或者陷入无线循环,所以最好判断一下输入;
  • cin.fail()判断输入的类型和定义的类型是否一致,一致返回true,否则返回false;
int select;
cin >> select;
if (!cin.fail())
遇到的问题:
  • 文件在读取时数据不正确;
  • 读取的结点数据未能正确保存;
产生原因
  • 结构体赋值时只是进行了简单的赋值操作;
  • 指针指向不明确,出现了野指针;
  • 错误代码1:
p_Data createData(p_Node Node)
{
	p_Data p_NewData = (p_Data)malloc(sizeof(Data));
	if (!p_NewData)exit(OVERFLOW);
	p_NewData->next = NULL;
	p_NewData->node = Node;
	return p_NewData;
}
  • 改正1
p_Data createData(p_Node Node)
{
	p_Data p_NewData = (p_Data)malloc(sizeof(Data));
	if (!p_NewData)exit(OVERFLOW);

	p_NewData->next = NULL;
	p_NewData->node = initNode();

	int strLeng = strlen(Node->name) + 1;
	strcpy_s(p_NewData->node->name, strLeng, Node->name);
	p_NewData->node->age = Node->age;
	p_NewData->node->number = Node->number;

	return p_NewData;
}
  • 错误代码2
//readFile()函数中的代码
p_Data curData = p_Head->next;
	if (curData != NULL)
	{
		free(curData);
		curData = NULL;
	}
  • 改正2:
p_Data curData = p_Head->next;
	if (curData != NULL)
	{
		free(curData);
		curData = NULL;
	}
	p_Head->next = NULL;
结语:
  • 如果本文对小伙伴有帮助,还望点个关注,我会推出更多优质文章的;
  • 关于该项目的主要几点和内容分析我就分析到这儿,如有疑问可私信或评论讨论,不足之处还请各位大佬指教,最后附上项目的网盘链接(嫌弃下载慢的可在我上传的资源中下载):https://pan.baidu.com/s/1SlIiR0ih_DNI9fzDy0aLng 提取码:260y
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-04-28 12:04:59  更:2022-04-28 12:06:54 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 17:29:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码