2019年1月31日

转一些思想 代码大全的

防御式编程思想 ----《代码大全》简要笔记

96 
娟子 
2016.05.07 16:19* 字数 1098 阅读 832评论 0
主要思想:

子程序应该不因传入错误数据而被破坏, 哪怕是由其他子程序产生的错误数据;换一种说法是, 程序员应该承认程序都是有问题的都需要被修改。

保护程序免遭非法输入数据破坏

软件开发领域“垃圾进,垃圾出”的原则已经过时,应该做到: 垃圾进,什么都不出;垃圾进,出错误提示;不许垃圾进。做法如下:

  • 检查所有来源于外部的值
  • 检查子程序所有输入参数的值
  • 决定如何处理错误的输入数据
Assertions 断言

在程序开发和使用期间,用于程序自检的代码即为断言; 使用断言可以在程序出现问题时让程序员更快速的根据断言给出的信息排查问题和原因。
断言通常含有两个参数:一个描述假设为真时的情况的布尔表达式,一个断言为假时需要显示的信息。

建立自己的断言机制
使用断言的指导建议
  • 用错误处理代码来处理预期会发生的情况, 用断言来绝不应该发生的状况
  • 避免把需要执行的代码放到断言中
  • 用断言来注解并验证前后条件
  • 对于高健壮性的代码, 应该线使用断言再处理错误
错误处理技术

可以使用的技术:返回中立值;换用下一个正确数据(如读取数据);返回与前次相同的数据(如图像显示处理);换用最接近的合法值(超过预设范围的值);把警告信息记录到日志文件中;返回一个错误码;调用错误处理子程序或对象;当错误发生时显示出错信息;用最妥当的方式在局部处理错误;关闭程序。

健壮性与正确性

二者在某种意义上是相斥的

高层次设计对错误处理方式的影响
异常 Exceptions

把代码中的错误和异常事件传递给调用方代码的一种特殊手段。

审慎明智的使用异常:

  • 用异常通知程序的其他部分,发生了不可忽略的错误
  • 只在真正例外的情况下才抛出异常
  • 不能用异常来推卸责任
  • 避免在构造函数和析构函数中抛出异常, 除非你在同一个地方把他们捕获
  • 在恰当的抽象层次抛出异常(如抛出更底层异常)
  • 在异常消息中加入导致异常发生的全部信息
  • 避免使用空的catch语句
  • 了解所有函数库可能抛出的异常
  • 考虑创建一个集中地异常报告机制
  • 把项目中对异常的使用标准化
  • 考虑异常的替换方案
隔离程序,使之包容由错误造成的伤害

隔栏,一种代码的容损策略,如常用的: 在输入数据时将其转化为恰当的类型。

辅助调试的代码
不要自动地把产品版的限制强加于开发版 之上
尽早引入辅助调试的代码 rails中的 pry、 debugger等
采用进攻式编程

在开发阶段让异常尽量显现出来,而在产品真正运行时能够自我修复

计划移除调试辅助的代码
  • 使用版本控制工具
  • 使用内置的预处理器
  • 编写你自己的预处理器
  • 使用调试存根
确定在产品代码中该保留多少防御式代码
  • 保留那些检查重要错误的代码
  • 去掉检查细微错误的代码
  • 去掉可以导致程序硬性崩溃的代码
  • 保留可以让程序稳妥崩溃的代码
  • 为你的技术支持人员记录错误信息
  • 确认留在代码中的错误信息是友好的
对防御式变成采取防御式姿态

用防御的姿态适当的因地制宜的使用防御式代码

posted @ 2019-01-31 16:21 铁轨嘴上飘 阅读(161) 评论(0) 推荐(0) 编辑

2018年10月16日

一些方案

摘要: kafaka用的是raft算法来保证分布式消息队列数据一致性,这点要优于rabbitmq. 分布式事务,通常是保证最终一致,这边先事务提交,然后日志文件里存下一步的操作,通过异步队列去从日志表里跑数据,成功或者失败后修改状态值。 消息队列如果出现积压,目前看到的还是扩容的方式,将服务器资源扩大到能够 阅读全文

posted @ 2018-10-16 18:20 铁轨嘴上飘 阅读(127) 评论(0) 推荐(0) 编辑

2018年9月18日

UML建模工具

摘要: 待完善 阅读全文

posted @ 2018-09-18 14:18 铁轨嘴上飘 阅读(160) 评论(0) 推荐(0) 编辑

linux 文本操作

摘要: sed -i 直接修改 sed 是负责插入替换删除字符串操作。 sed -n '/11/p' 11.txt |sed 's/11/33333/g' 查找11并替换11位3333 sed 's/11/33333/g' 11.txt 将11 替换成33333 https://www.cnblogs.co 阅读全文

posted @ 2018-09-18 14:03 铁轨嘴上飘 阅读(117) 评论(0) 推荐(0) 编辑

laravel 实现思路以及各组件原理

摘要: laravel 内核是个IOC容器,IOC是把本来自己实例化的对象。 通过在容器里注册,通过容器来进行实例化。 laravel队列用的是redis的列表来实现。 阅读全文

posted @ 2018-09-18 14:02 铁轨嘴上飘 阅读(338) 评论(0) 推荐(0) 编辑

2018年9月17日

另开一篇 https

摘要: https 流程 1.加密传输:对称加密传输信息 2.身份认证:非对称加密。通过证书来保障客户端给服务器的密钥唯一性。 因为中间层要是伪装公钥和证书,但是又无法解密原有的发送的数据,那么发给服务器的数据就不正确,无法从服务器拿到正确的数据。客户自然也就不会上当。 如果不伪装的话,从客户端那里拿到的数 阅读全文

posted @ 2018-09-17 16:49 铁轨嘴上飘 阅读(96) 评论(0) 推荐(0) 编辑

错题总结

摘要: 1.array_merage和相加的区别 数字索引 array_merge 会完全合并成新的数组,相加的话会根据key值是否相同优先保留前者。 字符串索引, 相同key值array_merge后者取代前者,相加前者取代后者。 2 trim函数 $a = 'aabbc'; echo trim($a,' 阅读全文

posted @ 2018-09-17 09:40 铁轨嘴上飘 阅读(112) 评论(0) 推荐(0) 编辑

2018年9月16日

认真工作的原因以及方法

摘要: 认真工作的方法 1.良好的生活习惯--保障能长时间的工作 2.高效的工作习惯以及学习习惯--保障能够快速适应工作的变化。 3.良好的口才以及手段激发手下的潜力--做老板或者领导必备的条件。 一切高效工作的原始驱动都是来源于自身的压力--生活中对更美好生活的向往。 记得经常复习以前的错误。反复的记住自 阅读全文

posted @ 2018-09-16 09:57 铁轨嘴上飘 阅读(437) 评论(0) 推荐(0) 编辑

2018年9月11日

数据库测试

摘要: 试了下2千万条数据的表,做了索引后,当查询第1900万条的时候,要9秒多。 count(*) 和查询后面的数据所耗时间差不多。 100万以内的数据可以在1秒内。500万1,6秒。 尽量保证每张表数据不超过100万比较好。 elatichsearch主要是做分词查询,数据量大的时候原理上不会比Mysq 阅读全文

posted @ 2018-09-11 17:42 铁轨嘴上飘 阅读(100) 评论(0) 推荐(0) 编辑

2018年8月28日

Laravel 执行过程核心

摘要: protected function sendRequestThroughRouter($request){ $this->app->instance('request', $request); //在app中注册request实例 Facade::clearResolvedInstance('re 阅读全文

posted @ 2018-08-28 10:55 铁轨嘴上飘 阅读(116) 评论(0) 推荐(0) 编辑

< 2025年2月 >
26 27 28 29 30 31 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 1
2 3 4 5 6 7 8

导航

点击右上角即可分享
微信分享提示