我再也不能通过命令行或Eclipse使用ADB连接到我的设备了。

执行命令

adb devices

返回设备名称,但显示为脱机状态。

我尝试过的事情。

切换Android调试模式 重新安装谷歌USB驱动 将操作系统恢复到以前工作的备份(CyanogenMod) 换掉USB数据线 多次重启电话/电脑 更新Android SDK

我真的不知道发生了什么。你觉得我还能试什么,我洗耳恭听。

需要明确的是,如果你遇到了同样的问题,那么问题可能是SDK过时了。从4.2.2开始,有一个安全特性需要您确认连接设备的RSA指纹。打开SDK管理器并更新工具!然后重新启动。


当前回答

对我来说,我有两个不同的SDK安装。当我启动Android SDK管理器并从Eclipse更新工具时,SDK路径指向一个位置,但命令行上使用的path环境变量指向另一个位置,该位置具有较旧版本的SDK,始终将4.2.2设备显示为脱机。

其他回答

我尝试了上面所有的解决方案。大多数情况下,adb kill-server可以解决这个问题。这次问题出在USB线上。包装花哨的劣质电缆是行不通的。

多个adb.exe文件?

当从C:/Windows/删除OLD adb.exe副本时,我的问题得到了解决。 我不知道adb.exe是如何拷贝到C:\Windows\ ?

当我从android-sdk/platform-tools/启动adb.exe时,我没有检测问题。

当我面对同样的问题时,我会像下面这样做:

通过在命令提示符中发出adb kill-server命令和adb start-server命令重新启动adb 关闭并重新打开USB调试 重启手机,如果它仍然不工作。 通过这些步骤,99%的问题都得到了解决。

下面是您可以通过命令行执行的步骤。无需访问设备。

步骤1:执行“adb devices -l”,您将看到离线设备。现在记下usb后面的数字:Example=> usb:1-1.4.2

步骤2:echo '1-1.4.2' |sudo tee /sys/bus/usb/drivers/usb/unbind

步骤3:echo '1-1.4.2' |sudo tee /sys/bus/usb/drivers/usb/bind

步骤4:检查“adb devices -l”。这些设备应该在线。

设备报告离线的原因是adb无法连接到该设备。来自开发环境的Adb可执行文件与受控设备创建连接(套接字)。设备有一个侦听此通信的服务(守护进程)。守护进程被称为adbd(在adbdaemon中)。 当在设备上启用adb时,实际上就启动了这个守护进程,因此可以与设备建立通信。

当设备被adb报告为离线时,是因为守护进程不再运行或处于不接受连接的状态。大多数情况下,如果网络在活动(网络)连接上出现故障,就会发生这种情况。

我唯一能解决这个问题的方法就是重启设备。 人们可以通过许多其他方法来修复离线状态,但重新启动设备总是有效的。