前言
通过分析源码自动查找bug,我们将之称为静态检查(static analyzer
).静态库致力于提供用于分析C
,C++
,Objective-C
的高质量的静态分析框架.检查库是完全开源的,我们可以在上面提供的链接里,下载最新的检查库.
我们可以制定使用特定的检查库,也可以使用XCode
自带的检查库,如何实现对检查库的配置和自定义,就是这篇文章要讲的内容.
使用场景
static analyzer
的实质是提供了一个fake compiler
,在真正的compile
完成之后,进行analyzer
.具体说明在scan-build内.
static analyzer
的输出是对bug检测的一个结果,这些bug是在compile
完成之后进行的.我们可以通过持续集成,将结果输出到sonar
上,进行一个bug的定级,和一些bad smell
的检查.
运行自定义的检查库
配置环境
下载
- 下载最新的分析库,点击链接,下载最新即可.
- 解压: 双击解压.或者通过指令
tar -jxvf <checkerFile>
安装命令行工具
下载checker
解压后,现将checker-xxx
文件夹保存到本地路径下,便于下面的命令工具安装,避免误删.
保存文件夹: 通过
Finder
--前往文件夹
--/usr/local/bin
,将checker-xxx
移动到文件夹下.安装命令行工具:
checker-xxx
文件中包含两个工具scan-build
和scan-view
,它们在checker
通过下载的checker
安装
$ sudo nano /etc/paths
在终端进入了文件的编辑界面,展示如下
/usr/local/bin
/usr/bin
/bin
/usr/sbin
/sbin
添加下载的checker-xxx
内scan-build
和scan-view
对应的文件夹
/usr/local/bin
/usr/bin
/bin
/usr/sbin
/sbin
/usr/local/checker-279
通过^X
退出编辑
通过$ echo $PATH
查看结果.
仅安装scan-build(不推荐,只做了解)
安装
pip
,用于安装scan-build
sudo easy_install pip
安装
scan-build
pip install scan-build
如果出现Permission denied: '/Library/Python/2.7/***'
的报错,执行下面代码
sudo chown -R $USER /Library/Python/2.7
然后再执行
pip install scan-build
使用最新的检查库
Clang
开源的代码检查库更新比较频繁,会有更多的bug提示和代码检查.所以使用最新的检查库,可以带来更全面的检查,以提高代码质量和健壮性.
静态检查时,其实是提供了一个"假的"编译器,在编译完成后,会对
- 下载
Clang
提供的静态库
在链接地址下载最新的checker-xxx.tar.bz2
- 解压
双击解压,解压出来的文件夹名字为checker-xxx
- 使用当前的
checker
作为检查规范
下载的checker
内包含set-xcode-analyzer
命令行工具,进入checker-xxx
文件夹下,cd /bin
,执行以下指令,在这之前,记得退出XCode
sudo ./set-xcode-analyzer --use-checker-build=/usr/local/checker-xxx
以上指令就是使用我们下载的检查器进行代码检查了.
- 使用
XCode
自带的静态检查
如果想恢复到系统自带的静态检查,进入对应文件夹下,执行
sudo ./set-xcode-analyzer --use-xcode-clang
静态检查工具讲解
在checker-xxx
文件夹中,我们只需要关注两个文件
- scan-build: 运行分析器的高级命令行工具
-
scan-view: 查看
scan-build
生成的分析结果.
scan-build
scan-build
是用来运行静态分析的命令行工具.在项目build
时,源文件会被编译,并且会进行静态分析.build
完成后,结果会以网页浏览器的形式展示给开发者.
scan-build
的用法是在xcodebuild
命令前加上scan-build
即可.以下有需要注意的几点:
- 在debug模式下运行
因为大多数项目允许在debug模式下使用断言,断言对于静态检查很有作用,可以减少错误检查的几率,可以通过在scan-build
后添加--force-analyze-debug-code
来制定模式,当然也可以通过xcodebuild -configuration Debug
来实现. - 通过
verbose
查看详情 - 在模拟器下运行
scan-build xcodebuild -configuration Debug -sdk iphonesimulator10.1
扩展:如果本地有多个编译器,可以通过指令来制定编译器:scan-build --use-cc <PATH>
或scan-build --use-c++ <PATH>
运行完成之后,会输出通过scan-view
查看的指示,在scan-view
后跟着一个文件夹,文件夹内部都是.html
文件,可以通过scan-view <PATH>
来查看,也可以直接双击打开.
静态检查知识补充
使用静态分析库有几个注意点:
持续更新,不断优化
代码检查库一直计划提升代码检查的精确度和范围,优化查找bug的方式,对于静态代码检查有一些基本的限制,可优化的空间还有很大.比编译耗时
使用静态代码检查自动查找程序bug其实是使用CPU时间来换更高的代码质量.静态分析要比编译耗时.
即使Clang
在速度和轻量级上尽可能进行了优化,但是也不要期待会比项目编译更快.一些用于查找bug的代码最差时需要指数级的时间消耗.检测失误
静态检测并不是完美的,可能正确的代码也会出现一些错误的bug提示,因为不同代码需要的检查精度不同,我不同的检查规则中,可能会出现不同频率的检测失误,Clang
一直在尽力减少这种失误,但目前并没有完全避免.并未100%覆盖全部bug
静态检查只是找到了那写常见的特定bug,但是对于某些bug还未覆盖.
相关链接
Use clang-tidy for static analysis and integration in Sonarqube