Linux下关于C语言队列问题的详解

最近写程序用到了linux系统下c语言的队列操作,于是有了下面一个问题 
下面是队列的代码: 
这个队列头文件 

extern struct pqueue Que;/*构造一个空队列*/extern pQueue *InitQueue();/*销毁一个队列*/extern void DestroyQueue(pQueue *pqueue);/*清空一个队列*/extern void ClearQueue(pQueue *pqueue);/*判断队列是否为空*/extern int IsEmpty(pQueue *pqueue);/*返回队列大小*/extern int GetSize(pQueue *pqueue);/*返回队头元素*/extern PNode GetFront(pQueue *pqueue,char *pitem);/*返回队尾元素*/extern PNode GetRear(pQueue *pqueue,char *pitem);/*将新元素入队*/extern PNode InQueue(pQueue *pqueue,char *pitem);/*队头元素出队*/extern PNode OutQueue(pQueue *pqueue,char *pitem);

下面是队列函数 

struct pqueue Queue;/*构造一个空队列*/pQueue *InitQueue(){pQueue *pqueue = (pQueue *)malloc(sizeof(Queue));if(pqueue!=NULL){pqueue->front = NULL;pqueue->rear = NULL;pqueue->size = 0;}return pqueue;}/*销毁一个队列*/void DestroyQueue(pQueue *pqueue){if(IsEmpty(pqueue)!=1)ClearQueue(pqueue);free(pqueue);}/*清空一个队列*/void ClearQueue(pQueue *pqueue){while(IsEmpty(pqueue)!=1){OutQueue(pqueue,NULL);}}/*判断队列是否为空*/int IsEmpty(pQueue *pqueue){if(pqueue->front==NULL&&pqueue->rear==NULL&&pqueue->size==0)return 1;elsereturn 0;}/*返回队列大小*/int GetSize(pQueue *pqueue){return pqueue->size;}/*返回队头元素*/PNode GetFront(pQueue *pqueue,char *pitem){if(IsEmpty(pqueue)!=1){//pitem = pqueue->front->data;strcpy(pitem,pqueue->front->data);}return pqueue->front;}/*返回队尾元素*/PNode GetRear(pQueue *pqueue,char *pitem){if(IsEmpty(pqueue)!=1){//pitem = pqueue->rear->data;strcpy(pitem,pqueue->rear->data);}return pqueue->rear;}/*将新元素入队*/PNode InQueue(pQueue *pqueue,char *pitem){//DBG0_PR("dbg QueueIn front=%d, rear=%d, count=%d\n", pqueue->front, pqueue->rear, pqueue->size);PNode pnode = (PNode)malloc(sizeof(Node));if(pnode != NULL){strcpy(pnode->data, pitem);pnode->next = NULL;if(IsEmpty(pqueue)){pqueue->front = pnode;}else{pqueue->rear->next = pnode;}pqueue->rear = pnode;pqueue->size++;}return pnode;}/*队头元素出队*/PNode OutQueue(pQueue *pqueue,char *pitem){PNode pnode = pqueue->front;if(IsEmpty(pqueue)!=1 && pnode!=NULL){if(pitem!=NULL)strcpy(pitem,pnode->data);//pitem = pnode->data;pqueue->front = pnode->next;free(pnode);pqueue->size = pqueue->size - 1;if(pqueue->size == 0 ){pqueue->rear = NULL;}}return pqueue->front;}

问题在使用队列的outque时,描述如下: 
入队操作,队列大小size为1,出队操作队列大小操作为0,然后程序循环一圈回来再判断队列大小,size值变成了393216,改了半天也不知道怎么回事, 

提示错误是这样的 

*** glibc detected ***      double free or corruption (!prev):

如果哪位大虾看见了,求解答或者给个思路,感觉自己已经进了死胡同了,跪谢!!!!

回复讨论(解决方案)

注释掉一部分代码,如果问题消失,问题就出在注释掉的代码里

立即学习“C语言免费学习笔记(深入)”;

实时打印size的值,看在哪一步出现的异常

仅供参考 

#ifndef __PQUEUE_H__#define __PQUEUE_H__#include #include #include #define MAX_DATA_SIZE 256typedef struct _node {char data[MAX_DATA_SIZE];struct _node* next;} Node, *pNode;typedef struct __pqueue {pNode front;pNode rear;int size;} Queue, *pQueue;/*构造一个空队列*/extern pQueue InitQueue();/*销毁一个队列*/extern void DestroyQueue(pQueue pqueue);/*清空一个队列*/extern void ClearQueue(pQueue pqueue);/*判断队列是否为空*/extern int IsEmpty(pQueue pqueue);/*返回队列大小*/extern int GetSize(pQueue pqueue);/*返回队头元素*/extern int GetFront(pQueue pqueue, char *pitem);/*返回队尾元素*/extern int GetRear(pQueue pqueue, char *pitem);/*将新元素入队*/extern int InQueue(pQueue pqueue, char *pitem);/*队头元素出队*/extern int OutQueue(pQueue pqueue, char *pitem);#endif /* __PQUEUE_H__ */////////////////////////////////////////////////////////#include "pqueue.h"#define err_log(fmt, ...) printf("[%s:%d]"fmt"\n", __FUNCTION__, __LINE__, ##__VA_ARGS__)#define err_assert(con) { \if (!(con)) { \printf("[%s:%d]ASSERT>>> %s failed\n", __FUNCTION__, __LINE__, #con); \abort(); \} \}/*构造一个空队列*/pQueue InitQueue(){return (pQueue)calloc(1, sizeof(Queue));}/*销毁一个队列*/void DestroyQueue(pQueue pqueue){err_assert(pqueue != NULL);if(!IsEmpty(pqueue))ClearQueue(pqueue);free(pqueue);}/*清空一个队列*/void ClearQueue(pQueue pqueue){err_assert(pqueue != NULL);while (!IsEmpty(pqueue)) {OutQueue(pqueue, NULL);}}/*判断队列是否为空*/int IsEmpty(pQueue pqueue){err_assert(pqueue != NULL);return !pqueue->size;}/*返回队列大小*/int GetSize(pQueue pqueue){err_assert(pqueue != NULL);return pqueue->size;}/*返回队头元素*/int GetFront(pQueue pqueue, char *pitem){err_assert(pqueue != NULL);if (IsEmpty(pqueue)) {return -1;}if (pitem) {err_assert(pqueue->front != NULL);strcpy(pitem, pqueue->front->data);}return 0;}/*返回队尾元素*/int GetRear(pQueue pqueue, char *pitem){err_assert(pqueue != NULL);if (IsEmpty(pqueue)) {return -1;}if (pitem) {err_assert(pqueue->rear != NULL);strcpy(pitem,pqueue->rear->data);}return 0;}/*将新元素入队*/int InQueue(pQueue pqueue, char *pitem){err_assert(pqueue != NULL);pNode pnode = (pNode)calloc(1, sizeof(Node));if(NULL == pnode)  {return -1;}strcpy(pnode->data, pitem);pnode->next = NULL;if(IsEmpty(pqueue)) {pqueue->front = pnode;}else {pqueue->rear->next = pnode;}pqueue->rear = pnode;pqueue->size++;return 0;}/*队头元素出队*/int OutQueue(pQueue pqueue,char *pitem){err_assert(pqueue != NULL);pNode pnode = pqueue->front;if (IsEmpty(pqueue)) {err_log("empty queue");return -1;}if (pitem)strcpy(pitem, pnode->data);pqueue->front = pnode->next;free(pnode);pqueue->size--;if (pqueue->size == 0 ){pqueue->rear = NULL;}return 0;}////////////////////////////////////////////////////////#include "pqueue.h"int main(void){pQueue queue = NULL;queue = InitQueue();InQueue(queue, "I'm ");InQueue(queue, "a ");InQueue(queue, "boy. ");while (!IsEmpty(queue)) {char buf[MAX_DATA_SIZE];if (OutQueue(queue, buf) < 0) {break;}printf("%s", buf);}printf("\n");DestroyQueue(queue);return 0;}

找到问题了,不是队列的原因,我在一个函数里面malloc了一个char*,然后在线程中调用该函数返回的这个char*,用完之后free(在该功能尾部),结果就报上面的错误了,我注释掉这句free之后就没事了,不解的是不知道为啥不能free

free应该放在你写malloc的函数里面

*** glibc detected ***      double free or corruption (!prev): 
通常是指操作已释放的对象,如: 
1.已释放对象,却再次操作该指针所指对象。 

2.多线程中某一动态分配的对象同时被两个线程使用,一个线程释放了该对象,而另一线程继续对该对象进行操作。

加个线程同步 应该就没有问题

以上就是Linux下关于C语言队列问题的详解的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/192127.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
失控进化巡逻车事件怎么玩-失控进化巡逻车事件玩法攻略
上一篇 2025年11月1日 13:37:52
下一篇 2025年11月1日 13:37:57

相关推荐

  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • c++如何实现UDP通信_c++基于UDP的网络通信示例

    UDP通信基于套接字实现,适用于实时性要求高的场景。1. 流程包括创建套接字、绑定地址(接收方)、发送(sendto)与接收(recvfrom)数据、关闭套接字;2. 服务端监听指定端口,接收客户端消息并回传;3. 客户端发送消息至服务端并接收响应;4. 跨平台需处理Winsock初始化与库链接,编…

    2026年5月10日
    100
  • 谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    使用谷歌浏览器的开发者工具截图步骤:1. 按ctrl+shift+i(windows/linux)或cmd+option+i(mac)打开开发者工具。2. 点击右上角三个点,选择”更多工具”,再选择”截图”。3. 选择截取整个页面。推荐的谷歌浏览器扩展…

    2026年5月10日 用户投稿
    100
  • pycharm解析器怎么添加 解析器添加详细流程

    在pycharm中添加解析器的步骤包括:1) 打开pycharm并进入设置,2) 选择project interpreter,3) 点击齿轮图标并选择add,4) 选择解析器类型并配置路径,5) 点击ok完成添加。添加解析器后,选择合适的类型和版本,配置环境变量,并利用解析器的功能提高开发效率。 在…

    2026年5月10日
    000
  • python中numpy的用法

    NumPy是Python中用于科学计算的强大库,它提供了以下功能:多维数组处理矩阵运算快速傅里叶变换(FFT)线性代数随机数生成 NumPy在Python中的强大功能 NumPy是Python中用于科学计算的一个强大且灵活的库。它提供了用于处理多维数组和矩阵的一组高效工具,是数据分析和机器学习项目的…

    2026年5月10日
    100
  • JavaScript Electron桌面应用

    答案:使用JavaScript开发%ignore_a_1%桌面应用需结合Web技术与Node.js,通过主进程管理窗口、渲染进程展示界面,并利用IPC通信,调用系统功能如文件对话框,最后用electron-builder打包发布,注意安全与进程职责分离。 用JavaScript开发Electron桌…

    2026年5月10日
    000
  • c语言short怎么设置

    C语言中short类型数据为16位有符号整数,范围[-32768, 32767]。设置方法:1. 声明short变量(如:short myShort = 123;);2. 使用短整型字面量(如:myShort = 123S;);3. 使用类型转换(如:short myShort = (short) …

    2026年5月10日
    000
  • WebAssembly中导入JavaScript函数:无胶水代码集成指南

    本文深入探讨了在WebAssembly模块中直接导入和使用JavaScript函数的机制,特别是当使用Emscripten的STANDALONE_WASM和SIDE_MODULE编译模式时。文章详细分析了TypeError: import object field ‘GOT.mem&#8…

    2026年5月10日
    000
  • Linux文件系统iostat命令使用技巧

    Linux文件系统iostat命令使用技巧Linux文件系统iostat命令使用技巧Linux文件系统iostat命令使用技巧Linux文件系统iostat命令使用技巧

    iostat是Linux系统中用于监控I/O设备负载的关键工具,能分析磁盘性能并识别瓶颈。默认输出包括CPU使用率和设备I/O统计,分为系统启动以来的平均值和当前采样周期数据。核心指标有:%util反映设备利用率,持续接近100%可能表示I/O瓶颈;await为平均I/O等待时间,过高说明响应变慢;…

    2026年5月10日 用户投稿
    000
  • 如何测试html5编码_测试HTML5页面编码兼容性方法【编码测试】

    HTML5页面编码兼容性测试需五步:一查meta charset是否正确且前置;二验HTTP响应头Content-Type charset是否为utf-8;三用file或chardet工具探测实际编码;四跨浏览器测试URL参数中中文、Emoji解析;五通过W3C验证服务检查编码声明与字节一致性。 如…

    2026年5月10日
    100
  • c语言整除函数怎么表示

    C语言中进行整数除法的函数是 /,其语法为 result = dividend / divisor,结果取整且不会有小数部分。 C 语言整除函数表示方法 C 语言中,用于进行整数除法的函数是 /。 语法: result = dividend / divisor; 其中: 立即学习“C语言免费学习笔记…

    2026年5月10日
    000
  • 后缀php怎么打开_php文件打开方式与运行环境搭建指南

    要打开PHP文件需根据用途选择方式:查看代码可用文本编辑器或IDE,运行则需服务器环境。推荐新手使用XAMPP、WAMP等集成环境,将文件放入htdocs目录后访问localhost;开发者可利用PHP内置服务器,命令行执行php -S localhost:8000运行;高级用户可手动配置Apach…

    2026年5月10日
    000
  • 人工智能如何为 C 语言代码提供安全增强功能?

    人工智能通过提供以下功能来提升 c 代码安全性:静态分析:识别潜在安全漏洞(例如缓冲区溢出);动态分析:监控代码执行并检测异常行为;模糊测试:生成随机输入以测试代码的异常行为;自动化修复:建议修复措施或自动生成补丁程序。 人工智能赋能 C 代码:提升安全性 人工智能 (AI) 在 C 代码安全方面发…

    2026年5月10日
    100
  • Golang如何提升TCP长连接处理效率_Golang TCP长连接处理性能优化实践详解

    答案:通过非阻塞I/O、单Goroutine双工模型、sync.Pool对象复用、TCP_NODELAY优化及高效心跳管理,结合系统调优,可显著提升Golang百万级TCP长连接处理效率。 在高并发网络服务场景中,TCP长连接的处理效率直接影响系统的吞吐能力和资源消耗。Golang凭借其轻量级Gor…

    2026年5月10日
    000
  • 解决Python脚本中相对路径文件找不到的常见问题与策略

    本文旨在解决python脚本中因相对路径处理不当导致的文件找不到错误,尤其是在项目迁移后。文章将深入探讨python中相对路径的工作原理、当前工作目录(cwd)的影响,并提供使用`os.getcwd()`诊断问题以及利用`os.path.dirname(__file__)`结合`os.path.jo…

    2026年5月10日
    000
  • Go语言Cgo代码GDB调试失效:Go 1.1版本下的挑战与官方进展

    本文探讨了go语言程序中cgo代码在使用gdb进行调试时遇到的挑战,特别指出go 1.1版本中存在的变量值显示异常问题。该问题是一个已知的官方缺陷(go issue 5221),导致在cgo交互部分gdb调试功能失效,而go 1.0版本则无此问题。文章将通过示例代码重现该现象,并阐述其根源及官方的解…

    2026年5月10日
    000
  • C++内存检测工具 Valgrind使用实践指南

    Valgrind是一款主要用于Linux和macOS的内存调试工具,可检测内存泄漏、越界访问、未初始化内存使用等问题,通过memcheck工具结合–leak-check=full、–track-origins=yes等选项进行详细分析,需编译时添加-g选项以支持调试信息,虽然…

    2026年5月10日
    000
  • php源码怎么运行手机_php源码手机运行环境搭建步骤【教程】

    可在手机上通过特定工具运行PHP源码。首先选择支持PHP的移动应用,安卓用户可安装UserLAnd或KSWEB,iOS用户可尝试iSH Shell或a-Shell;然后配置本地服务器环境,启动HTTP和PHP服务,将PHP文件放入指定根目录;接着可通过Termux搭建完整开发环境,更新包列表并安装P…

    2026年5月10日
    200
  • Go语言:检查预编译库的构建版本与平台信息

    本文详细介绍了如何利用go语言内置的`go tool pack`工具,从预编译的go静态库(`.a`文件)中提取其构建信息,包括go编译器版本、操作系统和cpu架构。当`go build`因库版本不匹配而失败时,此方法能帮助开发者准确诊断问题,确保构建环境与库的兼容性。 在Go语言的开发实践中,我们…

    2026年5月10日
    000
  • PHP动态网页数据库备份恢复_PHP动态网页MySQL数据库备份教程

    答案:PHP动态网页的MySQL数据库备份与恢复需通过定期导出SQL文件并安全存储来保障数据安全,核心方法包括使用mysqldump命令行工具实现高效灵活的自动化备份,利用phpMyAdmin图形化工具进行手动导出导入以降低操作门槛,以及通过PHP脚本调用系统命令将备份过程集成到应用中;恢复时可采用…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信