防御编程与防御陷阱

防御编程旨在防止崩溃和错误,但不当使用可能导致问题被掩盖。文章阐述了如何从消极防御转向积极响应,确保系统在面对输入错误时能及时采取有效措施。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

防御编程是在多人开发的系统中保持局部正确性的一种编程方法,

有其积极的一方面,通过防御编程检查所使用参数是否正确阻止崩溃和意外的产生。

防御编程对输入参数的一个检查,这种检查由基本的是否存在,范围是否正确,逻辑是否符合等等。

 

例如函数防御编程有如下的形式却变成了防御陷阱

void fun(void* p)

{

    if(!p)return;

}

函数判断p是否可用,如果不可用就直接返回不执行。

看似通过防御编程解决里p指针不正常导致的崩溃,却把错误隐藏起来。

这种如果不正确就不执行的方式是一种消极防御,或者叫防御陷阱。

在多人合作的环境中其他人可能根本不知道你的函数没有执行。

只有最后出现逻辑数据不正常的情况下才猛然发现是因为某个函数没有正常执行导致的。

正常的方式是对所防御的情况做出评估给出对应的反应。

例如比较极端的提醒方式直接退出系统。

void fun(void* p)

{

    if(!p)_exit();

}

当然还有更友好的方式,弹出对话框警告,

但前提是要提供对应的支持,如果是系统函数要写严重警告的错误日志等等。

防御编程不能为了防御再去防御,要在第一时间作出对应防御的同时

一定要对所防御的本身提出回应

而不是消极的等待出现严重问题再倒查防御错误。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值