Android手机软重启adb命令是什么

Android手机软重启adb命令是什么,第1张

运行设备的shell(命令行)。

管理模拟器或设备的端口映射。

计算机和设备之间上传/下载文件。

将本地apk软件安装至模拟器或android设备。

ADB一个 客户端-服务器端 程序, 其中客户端是用来 *** 作的电脑,服务器端是android设备。

扩展资料

1、 查看设备 *adbdevices。这个卜槐命令是查看当前连接的设备, 连接到计算机的android设备或者模拟器将会列出显示。

2、 安装软件:adbinstall <apk文件路径>。

这个命令将指定的apk文件安装到设备上。

3、 卸载软件型态友

adbuninstall <软件名>。

adbuninstall -k <软件闭粗名>。

如果加 -k 参数,为卸载软件但是保留配置和缓存文件。

参考资料来源:百度百科-ADB

做过安卓开发的朋友或多或少都遇到过让人厌恶的类似于“could not read ok from ADB Server”的错误。产生这个错误的原因可能多种多样,每次遇到问题的时候,可能大部分人都和我一样,去google一下这个问题别人是如何解决的。假设一下子找到解决了,就放过,下次在遇到的时候同样的再去google一下就好了。但是,这样不是正确的治学态度,为此孔祥子决定去扒一扒!

如下,是我在发现Android studio连接不上手机的时候,尝试去启动一个adb server,但是失败了。

<pre>

根据问题提示,5037端口被占用了。下面就来看看到底是哪一个端口被占用。

<pre>

C:\Users\zxy>netstat -ano | findstr "5037"

TCP127.0.0.1:5037 0.0.0.0:0 LISTENING 7912

TCP127.0.0.1:5037 127.0.0.1:50025ESTABLISHED 7912

TCP127.0.0.1:5037 127.0.0.1:56501ESTABLISHED 7912

TCP127.0.0.1:50025127.0.0.1:5037 ESTABLISHED 7120

TCP127.0.0.1:56501127.0.0.1:5037 ESTABLISHED 1264

</pre>

果然,5037被进程id为7912的进程占用扒敏了。顺藤摸瓜,看看到底什么进程捣的鬼,

<pre>

C:\Users\zxy>tasklist | findstr "7912"

romaster_daemon.exe 7912 Console1 3,024 K

</pre>

看到了吗,是此此轿这个进程romaster_daemon.exe ,好了,到此为止找出来是哪一个程序了,下面打开任务管理器,kill掉就可以了。

Android adb(Android Debug Bridge) 是一个通用命令行工具,其允许您与模拟器实例或连接的 Android 设备进行通信。它可为各种设备 *** 作提供便利,如安装和调试应用,并提供对 Unix shell(可用来在模拟器或连接的设备上运行各种命令)的访问。

该工具作为一个客户端-服务器程序,包括三个组件:

客户端(adb client) ,该组件发送命令。客户端在开发计算机上运行。可以通过发出 adb 命令从命令行终端调用客户端。

这里说的客户端,其实包含很广泛。例如我们在命令行窗口运行一个adb命令,其实就是一个adb客户端。还有,我们在android studio中通过点击运行或者调试按钮,app就安装到手机里面了,这个也可以看做是adb客户端。对应的后台进程名称 根据运行的程序的不同而不同。

后台程序 ,该组件在设备上运行命令。后台程序在每个模拟器或设备实例上作为后台进程运行。

也就说,开发者测试手机或者模拟器上运行的后台进程,负责接收命令,并运行命令。这个名字对应应该是adbd

具体如下

服务端森肆 ,该组件管理客户端和后台程序之间的通信。服务器在开发计算机上作为后台进程运行。

您可以在 android_sdk/platform-tools/ 中找到 adb 工具

这个是在开发者自己的电脑上,运行的旨在管理adb客户端和手机端的后台程序通信的一个管理程序。

具体流程如下

启动一个 adb 客户端时,此客户端首先检查是否有已运行的 adb 服务器进程。如果没有,它将启动服务器进程。当服务器启动时,它与本地 TCP 端口 5037 绑定,并侦听从 adb 客户端发送的命令—所有 adb 客户端均使用端口 5037 与 adb 服务器通信。

然后,服务器设置与所有运行的模拟器/设备实例的连接。它通过扫描 5555 到 5585 之间(模拟器/设备使用的范围)的奇数号端口查找模拟器/设备实例。服务器一旦发现 adb 后台程序,它将设置与该端口的连接。请注意,每个模拟器/设备实例将获取一对按顺序排列的端口 , 这些端口包括用于控制台连接的偶数号端口和用于 adb 连接的奇数号端口。例如:

模拟器 1,控制台:5554

模拟器 1,adb:5555

模拟器 2,控制台:5556

模拟器 2,adb:5557

以此类推...

如上所示,在端口 5555 与 adb 连接的模拟器实例与侦听端口 5554 的控制台的实例相同。

注意 ,这里所说的端口都是开发者电脑上的端口。

我的理解,偶数端口用来实际的数据传输。奇数端口用来发送控制命令和连接用的,例如调试。(如果不正确请指出)

当服务器已设置与所有模拟器实例的连接后,您可以使用 adb 命令访问这些实例。由于服务器管理与模拟器/设备实例的连接,并处理来自多个 adb 客户端的命令,因此,您可以从任意客户端(或从某个脚本)控制任意模拟器/设备实例。

解读一下

注意:上图中的标识为黄色的区域的进程为后台守护进程。

Adb Server运行在开发者电脑上,任何adb client都要等待这个运行起来之后才能做后续的工作。电脑上的android studio或者eclipse等一些adb client和它交互。一旦adb client的命令被发送到手机中,并且被手机中的adbd接收之后,才能和手机交互。

然后在看一张更详细的图

这个图,详细的解释了我运行adb命令中的详细细节。

关于adb的详细命令可以参考: http://adbshell.com/commands 这个网站详。

看了之后,对于前面的5037被占用,导致无法连接手机的原因,我想,我们应该有了更深层次的理解。同时对于其他情况的不能连接手机,我们下次就会有了自己的思考了。

在Mac 下配置Android SDK的adb命令添加到环境变量:

1. 检查 .bash_profile

使用 vim .bash_profile 打开该文件,如果该文件存在则直接进入如下第二个步骤,如果该文件不存在,可通过下面命令创建.bash_profile:

touch .bash_profile

2. 编辑 .bash_profile

打开.bash_profile文件,进行编辑,命令如下:

vim .bash_profile

添加如下内容, 以下数明是我的sdk的路径,具体路径根据自己sdk路径稍作改动即可;

3. 保存 .bash_profile

esc 键后退,然后输入 :wq 后保存退出;

4. 更新配置

source .bash_profile

(1) 查看当前显示的activity的名字**

(2) 查看前台Activity

(3). 查看前台Activity的栈信息

结果如下:

在没有root的手机里想adb pull出里面的东西可以先用这颤毕档个命令搜出位置,然后在pull出来

将apk后缀改成zip, 然后解压,

Ctrl + C 停止录屏

配茄乱置fastboot命令环境变量

fastboot刷机步骤:

持续更新...


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12548187.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-26
下一篇 2023-05-26

发表评论

登录后才能评论

评论列表(0条)

保存