linux 下写socket遭遇broken pipe(SIGPIPE C++)

在Linux下,当尝试向断开连接的socket发送数据时,系统会产生SIGPIPE信号导致程序终止。通过捕获SIGPIPE信号或设置其处理函数为SIG_IGN可以避免程序异常退出。本文介绍了如何在C++代码中处理这一问题,以防止程序因broken pipe信号而中断。
摘要由CSDN通过智能技术生成

原代码片段如下,程序在第08行报错,但是try,,,catch无法抓到错误,经过debug分析是由于收到broken pipe的信号。看来程序此时被终止了;那么我期望不被终止,该怎么做了。


01        int sendLen = 0;
02        int totalLen = 0;
03        int packSize = pack.size();
04        while(packSize != totalLen)
05        {
06                try
07                {
08                         sendLen = write(fd, const_cast<char*>(pack.c_str())+totalLen, packSize-totalLen);
09                        totalLen += sendLen;
10                        if(sendLen <= 0)
11                        {
12                                totalLen == 0;
13                                fprintf(stderr,"write fd err . fd == %d - %m/n",fd);
14                                return false;
15                        }
16                }

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值