Android源码浅析(四)——我在Android开发中常用到的adb命令,Linux命令,源码编译命令


我自己平时开发的时候积累的一些命令,希望对你有所帮助

adb是什么?:

adb的全称为Android Debug Bridge,就是起到调试桥的作用。通过adb我们可以在IDE中调试Android程序,说白了就是debug工具。adb的工作方式比较特殊,采用监听Socket TCP 5554等端口的方式让IDE和Qemu通讯,默认情况下adb会daemon相关的网络端口,所以当我们运行Android Studio时adb进程就会自动运行。

adb环境

在我们的sdk目录androidSdk\platform-tools下可以直接使用我们的adb

这里写图片描述

但是如果你想像JDK一样可以全局使用,那就得配置一下adb的环境了,不然会爆adb找不到的错误,配置环境很简单,把我们的路径加入到我们的PATH路径下就好了,不会的可以搜索

Log

如果只是纯应用开发的话,用到的log应该是比较多的,你输入

logcat

就会和你的IDE一样在刷log了,如果你想过滤,其实也好办

logcat -s TAG

有时候程序突然挂了,而我的IDE也没什么东西,可能抽风了,那怎么办?输入

logcat -s "AndroidRuntime" 

如果你的log太多,想保存下来分析的话,你也可以这样

 logcat > c:\XX.txt

adb shell

shell下能做很多的事情,常用的是我们Linux命令,我们先来看几个简单的命令吧

su

su是获取权限的意思,这样就有权限查看系统文件了

cat

如果你想查看文本或者其他文本类,比如.java等文件就可以直接cat xxx.txt了,嗯,这些都比较简单,我们想看一下连接的设备可以

adb devices

这里写图片描述

有设备了,我想安装一个apk,那就很简单咯

adb install c:\\xxx.apk

如果卸载呢?卸载有很多种方式哈,你删掉也是其中一种,先说下正常卸载,那也是你安装的应用才能卸载,系统的应用是不让卸载的,卸载可以用

adb uninstall 包名

如果你想删掉一个系统文件,你会怎么做?首先进入system/app目录下对吧,然后输入

rm -rf xxx.apk

但是,你会看到这样的一个提示

这里写图片描述

什么?只读文件?我明明已经是#的root管理权限了啊,那我应该怎么做呢?

adb root

首选我们获取一下root,然后

adb remount

切换一下remount模式,这样我们就可以删掉了,那好,问题来了,我们如何用命令启动一个Activity或者一个Servie呢?

首先看下启动Activity,假设我现在有一个程序的包名是com.lgl.test,而我想启动这个MainActivity,服务就是MainService那应该怎么写?首先你得进入shell模式,然后

am start -n com.lgl.test/.MainActivity

启动服务的话

am startservice -n com.lgl.test/.MainService

到这里,一些简单的应该是没什么问题的了

Linux

在shell模式下,你可以看一些权限

ls -l

你可以看到一行有两个root,他们是什么意思呢》左边的是用户组,右边的是用户群组,这个可是在源码编译中有些注意的哟

这里写图片描述

但是你如果在linux中

这里写图片描述

你可以看到不管是用户组还是用户群组都是我是用户名,再实际开发中,肯定是我们的文件拥有的权限要大一些,那这些怎么改呢?

左边的可以这么改

sudo chown -R 用户名 文件名

右边

sudo chown -R root:用户名 文件名

这里刚好说到权限的问题,如果你想要一个权限是可读可写的话,你可以这样设置

sudo chmod 777 文件

还有一些简单的,我就直接贴出来

//移动
mv 
//复制
cp
//重启
reboot
//我们想重启也可以adb reboot
//创建文件
mkdir
//压缩
tar

这些都是比较常见的了,我们怎么这么快就扯到了Linux?我们的adb还有很多命令没说呢,再来看下我们的的push和pull

想取的系统的文件的文件的话,就需要pull了

  adb pull /system/app/phone.apk c:\\

这里我就把这个apk放在了c盘,如果你想把一些文件给塞进去系统,你可以

adb push c:\\phone.apk /system/app/

对了,ls是我们的清单,显示当前目录的文件夹,在Dos下是dir,如果我想在一个目录项回退到上一个目录,可以

cd ..

这里写图片描述

如果想回退到上上个目录,可以

cd ../..

这里写图片描述

如果你蛋疼的想回到上上上个目录,那就以此类推了

cd ../../..

好的,我们再来看下剩下的adb命令

adb命令

这部分我也不是很常用

    1. 显示系统中全部Android平台:
  android list targets
  • 2.显示系统中全部AVD(模拟器)
android list avd
  • 3.创建AVD(模拟器)
android create avd --name 名称 --target 平台编号
  • 4.启动模拟器
 emulator -avd 名称 -sdcard ~/名称.img (-skin 1280x800)

  • 5.删除AVD(模拟器)
android delete avd --name 名称
  • 6.启动DDMS
 ddms
  • 7.模拟按键
input keyevent 5

这些就差不多了,有些不行的话,可以尝试在shell模式下进行

编译命令

编译源码的命令大家按照流程走下去应该就可以了,首先熟悉一下linux命令,先从下载源码开始吧

repo init xxx

初始化一下你的空间,这个一般就是闭门服务器的地址,然后同步

repo sync

同步完之后一般有u-boot会先编译u-boot

cd u-boot/
make 产品代码
make

这里三个命令,然后编译完成之后,就有一个uboot.img的镜像了,然后编译内核(Kernel)

cd kernel/
make 产品名

这里每家的芯片都不一样哈,详见编译文档,编译之后我们回到主页面

make -j8

如果想保存日志文件

repo sync > 123.txt

make是编译,后面带的参数是什么呢?是启动的核数,这个你可以根据自己的电脑配置来,编译完成之后

source build/envsetup.sh 
lunch

你可以输入lunch选择你要编译的类型

这里写图片描述

最后执行一下

./mkimage.sh 

就可以生成固件了

m mm mmm

关于这三个的差别,其实就是

  • m : 编译全部
  • mm : 编译当前模块
  • mmm : 编译指定路径

上述有些可能不对称,平台之间还是有些差异性的

monkey

我们调试的时候需要用到monkey 的话可以执行

//对应用做压力测试1W次
monkey -p 包名 --pct-syskeys 0  -v 100000  
//对整个系统进行压力测试1000W次
monkey  --pct-syskeys 0  -v 10000000  

大体的应该是这些常用的吧,如果有后续的话会继续补充,欢迎各位评论

我的群:555974449欢迎一起来玩耍一下
Logo

更多推荐