史上第一款AOSP开发的IDE (支持Java/Kotlin/C++/Jni/Native/Shell/Python)

本文主要是介绍史上第一款AOSP开发的IDE (支持Java/Kotlin/C++/Jni/Native/Shell/Python),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ASFP Study

史上第一款AOSP开发的IDE (支持Java/Kotlin/C++/Jni/Native/Shell/Python)

类似于Android Studio,可用于开发Android系统源码。

Android studio for platform,简称asfp(爱上富婆)。

背景&下载&使用

背景

由于Android系统源码过于庞大,比如Android14源代码就有400G了。

做AOSP开发的小伙伴都经常受困于改代码的工具,此前主流的IDE主要有:

  1. 通过idgen 生成对应的android.ipr和android.iml文件,然后用Android Studio加载整个源码。

    弊端很明显,文件权限问题,很消耗资源,很卡,没法编译,Gradle定时作妖

  2. 通过AIDEGen给对应的模块编译,然后使用Idea加载,具有跳转和补全的作用。

    使用复杂繁琐,没法编译,貌似也不支持kt

  3. 用Eclipse加载源码模块,倒入framework.jar等库。

    UI跟不上时代,使用困难

  4. 使用Source Insight/Visual Code/Sublime的工具进行裸开发,借助其他IDE完成部分语法校验和补全工作。

    没有补全功能,优点是不那么吃系统资源

基本情况

现在google官方推出了系统开发专用版本Android Studio for Platform,应该能解决大部分安卓系统开发从业者的烦恼。

先说一下大体情况:

  • 优点:

    • 可以加载你关注的几个模块,支持单独编译,有自己的Soong build system。
    • 支持多款语言的跳转/补全/派生关系。
    • 支持灵活的文本搜索,文件搜索,灵活配置,JetBrain家族的特性,很熟悉的味道。
    • 支持单点调试,但是必须base官方源码和官方镜像
  • 缺点:

    • 目前仅支持Linux系统,可以在Ubuntu下使用
    • 对电脑配置要求也有点高
    • 对于JNI C++的跳转还有说欠缺

Let’s get started!

下载

https://developer.android.com/studio/platform?hl=zh-cn

image-20231108224251683

image-20231108224330263

目前只支持Ubuntu,会自动识别操作系统类型,如果非Ubuntu会显示不可用。

以我的理解,以后也不会支持Windows,搞android系统开发的都懂。

如果你不方便下载资源,我已经上传到

网盘:

百度网盘:

链接:https://pan.baidu.com/s/1g82vNLN2jFH3dWrS2gY_Pg?pwd=asfp 
提取码:asfp

CSDN下载:

https://download.csdn.net/download/dengtonglong/88516673

image-20231023120651551

入门

google官方教学视频教程地址: https://www.bilibili.com/video/BV1U

  1. 如果您尚未安装 Repo,请按照安装 Repo 中的说明操作。

    关于repo,想了解深入一些,可以参考这篇文章:

    https://blog.csdn.net/dengtonglong/article/details/133365006?spm=1001.2014.3001.5502

  2. 如果您尚未初始化并同步 Repo 检出分支,请按照初始化 Repo 客户端中的说明操作。

    现在大部分android源码项目都是通过repo来管理,也是官方推荐的方式。

  3. 下载 ASfP到Ubuntu。

  4. 安装 ASfP:

    sudo dpkg -i /path/to/asfp-2023.1.1.19-linux.deb

  5. 安装完asfp后,默认在这个目录下:

    /opt/android-studio-for-platform/bin/studio.sh

    也可以制作桌面图标:

    [Desktop Entry]
    Version=1.0
    Encoding=UTF-8
    Name=Android Studio
    Exec=/opt/android-studio-for-platform/bin/studio.sh
    TryExec=/opt/android-studio-for-platform/bin/studio.sh
    Comment=Android Studio For Platform
    Terminal=false
    Categories=Qt;Development;
    Icon=/opt/android-studio-for-platform/bin/studio.png
    Type=Application
    

    image-20231108165501869

    也可以将这个安装目录,mv到你常用的目录。

  6. 通过以下方式导入项目:

    可以选择主题风格:

    image-20231107182239873

    image-20231107182536908

    指向您的 Repo 检出目录

    指定 lunch 目标

    然后选择要构建的模块

    image-20231107183116309

  7. 点击完成,您的项目将开始同步。

  8. 像新建工程,ide设置,添加模块、依赖,配置文件,存储路径这些,是和JetBrain其他软件一样的操作,甚至快捷键都一样,熟悉的配方。

    用惯了Android Studio的人,应该对工程师来讲,这个不陌生。

编译

第一次加入项目,会自动编译,由于我加入的代码包含一些定制化,还有test目录经常出问题,编译到了99%,大体也算完成了。

本质上编译指令是:

Syncing targets: [frameworks/base]Preparing for sync...
Updating MAX_ARG_STRLEN to 131072Generating Soong artifacts...
/bin/bash -c "source build/envsetup.sh && lunch xxxx-userdebug && echo ANDROID_PRODUCT_OUT=$ANDROID_PRODUCT_OUT && refreshmod"
including device/mediatek/build/vendorsetup.sh

refreshmod应该很强大!

image-20231108092959039

编译完,会生成各种项目配置iml文件

dependencies.iml

依赖的配置目录

frameworks.base.iml

源代码的配置目录

frameworks.base-gen.iml

源代码产生的文件的目录

image-20231108102839175

编译之后,会生成各种中间版本的jar,

这些classes.jar其实和平时编译生成在out目录下的是一样的。

image-20231108172411187

frameworks.base.core生成的classes.jar

  • core-android-libraries

所有dependencies的classes.jar

  • dependencies-jars

frameworks.base生成的classes.jar

  • frameworks.base-jars

虽然说ASFP支持soong编译,但不咋好用,是项目实践中,还是建议用m/mm/mmm编译调试!

配置

项目配置位置:

image-20231108103909927

image-20231108104925002

体验特性

特性是可以提供便利的

Java Kotlin跳转 补全 派生关系

  • 支持java跳转 补全 派生关系

    查看哪些地方调用了:

    image-20231108093617436

  • 支持kotlin跳转 补全 派生关系

    image-20231108104033476

  • 支持java和kotlin相互跳转

    可自行尝试。

  • scratch功能

当写android源码,比如一些复杂的计算,字符串处理,一些数据处理的算法,需要通过java代码或kt代码验证它的语法和运行。

这个时候,scratch功能就非常有用了。

点击创建scratch

image-20231108174349402

创建一个scratch类

image-20231108100426729

点击绿色箭头,直接运行:

image-20231108100518523

运行成功!

image-20231108100624168

JNI跳转

我以com/android/server/alarm/AlarmManagerService.java为例,

发现setKernelTime这个native方法并不能跳转到对应的jni方法,这个有点违背某些博客大V的说法。

image-20231108100130378

替换的方法,可以用ctrl+shift+R查找

image-20231108100101965

Native语言支持

在Native环境,可以进行补全,这个已经非常好了,帮我们解决了写native代码的一大困扰:

image-20231108113459863

C/C++语言支持

添加servicemanager模块,貌似很多红色报点,我觉得C和C++份依赖于整个环境,缺这缺那的,不可能跑的通的。

所以提示 需要加入对应的环境,如果是专职作内核开发的小伙伴,可以尝试调通。

image-20231108105127375

image-20231108095757328

但是支持代码补全,这个已经非常好了。

image-20231108175204604

所以建议大量开发C C++代码,建议转战clion。

image-20231108105149878

C++也支持scratch

image-20231108105332754

image-20231108105450772

可以试验C++代码运行的语法和可行性。

Python语言支持

image-20231108174759835

image-20231108175826022

安装python的插件即可。

Shell语言支持

直接点击绿色箭头即可运行,本质上用的是bash运行的。

image-20231108114344688

mk/bp支持

不支持这两个语法,但是检测到修改,会提示让你重编。

image-20231108114842773

单点调试体验

理论上,单点调试的环境要求比较严格,需要用官方代码+官方镜像;

我尝试在我本地代码上调试,最后失败告终。

image-20231108094500252

image-20231108094522417

image-20231108094635353

image-20231108094730166

image-20231108095114798

出现“debug info can be unavailable”的错误,需要关闭运行的AS。

image-20231108095546936

image-20231108095735584

最后都没办法成功单点调试,以后有机会再实验吧!

体验小结

简要给出我个人的使用体验,并不代表官方。

跳转补全关系
javaYYY
ktYYY
C/C++NYN
JNI/NativeNYN
PythonYYY
ShellYYN/A
mk/bpNNN
  • 非常适合做Framework开发的小伙伴,也就是手机厂中的系统组
  • 如果公司有自己的组件,加入到其中,也是可以兼容,实现跳转和补全
  • 希望加强C C++ native的开发体验,也许是可以调好的,如果专职作某块的开发,肯定可以把linux C那套集成
  • 建议再观望观望,等更加稳定的版本出来!

这篇关于史上第一款AOSP开发的IDE (支持Java/Kotlin/C++/Jni/Native/Shell/Python)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/383179

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD