静态分析与软件测试中的动态分析
admin
2023-02-18 19:40:03
0

什么是静态分析?
静态分析不涉及被测软件的动态执行,并且可以在运行程序之前的早期阶段检测可能的缺陷。
静态分析在编码之后和执行单元测试之前完成。
静态分析可以由机器完成,以自动“遍历”源代码并检测不合规规则。经典的例子是一个编译器,它可以找到词汇,句法甚至一些语义错误。
静态分析也可以由审查代码的人执行,以确保使用正确的编码标准和约定来构建程序。这通常称为代码审查,由同行开发人员(编写代码的开发人员以外的人)完成。
静态分析还用于强制开发人员通过设置不得使用的规则来不使用编程语言的风险或错误部分。
当开发人员执行代码分析时,他们通常会寻找
 代码行
 评论频率
 适当的嵌套
 函数调用次数
 循环复杂性
 也可以检查单元测试
质量属性可以成为静态分析的重点:
 可靠性
 可维护性
 可测性
 可重用性
 可移植性
 效率
静态分析的优点是什么?
静态分析的主要优点是,在准备进行集成和进一步测试之前,它会发现代码存在问题。
静态代码分析的优点:
 它可以在确切的位置找到代码中的弱点。
 它可以由经过培训的软件保障开发人员进行,他们完全理解代码。
 其他或未来的开发人员可以轻松理解源代码
 它允许更快地转换修复
 在开发生命周期的早期发现了弱点,降低了修复成本。
 在以后的测试中减少缺陷
 检测到使用动态测试不能或几乎检测不到的独特缺陷
 无法访问的代码
 可变使用(未申报,未使用)
 未调用的函数
 边界值违规
静态代码分析限制
 如果手动进行则很费时间。
 自动化工具会产生误报和漏报。
 没有足够的训练有素的人员来彻底进行静态代码分析。
 自动化工具可以提供错误的安全感,以便解决所有问题。
 自动化工具的效果与它们用于扫描的规则一样好。
 它没有发现运行时环境中引入的漏洞。
什么是动态分析?
与静态分析相反,在不执行代码的情况下,动态分析基于系统执行,通常使用工具。
来自维基百科对动态程序分析的定义:
动态程序分析是对计算机软件的分析,该计算机软件是通过在真实或虚拟处理器上执行从该软件构建的程序来执行的(在不执行程序的情况下执行的分析称为静态代码分析)。动态程序分析工具可能需要加载特殊库甚至重新编译程序代码。
最常见的动态分析实践是针对代码执行单元测试以查找代码中的任何错误。
动态代码分析优势:
 它识别运行时环境中的漏洞。
 它允许分析您无法访问实际代码的应用程序。
 它识别静态代码分析中可能是漏报的漏洞。
 它允许您验证静态代码分析结果。
 它可以针对任何应用程序进行。
动态代码分析限制:
 自动化工具提供了一种错误的安全感,一切都在被解决。
 无法保证源代码的完整测试覆盖率
 自动化工具会产生误报和漏报。
 自动化工具仅与用于扫描的规则一样好。
 将漏洞追溯到代码中的确切位置更加困难,需要更长时间才能解决问题。

相关内容

热门资讯

最新引进“芒果竞技真的有挂吗?... 家人们!今天小编来为大家解答芒果竞技透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买很...
今日重大消息“川蜀汇有没有挂?... 今日重大消息“川蜀汇有没有挂?”(果然有透视挂)您好,川蜀汇这个游戏其实有挂的,确实是有挂的,需要了...
今日重大通报“新蜜瓜拼十开挂神... 家人们!今天小编来为大家解答新蜜瓜拼十透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买...
玩家攻略科普“陕西欢喜有没有挂... 玩家攻略科普“陕西欢喜有没有挂?”(果然有透视挂)您好,陕西欢喜这个游戏其实有挂的,确实是有挂的,需...
最新引进“新道游到底是不是挂?... 您好:新道游这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游戏中...
终于了解“黑桃A怎么装挂?”(... 您好:黑桃A这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游戏中...
今日重磅消息“经典联盟牛牛有挂... 今日重磅消息“经典联盟牛牛有挂吗?”(原来真的有挂)您好,经典联盟牛牛这个游戏其实有挂的,确实是有挂...
玩家最新攻略“宝宝浙江游戏到底... 玩家最新攻略“宝宝浙江游戏到底是不是挂?”(其实是有挂)您好,宝宝浙江游戏这个游戏其实有挂的,确实是...
玩家攻略科普“樱花互粉可以开挂... 玩家攻略科普“樱花互粉可以开挂吗?”(详细开挂教程)您好,樱花互粉这个游戏其实有挂的,确实是有挂的,...
今日重大消息“娱网皮球真的有挂... 网上科普关于“娱网皮球有没有挂”话题很是火热,小编也是针对娱网皮球作*弊开挂的方法以及开挂对应的知识...