Android设备 adb传输,android – 通过ADB shell传输二进制数据(即使用tar快速传输文件)...

我一直在尝试从我的

Android设备移动文件到我的osx机器使用类似于:adb shell tar -c directory_to_copy | tar -x.似乎远程tar正在工作,但文件损坏的方式.

经过一些玩耍,我发现:

>似乎adb shell命令将LF转换为CRLF:

% adb shell 'cd /mnt/sdcard;echo hi>a.bin'

% adb shell 'cd /mnt/sdcard;cat a.bin' | hexdump -C

00000000 68 69 0d 0a |hi..|

00000004

% adb pull /mnt/sdcard/a.bin

0 KB/s (3 bytes in 0.457s)

% hexdump -C a.bin

00000000 68 69 0a |hi.|

00000003

>它看起来服务器或守护程序正在导致而不是客户端(请参阅len = 4):

% ADB_TRACE=1 adb shell 'cd /mnt/sdcard;cat a.bin'

[... snip ...]

system/core/adb/commandline.c::read_and_dump():read_and_dump(): post adb_read(fd=3): len=4

[... snip ...]

我猜这个守护进程在windows用户的shell命令中正在进行这种翻译.

我的问题是:

> wtf? (什么是什么目的?)

有没有办法告诉它(adbd?)不这样做?

>任何人都可以想到任何创造性的方式来规避(我想到的是base64编码数据,但是我宁愿避免这种开销),而且创建一个本地文件不是一个选择,因为我的文件系统已经满了)

谢谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值