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

[程序员] 最近的感悟,错误处理占大头?

根据昨天分享的一个问题,想到的。

在代码里,异常处理的代码也算是占大头,扑面而来的就是发生错误时怎么处理的大片代码;而且出现问题的概率是绝对的占大头。所以,异常代码出现bug的概率也在不知不觉中增加!

昨天遇到的这个例子:[程序员] 网络丢包的另一个例子:send失败是不是要close socket?。就是一个很好的说明,这里就是一个非常极端的例子,收发两端的buff都满了,这种情况出现的概率非常低;最终触发错误处理代码逻辑中的不合理,导致上层业务数据丢。但是这种不合理,又没有什么好的正向解决的方法(或者是一直不close,慢慢等buff清空,但是又要考虑是否有安全问题),导致最终的解决方法是不确定的,需要根据具体的需求,具体实现!

或者是将buff的size增大,减少出现buff慢的概率,然后容忍这种低概率事件的存在。或者是上层实现更加可靠的传输。或者是等待的时间拉长,也是容忍这种高概率事件的发生。

所以新产品虽然在实验室的环境中,跑着没有问题;但是并不代表安装到客户现场就一定没问题,因为异常出现的本质就是意想不到!谁能知道客户现场的网络能有这么差!导致产品内部各种异常处理出现问题/不能恢复!谁知道客户买的硬件会有缺陷,磁盘读取非常的慢,导致程序不能按时处理完成某项业务,导致产品问题!谁又能想到客户网络对接的网元实现与实验室的行为不一致,导致不兼容!谁又能知道客户技术员是如此的较真,只要不顺手,什么都可以称之为问题!等等不一而足。不知道大家有没有遇到过此类的事件?

这些都是超出研发想象的一些异常问题。所以即使在研发内部已经预想到了很多的异常可能,加了很多的异常代码,但是保不住还有没有想到的异常在客户现场等着你!即使想到了某种异常,而加了异常处理代码,到了现场,或许会因为异常处理代码的加入,而引入其他的问题。

http://www.lryc.cn/news/351780.html

相关文章:

  • vue3(一) - 结构认识
  • 数据库迁移——kettle开发01
  • Netty: Netty中的组件
  • Julia编程01:Julia语言介绍
  • 二叉树顺序结构及链式结构
  • 【Python】pandas连续变量分箱
  • Qt 打卡小程序总结
  • 【qt】标准项模型
  • 一文深度剖析 ColBERT
  • css左右滚动互不影响
  • 【linux-uboot移植-mmc及tftp启动-IMX6ULL】
  • Python-温故知新
  • 绿联NAS DXP系列发布:内网穿透技术在私有云的应用分析
  • 力扣:242. 有效的字母异位词
  • 设计模式14——组合模式
  • MyBatis面试题(Mybaits的优点、缺点、适用场合、与Hibernate有哪些不同)
  • python写接口性能测试
  • 《暮色将尽》跨越世纪的历程,慢慢走向并完善自我
  • python-鸡兔同笼问题:已知鸡和兔的总头数与总脚数。求笼中鸡和兔各几只?
  • 【NumPy】关于numpy.transpose()函数,看这一篇文章就够了
  • 什么是住宅IP代理?为什么需要家庭 IP 代理
  • Java方法的重载
  • RabbitMQ 消息队列安装及入门
  • K8S认证|CKA题库+答案| 14. 排查故障节点
  • Linux:网络管理命令之ss
  • 数据结构-队列(带图详解)
  • python文件名通常以什么结尾
  • 前端javascript 中 JSON.parse() 的作用
  • 【Linux学习】进程基础API
  • 音视频及H264/H256编码相关原理