12、Linux系统编程中的错误处理与errno使用

Linux系统编程中的错误处理与errno使用

1. 常见错误类型及处理基础

在编程过程中,大多数错误要么与权限相关,要么与系统资源有关。在处理数学函数时,当出现错误,它们可能会返回特殊数字,因为常规的 0、1 和 -1 可能是正常计算结果。

在处理用户输入和缓冲区溢出方面,像 strcat() strcpy() strdup() 这类函数是不安全的。因为它们会复制接收到的所有内容,而不考虑目标缓冲区是否有足够空间。例如,当给程序输入一个超过 10 个字符(实际是 9 个,因为空字符占一位)的字符串时,程序可能会因段错误而崩溃。

不过,这些 str 函数有对应的带 n 的版本,如 strncat() 。这类函数只会复制作为第三个参数指定的大小。在示例中,我们指定大小为 sizeof(buf)-1 ,这样做是为了给字符串末尾的空字符 \0 留出空间。使用 sizeof(buf) 比使用具体数字更好,因为如果后续更改了缓冲区大小,使用具体数字可能会忘记更新 strncat() 的参数。

2. 错误处理与errno变量

在 Linux 和其他类 UNIX 系统中,大多数系统调用函数在出错时会设置一个特殊变量 errno 。我们可以从返回值(通常为 -1)获取一个通用错误码,然后通过查看 errno

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值