infer使用的浅谈简析

作者: Nlinger | 来源:发表于2016-03-25 15:17 被阅读4028次

所有者:facebook

使用场景: 在发布前检测 iOS 和 Android 应用的问题

About Infer


Infer 是一个静态分析工具。Infer 可以分析 Objective-C, Java 或者 C 代码,报告潜在的问题。

任何人都可以使用 Infer 检测应用,这可以将那些严重的 bug 扼杀在发布之前,同时防止应用崩溃和性能低下。

infer分析图

Infer特性


Android 和 Java

Infer 可检查 Android 和 Java 代码中的 NullPointException 和 资源泄露。

iOS

除了以上,Infer 还可发现 iOS 和 C 代码中的内存泄露,内存泄露,内存泄露。

Infer适用范围


包括 Facebook Android 和 iOS 主客户端,Facebook Messenger, Instagram 在内的,以及其他影响亿万用户的手机应用,每次代码变更,都要经过 Infer 的检测。

Infer优点


1:效率高,规模大,几分钟能扫描数千行代码;

2:支持增量及非增量分析(后边会解释)

3:分解分析,整合输出结果。(infer能将代码分解,小范围分析后再将结果整合在一起,兼顾分析的深度和速度)

Infer捕捉的bug类型


C/OC中捕捉的bug类型

1:Resource leak

2:Memory leak

3:Null dereference

4:Premature nil termination argument

只在 OC中捕捉的bug类型

1:Retain cycle

2:Parameter not null checked

3:Ivar not null checked

Infer安装


Infer为Linux和MacOS系统提供了预构建的二进制文件,如果你只是想使用Infer,而不想为该项目贡献代码的话,这些二进制文件足够了.相反,如果你想编译infer,请选择源码安装。此文档以Mac系统,源文件安装为栗子。

环境要求

Python版本:大于等于2.7

第一种:二进制文件安装

infer release页面获取最新版本infer-osx-vXX.tar.xz (以osx标识),然后执行下面命令来安装Infer.

第二种:源码安装

借助brew安装

1.1安装brew

/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

1.2安装infer

brew install infer

安装达到100% 后可通过`infer --version`查看infer版本信息

1.3配置到环境变量

cd 你的代码文件路径//建议放到一个不常改动的位置哦)

echo "export PATH=\"\$PATH:pwd/infer/infer/bin\"" \ >> ~/.bash_profile &&source ~/.bash_profile

执行完如上操作,如果没报错你就成功啦!

Git克隆+clang

(网速特别慢就不推荐了,因为俩步操作都很耗时)

2.1远程克隆git clone https://github.com/facebook/infer.git

2.2插件安装

注意:如果要分析C和Objective-C,Infer还需要clang以及facebook-clang-plugin插件。 facebook-clang-plugin插件见:facebook-clang-plugin如果只想分析Java/Android代码,那么无需以上的依赖库

Infer 的使用


facebook/infer demo

目前infer支持的编译器有如下几种:

infer能分析的文件类型

在github上下载demo,demo下examples目录里,你会发现有android项目、C语言文件、java类、oc类、iOS项目,没错啦,infer完全支持以上几种类型的BUG分析。这里我们用ios_hello项目来做栗子:

首先用cd命令进入ios_hello目录,然后运行以下命令进行编译

infer -- xcodebuild -target HelloWorldApp -configuration Debug -sdk iphonesimulator

注意: 其中HelloWorldApp是你的项目名称

编译结果


1: 在项目所在目录下多出build和infer-out文件夹

编译后

build文件夹:捕获阶段: Infer 捕获编译命令(上面介绍的编译器命令),将文件翻译成 Infer 内部的中间语言。运行环境和设备信息也有所体现。

infer-out文件夹:分析阶段产生的文件,Infer将分析bugs结果输出到不同格式文件中,如csv、txt、json 方便对分析结果进行加工分析。

2: 运行后在终端会看到大量日志信息(同infer-out文件,可以以多种形式查看log信息)

代码分析

cc

错误总结

注意事项总结


1:在俩次执行编译命令的过程中,发现在没有对代码做任何更改的时候,报出BUILD SUCCEEDED的提示:我懵了!

我懵了

根据提示可以看到,此次build并没有分析任何文件。原因就是上面所提到的增量分析。

增量模式和非增量模式

在第一次运行的时候,两种模式是一样的,都会对工程的所有文件进行编译检查,产生检查结果:

增量模式:当已经产生分析结果后(build和infer-out文件夹),再执行编译命令,即为增量模式。如有代码没有改动,则此次不会有编译结果产生,如果代码有新的改动,此次只产生新的编译结果。这种以增量为基准的原则叫做增量模式。

非增量模式:在删除了俩个文件夹的情况下,运行文件,会输出所有的编译信息,即此时处于非增量模式。

增量模式和非增量模式的转化

1:简单粗暴的做法是删除文件夹,即增量->非增量

2:科学的做法是这样的:xcodebuild -target HelloWorldApp -configuration Debug -sdk iphonesimulator clean,以保证增量->非增量状态

but...项目中我们更常用到的方式是修改单个文件,然后检测。 比如我检测出了这样的问题:

查到bug

然后我去代码修正了这个问题:

修改代码

执行:

xcodebuild -target HelloWorldApp -configuration Debug -sdk iphonesimulator clean

然后看终端,问题就修复了。

2:如果编译过程出现‘AttributeError: 'NoneType' object has no attribute 'encode'’

encode错误

解决办法:1,pwd查看你当前目录,应该在工程所在目录下,而不是图上用户目录。

                2,猴塞雷,请关注你的额代码,可能有错误。

相关文章

  • infer使用的浅谈简析

    所有者:facebook 使用场景: 在发布前检测 iOS 和 Android 应用的问题 About Infer...

  • iOS infer静态分析工具使用

    infer介绍 infer官网 infer中文网站 Infer 是 Facebook 开源的、使用 OCaml 语...

  • infer 项目静态分析

    使用infer进行项目静态分析 项目不使用.xcworkspace时使用,xxx为项目名,下同 infer -- ...

  • 使用Infer进行静态代码扫描

    安装Infer 在Mac上可以直接使用brew 来安装,比较简单 使用Infer Android iOS 查看报告...

  • infer使用

    简单文件分析 在examples目录下的README.md文件,讲解了如何编译分析文件和项目 编译分析Hello....

  • 2019-02-17 Google-Colab 读取Google

    如下图所示,infer_3.png的位置。 亲测可行,使用PaddlePaddle传入infer_3.png图片,...

  • 浅谈对“社群”简析

    打开手机发现身边的朋友圈都在讨论一个词语【社群】,这个词语在一夜之间影响着人与人之间的关系。我就举下身边比较有名的...

  • FMDB使用简析

    之前项目中要求使用本地数据库,按照惯例自己封装了一个数据库操作,结果发现虽然成功了但是非常麻烦,于是想到了使用第三...

  • WKWebView使用简析

    一、WKWebview的初始化 首先来一段常用的初始化webview的代码 1. 创建webView最重要的参数c...

  • BottomNavigationBar使用简析

    一,基本使用 布局代码:

网友评论

  • e2cd15586a06:楼主,不知道使用infer扫描ios代码时能不能设置忽略一些文件或者忽略一些类型的infer扫描错误(比如:扫描空指针问题)?
  • 76028afbd5bb:你好,你用Infer分析过java代码吗。我觉得Infer找到的空指针异常并不是很全,一些潜在的空指针Infer不能发现。难道有什么参数能控制输出结果的级别吗?
    e2cd15586a06:楼主,不知道使用infer扫描ios代码时能不能设置忽略一些文件或者忽略一些类型的infer扫描错误(比如:扫描空指针问题)?
    卡卡西桑:3:分解分析,整合输出结果。(infer能将代码分解,小范围分析后再将结果整合在一起,兼顾分析的深度和速度)
    Nlinger:@陈之歌 我没有分析过java呢,针对移动端也有更好的工具,这个的操作略麻烦
  • dbb76d231298:hi ,Nlinger ,我在使用infer的时候,同样出现了‘AttributeError: 'NoneType' object has no attribute 'encode'’的错误,我确定是在工程目录下,并且代码没有问题,请问,这种情况,应该怎么解决呢?谢谢!
  • 灿烂先森:赞👍!
  • HenryCheng:先马后看 :smile:
    HenryCheng:@Nlinger 这半夜还不睡😥😥😥
    Nlinger:@HenryCheng 一起沟通学习
    Nlinger:@HenryCheng 一起沟通学习

本文标题:infer使用的浅谈简析

本文链接:https://www.haomeiwen.com/subject/xcfdlttx.html