1.字节码插桩(四): AST
2.Android代码静态检查(lint、Checkstyle、ktlint、Detekt)
3.AS自带的 检测工具Lint
4.android.annotation.SuppressLint 导å
¥ä»ä¹å
ï¼
字节码插桩(四): AST
在Android开发过程中,通过AndroidStudio生成Bean对象通常借助注解自动生成getter/setter方法、equals()和hashCode()方法,reentrylock源码遵循驼式命名规则,确保类(或接口)名称首字母大写,方法名称首字母小写,类或实例变量同样遵循驼式命名法,首字母小写,常量全部由大写字母或下划线构成,且首字符不能是下划线。那么,编译器如何解析这些不规范的命名方式呢?这里涉及到一个关键的字节码插桩技术——AST(Abstract Syntax Tree)。
AST(Abstract Syntax Tree)是编译器对源代码进行初步加工后得到的结果,是一个树形结构表示的源代码。在Java编译过程中,编译流程大致分为三个阶段:第一阶段解析源文件为语法树;第二阶段调用注解处理器(APT模块),处理生成的SOBer指标的源码新源文件;第三阶段将语法树转换为类文件。利用操作AST可以实现修改源代码的功能。
在代码实现层面,APT(Annotation Processing Tool)与AST结合使用,允许在编译期进行代码生成、代码检查或代码转换。AST操作属于编译器级别,对程序运行没有影响,效率相对其他AOP(Aspect-Oriented Programming)技术更高。
AST操作常见API包括但不限于:访问节点类型、获取节点子节点、设置节点属性等。在Android开发中,AST的应用场景广泛,特别是在代码规范检查方面。例如,Android Lint是一个静态代码检查工具,其内部已经封装了AST,用于扫描和检查Android工程代码,发现潜在问题,乐檬4.5源码提醒程序员及时修正,提高代码质量。
在开发Linter工具时,需求包括禁止日志输出、使用Toast、资源文件命名规范、避免自建线程等。开发步骤涉及创建Java工程、配置Gradle、创建Detector(负责扫描代码发现问题并报告)、实现Id类型检查、检查message.obtain()调用、避免创建Thread、序列化内部类检查、禁用系统Log/System.out日志等。
通过自定义IssueRegistry提供需要被检测的Issue列表,声明Lint-Registry属性并在build.gradle中声明,完成自定义Lint编码部分。利用AST,易货源码PHP开发者可以有效地实现代码规范检查,提高代码质量,降低潜在错误,提升开发效率。
综上所述,AST在Android开发中扮演着重要角色,不仅能够辅助编译器完成解析任务,还能在代码编写阶段进行静态分析,帮助开发者遵守代码规范,提升代码质量。利用AST结合Linter工具,可以有效地提高开发效率,降低维护成本,确保代码的健壮性和可维护性。
Android代码静态检查(lint、Checkstyle、ktlint、Detekt)
在Android项目开发中,静态代码检查工具如lint、登录页面源码 科技Checkstyle、ktlint和Detekt扮演着关键角色。它们通过在编译阶段自动检测代码缺陷,节省时间和资源,提升软件质量与可靠性,节省了开发和测试成本。Android项目主要使用Kotlin和Java,因此这些工具都需兼容这两种语言。
Lint是Android Studio内置的工具,它能检测+种潜在问题,覆盖Manifest、XML、Java、Kotlin等文件类型,通过LOMBOK-AST、PSI和UAST分析器进行深度分析。在build.gradle中添加相应配置后,执行lint命令,可在build/reports/lint/lint.html中查看详细结果。
CheckStyle专用于Java代码的编码规范检查,是Gradle的内置插件,它对比源码与编码约定,以HTML或XML格式显示结果。尽管自带+规则,但不支持自定义规则。在build.gradle中配置后,preBuild阶段会执行CheckStyle检查。
对于Kotlin的代码检查,Detekt和ktlint是两个选择。Detekt支持规则定制,输出HTML格式,阅读体验较好,而ktlint规则不可定制。两者可通过命令行结合Git钩子进行代码提交前的检查。
尽管团队和项目的代码规范各异,但静态代码检查工具在确保代码质量、发现性能问题和隐藏bug方面必不可少。对于高质量项目,使用这些工具是提升开发效率和软件质量的重要手段。
AS自带的 检测工具Lint
Lint 是 Android Studio 自带的代码扫描分析工具,旨在帮助开发者发现并解决代码结构和质量问题,提供解决方案,而无需编写测试用例。Lint 提供的问题描述和严重等级类似于测试中发现的 bug,便于定位并按优先级进行解决。开发者可以根据需要调整严重程度标准,确保原则问题得到严格处理。
Lint 的工作方式是检查 Android 项目的源文件,如 Java 代码、XML 代码、图标以及 ProGuard 配置文件等,以发现潜在的 bug 或优化点。优化内容包括但不限于无障碍性、正确性、国际化、性能和安全性等方面。
Android Studio 内置了 Lint 工具,使用方法为工具栏中的“Analyze”选项,然后点击“Inspect Code”。在弹出的菜单中,可以选择项目、模块或特定文件进行检查。此外,还可以通过自定义范围选择特定类进行检查。
为了自定义 Lint 的检查规则,打开“Preferences/Settings”并搜索“Inspections”。在检测配置页面中,可以修改拼写警告等级,通过搜索“spelling”找到并调整“Typo”的严重程度,将其设置为“Error”以在拼写不规范时报告错误。
Lint 提供了多种警告严重程度级别,包括“Unused Entry”、“Typo”、“Server Problem”、“Info”、“Weak Warning”和“Error”。开发者可以根据需要选择合适的严重程度,以突出显示需要优先解决的问题。
在 Java 代码中,可以使用注解 `@SuppressLint("警告名称")` 来忽略特定的 Lint 警告。例如,忽略对新 API 的警告,可以使用 `@SuppressLint("UseNewApi")`。在 XML 文件中,通过声明 `tools:ignore="警告名"` 可以忽略 Lint 警告。在 Gradle 的 `build.gradle` 文件中,通过添加 `lintOptions{ ...}` 来配置 Lint 的操作,包括开启或关闭警告。
为了自动删除项目中查找出来的无用资源文件,开发者可以使用 Lint 工具。在 Android Studio 工具栏中选择“Analyze”并输入“Run Inspection By Name..”来启动检查。输入“无用资源”并选择相应的范围后,系统将自动检测并提示移除无用资源。点击“Remove All Unused Resources”即可自动删除这些资源。
在日常开发中,开发者经常需要处理的 Lint 相关问题包括但不限于代码结构优化、拼写错误、资源重复或未使用、性能瓶颈、安全风险等。通过定期使用 Lint 工具进行代码扫描,开发者可以持续提高代码质量,确保应用程序的稳定性和用户体验。
android.annotation.SuppressLint å¯¼å ¥ä»ä¹å ï¼
å³å» android 项ç®ï¼ä¹åå¨å¼¹åºçèåä¸ç Android Tools éé¢æ¯ä¸ªé½ç¹ä¸ä¸ï¼å¯è½æ¯ä¸ä¸ª add support package æ fix project properties æ android lint ç¸å ³ç设置ã
Lint åªæ¯ä¸ä¸ªä»£ç æ£æ¥çåè½ï¼å°±å unix/linux ä¸ç C/C++ ç¼ç¨å·¥å ·çåè½ä¸æ ·ï¼ä½ å ¶å®å¯è½å®å ¨å°æå®ä»¬ä»ä»£ç ä¸å»æï¼è¿ä¸ªä» ä» æ¯ç»ç¼è¯å¨ä½¿ç¨çï¼å¹¶ä¸å½±ååæ¥ä»£ç çåè½ã