记录一次卑微找bug

写了一个多线程TCP通信客户端,在测试的时候,发现只要有一个任意一个客户端退出,服务端就会崩溃退出

[NORMAL][1681733519] 127.0.0.1:56382 is closed
Segmentation fault

导致整个服务器崩溃!

我找了好久好久,一直以为是线程池写的有问题,导致某个地方越界访问了。

最后在强迫症修改代码格式的时候,改到了Task.hpp文件,发现了这句代码,这里一开始是写着返回值的,后面没用到返回值,就把return语句注释掉了,但是没有修改函数的返回值!导致一直出bug,所以一定要规范写代码啊啊啊!

std::string operator()(const std::string &name)

记录一次卑微找bug_第1张图片

 万恶之源

使用telnet来进调试,介绍如下

telnet

sudo yum install telnet -y #安装telnet工具
telnet 127.0.0.1 8080 #远程登陆工具telnet

下面是一些常用的telnet命令用法:

  1. 连接到远程主机:telnet <远程主机IP地址> [端口号] 例如:telnet 127.0.0.1 8080 这个命令会连接到IP地址为127.0.0.1的主机的8080端口。

  2. 发送命令:在连接上远程主机后,可以输入命令来执行操作。输入Ctrl+]命令,再回车,可以进入发送消息的功能。

  3. 退出连接:先输入Ctrl+]命令退出发送消息的功能,再输入quit,可以退出当前的telnet连接。

需要注意的是,telnet命令在现代网络中已经不太安全,因为它的数据传输是明文的,容易被黑客截获。因此,建议使用更加安全的SSH协议来进行远程登录。

你可能感兴趣的:(Linux,bug)