当前位置: 首页 > news >正文

问题排查|记录一次基于mymuduo库开发的服务器错误排查(段错误--Segmentation fault (core dumped))

问题记录:
在刚完成mymuduo库之后,写了一个简单的测试服务器,
但是在服务器运行后直接报错:

cherry@hcss-ecs-4995:~/mymuduo/example$ ./testserver
Segmentation fault (core dumped)

出现多错误这通常意味着程序试图访问其内存空间中未分配(或不允许)的部分。

所以我决定先使用gdb进行一下简单的调试:

gdb ./testserver

把程序跑起来之后马上定位到了报错位置:

Program received signal SIGSEGV, Segmentation fault.
EventLoop::updateChannel (this=0x7fffffffdd60, channel=0x555555572eb0) at /home/cherry/mymuduo/EventLoop.cc:126
126         poller_->updateChannel(channel);

我再查看代码:

125 void EventLoop::updateChannel(Channel *channel) {
126 	poller_->updateChannel(channel);
127 }

既然是段错误,说明我们访问了不被允许访问的内存,或者操作了不被允许操作的内存
接下来我们有以下三个主要的思路:

(gdb) print poller_ #poller是否是空
(gdb) print channel #channel是否为空
(gdb) print *channel #如果channel不是空,那么它是否指向了有效对象,该对象状态是否正常?
(gdb) backtrace #如果都正常,查看调用栈,是哪里调用了 EventLoop::updateChannel 方法

但是比较悲剧的是,我直接 print poller_ 就发现我们重要的poller对象竟然是空!

所以我马上去看了一下构造函数代码是否正常

EventLoop::EventLoop(): looping_(false), quit_(false), callingPendingFunctors_(false), threadId_(CurrentThread::tid()), poller_(Poller::newDefaultPoller(this)), wakeupFd_(createEventfd()), wakeupChannel_(new Channel(this, wakeupFd_)) 

在构造函数中, poller_的初始化是通过newDefaultPoller来完成的,那么去看看它是否正常工作:

Poller* Poller::newDefaultPoller(EventLoop *loop) {if (::getenv("MUDUO_USE_POLL")) {return nullptr; // 生成poll的实例} else {return nullptr; // 生成epoll的实例}
}

好巧不巧,我们竟然在生成epoll实例的地方返回了一个空!之前在写这个代码的时候还没有完成EpollPoller.h文件的书写,为了防止部分编译报错所以先写成空了。

更改代码如下:

#include "EpollPoller.h"
return new EPollPoller(loop);
http://www.lryc.cn/news/358766.html

相关文章:

  • Mysql常用操作DQL数据库、表操作:
  • 标题:Go语言中的YAML魔法:轻松配置你的环境
  • STM32高级控制定时器之输入捕获模式
  • 使用 Vue 3 和 qrcode.js 开发二维码显示组件
  • LabVIEW异步编程概述
  • 【数据库】MySQL表的操作
  • 【mybatis解决oracle查询in超过1000条数据】
  • EasyExcel之动态表头导出不生效
  • appium元素定位工具_uiautomatorviewer.bat
  • 手机离线翻译哪个好?断网翻译也能超丝滑
  • 神器!!Python热重载调试【送源码】
  • Flutter基础 -- Dart 语言 -- 列表集合枚举
  • 怎么花草识别?方法有三种!
  • 【qt】自定义对话框
  • 汽车IVI中控开发入门及进阶(二十二):video decoder视频解码芯片
  • 混沌测试介绍
  • python 单链表创建,遍历
  • 【方法】如何取消PPT“以只读方式打开“?
  • ChatTTS,语气韵律媲美真人的开源TTS模型,文字转语音界的新魁首,对标微软Azure-tts
  • Django企业招聘后台管理系统开发实战四
  • APP上架 篇一:上架资质要求
  • C++入门之类和对象
  • html中table的替代方案
  • 单片机的自动化编程语言:深度探索与未来展望
  • k8s 部署 Dashboard
  • HTTP/超文本传输协议(Hypertext Transfer Protocol)及HTTP协议通信步骤介绍和请求、响应阶段详解;
  • 【机器学习】随机森林:深度解析与应用实践
  • pytorch使用tensorboardX面板自动生成模型结构图和各类可视化图像
  • C# 键值对
  • android 应用安装目录