[关闭]
@qidiandasheng 2022-08-23T09:30:23.000000Z 字数 3712 阅读 5203

关于iOS里的警告(❎)

iOS调试&工具


前言

一个好的程序猿,会重视他写的每一行代码,看到警告会去思考为什么,会去尽量的消除警告,消除警告是代码洁癖必不可少的一项。所以对于iOS开发者来说了解警告的类型,并开启必要的警告是必须的。下面是Build Setting里关于warning的配置选项。

Apple LLVM 8.0 - Warning Policies

这是关于所有warning的策略,分为以下三个点:

禁止所有的Warnings

Inhibit All Warnings表示是否禁止所有的Warnings,默认为NO。如果设置为YES,那你就不会得到任何警告提示了。

迂腐的Warnings

Pedantic Warnings这个主要跟C和C++的标准有关,Pedantic意思是迂腐的,也就是说那些没有严格按照ISO CISO C++标准的代码是否显示。默认为NO,也就是不提示。

将警告等于错误

Treat Warnings as Errors,一种很常见的做法和代码洁癖是将警告标识为错误,从而中断编译过程。这让开发者不得不去修复这些警告,从而保持代码干净整洁。这个选项默认是NO,设置为YES,就会将警告等于错误。有时候我们在开发时不想被一些简单的warning给打断,那么可以先设置Debug为NO,Release为YES,在build release时就可以发现这些warning了。

我们也可以在Other C Flags里加入-Werror标识将警告等于错误。

如果要将某一类警告等于错误可以这样写-Werror=...。示例如下:


设置-Werror=unused-function之后表示只有unused-function警告等于错误。

也可以在-Werror被激活时使用-Wno-error=...来使某些警告不成为错误。示例如下:


设置-Werror-Wno-error=unused-function之后表示除unused-function之外的所有警告都等于错误。

Build Setting里的警告选项

Xcode的工程模板已经为我们设置开启了一些默认和常用的警告提示,但是这些警告有时候是不够的,你需要开启更多的警告类型来找到你代码中不合理的地方。

主要分为以下几大块:
Apple LLVM 8.0 - Warning - All languages
Apple LLVM 8.0 - Warning - C++
Apple LLVM 8.0 - Warning - Objective C
Apple LLVM 8.0 - Warning - Objective C and ARC

在上面这些大块下面都有对应warning的配置选项。如下图是跟All languages相关的一些warning,我们能看到之前例子里的两种类型的warning设置为YES,表示这两种类型的warning是提示的。

Other C Flags

我们上面有提到在Other C Flags中加入-Werror-Wno-error=...-Werror=...,来实现类似于Treat Warnings as Errors选项的效果及更强大的扩展。

其实我们也可以在Other C Flags加入特别的标识来达到Build Setting里设置对应警告选项BOOL值的效果。

Other C Flags里设置的优先级是大于某一个具体配置的。如在Apple LLVM 8.0 - Warning - All languages中的选项Unused Variable设置为YES,那么就表示这种类型的warning是会提示的。但是我在Other C Flags中加入-Wno-unused-variable,表示这种类型的warning是不提示的。
那么最后以Other C Flags中的设置为准,也就是不会提示这种类型的warning

Other C Flags中具有以下几种标记类型:

将警告等于错误相关

这部分上面已经提到过,包括-Werror-Wno-error=...-Werror=...

打开或关闭某些警告

-W...开启某些警告,如-Wunused-variable-Wno-...关闭某些警告,如-Wno-unused-variable

打开某一警告组

查看警告类型的标识名

如果知道对应类型的warning的标识名是什么?

可以先查看左侧的warning提示,如下图中就是unused-variableunused-function两种警告的标识。

或者查看GCC的手册,里面会列出很多标识,基本上跟warning提示对比下应该就能找出来了。

控制警告,局部加入或关闭

Clang提供了我们自己加入警告或者暂时关闭警告的办法。

加入警告

强制加入一个警告:

  1. //Generate a warning
  2. #pragma message "Warning 1"
  3. //Another way to generate a warning
  4. #warning "Warning 2"

两种强制警告的方法在视觉效果上结果是一样的,但是警告类型略有不同,一个是-W#pragma-messages,另一个是-W#warnings。对于第二种写法,把warning换成error,可以强制使编译失败。比如在发布一些需要API Key之类的类库时,可以使用这个方法来提示别的开发者别忘了输入必要的信息。

  1. //Generate an error to fail the build.
  2. #error "Something wrong"

关闭警告

警告类型列表

这里我整理了一篇专门收集警告:iOS警告类型,以供参考。

相关问题

pod里的警告没有提示

需要在Edit Scheme->Build里加入对应pod的target,才能显示那个pod里的警告。

警告开启建议

个人喜好(代码洁癖)不同,会有不同的需求。我的建议是对于所有项目,特别是新开的项目,首先开启-Wall-Wextra,然后在此基础上构建项目并且避免一切警告。如果在开发过程中遇到了某些确实无法解决或者确信自己的做法是正确的话(其实这种情况,你的做法一般即使不是错误的,也会是不那么正确的),可以有选择性地关闭某些警告。一般来说,关闭的警告项目不应该超过一只手能数出来的数字,否则一定哪儿出问题了.

关闭的warning需要列出文档以供开发人员参考,知道哪些warning关闭了。包括全局关闭、相应文件关闭、在某几行关闭某个警告等。

参考

谈谈Objective-C的警告
清除Masonry中的警告

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注