clang自定义静态代码检查库

前言

通过分析源码自动查找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文件夹保存到本地路径下,便于下面的命令工具安装,避免误删.

  1. 保存文件夹: 通过Finder--前往文件夹--/usr/local/bin,将checker-xxx移动到文件夹下.

  2. 安装命令行工具: checker-xxx文件中包含两个工具scan-buildscan-view,它们在checker
    通过下载的checker安装

$ sudo nano /etc/paths

在终端进入了文件的编辑界面,展示如下

/usr/local/bin
/usr/bin
/bin
/usr/sbin
/sbin

添加下载的checker-xxxscan-buildscan-view对应的文件夹

/usr/local/bin
/usr/bin
/bin
/usr/sbin
/sbin
/usr/local/checker-279

通过^X退出编辑

通过$ echo $PATH查看结果.

仅安装scan-build(不推荐,只做了解)

  1. 安装pip,用于安装scan-build
    sudo easy_install pip

  2. 安装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>来查看,也可以直接双击打开.

静态检查知识补充

使用静态分析库有几个注意点:

  1. 持续更新,不断优化
    代码检查库一直计划提升代码检查的精确度和范围,优化查找bug的方式,对于静态代码检查有一些基本的限制,可优化的空间还有很大.

  2. 比编译耗时
    使用静态代码检查自动查找程序bug其实是使用CPU时间来换更高的代码质量.静态分析要比编译耗时.
    即使Clang在速度和轻量级上尽可能进行了优化,但是也不要期待会比项目编译更快.一些用于查找bug的代码最差时需要指数级的时间消耗.

  3. 检测失误
    静态检测并不是完美的,可能正确的代码也会出现一些错误的bug提示,因为不同代码需要的检查精度不同,我不同的检查规则中,可能会出现不同频率的检测失误,Clang一直在尽力减少这种失误,但目前并没有完全避免.

  4. 并未100%覆盖全部bug
    静态检查只是找到了那写常见的特定bug,但是对于某些bug还未覆盖.

相关链接

运行自定义静态检查

Clang static analysis

scan-build

static analyzer installation

Use clang-tidy for static analysis and integration in Sonarqube

Clang Static Analyzer

Creating and using Clang plugin with Xcode

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343

推荐阅读更多精彩内容