调试Android USB遇到的令人费解的问题
上周参照网上代码,做了USB的初步探测程序,工作正常 。今天从硬件部拿到了一段例程,原本打算参考它来完善自己的程序。但运行之后总是报错,逐步跟进错误,进而发现了一个匪疑所思的问题。调试一天也未发现原因以及解决办法。在此做记录,留待以后解决或从网上得到帮助。
问题程序:
UsbHid.java:
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
public class UsbHid extends Activity{
private static UsbHid usbHid = null;
Context context;
private static final String TAG = "UsbHid";
private UsbManager myUsbManager;
private UsbDevice myUsbDevice;
private boolean HasUsbDevice;
...
private UsbHid(Context context) {
this.context = context;
myUsbManager = (UsbManager) context.getSystemService(Context.USB_SERVICE);
HasUsbDevice = enumerateDevice();
Log.d(TAG, "UsbHid init");
}
public bollean enumerateDevice() {
if (myUsbManager == null)
return -1;
HashMap<String, UsbDevice> deviceList = myUsbManager.getDeviceList();
if (!deviceList.isEmpty()) {
...
return true;
}
return false;
}
public static UsbHid getInstance(Context context) {
if (usbHid == null) {
usbHid = new UsbHid(context);
}
return usbHid;
}
public boolean getUsbDevice() {
return HasUsbDevice;
}
...
}
MainActivity.java:
public class MainActivity extends ActionBarActivity {
UsbHid usbHid = null;
UsbManager myUsbManager;
UsbDevice myUsbDevice;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
usbHid = UsbHid.getInstance(this);
if (usbHid.getUsbDevice()) {
usbHid.ConnectUsbHid();
this.setTitle("已连接USB设备");
} else {
this.setTitle("末检测到USB设备");
}
if (usbHid.getUsbDevice()) {
UsbReadThread thread = new UsbReadThread();
thread.start();
}
}
...
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
以上程序从原理上分析应该没有问题,但实际中deviceList.isEmpty()总是返回null。
更为奇怪的是,若将UsbHid.java中的
myUsbManager = (UsbManager) context.getSystemService(Context.USB_SERVICE);
HasUsbDevice = enumerateDevice();
移到MainActivity.java中,则没有问题,可以正常枚举设备。
前一天写的以上内容,今天原本打算暂时绕过以上问题,继续进行后续开发,毕竟这个问题不是不可避免的。但还是觉得应该再基于这个问题研究一下,因为这样才能够提高水平,丰富经验。
进行反复修改尝试,根据现象判断,最终发现了问题所在:
UsbHid.java:
public static UsbHid getInstance(Context context) {
if (usbHid == null) {
usbHid = new UsbHid(context);
}
return usbHid;
}
就是这句导致的问题!将这句程序封掉后,可以枚举到设备,程序可以正常工作了。
具体原因尚不清楚,但初步分析应该是由于usbHid是静态变量(private static UsbHid usbHid = null;),放在全局存储区,因此回收的时候并没有马上释放掉。下次进程再启动时,它并不是null,而是上次一分配过的值。基于这个想法,做了实验,将上面这段代码改写如下:
public static UsbHid getInstance(Context context) {
if (usbHid == null) {
usbHid = new UsbHid(context);
return usbHid;
}
return null;
}
改写程序的目的是测试是否每次都返回usbHid而非null。宏观上从程序运行现象来看应该是如果每次都返回usbHid,则每次程序都正常;如果有返回null的时候,则程序会停止运行。
测试结果印证了 猜测,一次成功接一次失败,即确实usbHid在前一次进程结束后并未彻底释放,而直到出错被停止运行后才被释放掉。
另外一个测试也验证了以上想法:将手机重启,之后运行以上程序,由于是第一此运行,因此完全正常,而后每次即使不插入usb设备,也不报错。这就说明了usbHid这个变量并没有被释放干净。
至于为何进程结束后,仍不能是放干净,则有待进一步深入,应该是与Java的回收机制有关了……
调试Android USB遇到的令人费解的问题的更多相关文章
- Eclipse中调试Android技巧
Android eclipse中程序调试 一:断点调试 用eclipse开发android程序的时,跟VS一样是可以断点单步调试的. 步骤如下. 1 设置断点:在编码窗体的左边框上用鼠标双击,或者右键 ...
- 在 Chrome 中调试 Android 浏览器
最近需要使用 Chrome Developer Tools 调试 Android 浏览器,但是官方指南并不是很好使,经过一番折腾,终于调试成功了,在此把经验分享给需要的朋友. Chrome Devel ...
- Web程序员开发App系列 - 调试Android和IOS手机代码(补图)
Web程序员开发App系列 Web程序员开发App系列 - 认识HBuilder Web程序员开发App系列 - 申请苹果开发者账号 Web程序员开发App系列 - 调试Android和iOS手机代码 ...
- 在ubuntu下真机调试android程序出现设备没有访问权限
今天把android的开发环境从windows平台切换到了ubuntu上. java jdk android-adt android-ndk都下好,环境变量都配好之后, 在调试程序的时候,出现设备没有 ...
- 理解WebKit和Chromium: 调试Android系统上的Chromium
转载请注明原文地址:http://blog.csdn.net/milado_nju 1. Android上的调试技术 在Android系统上,开发人员能够使用两种不同的语言来开发应用程序,一种是Jav ...
- I.MX6 Android USB Touch eGTouchA.ini文件存放
/******************************************************************** * I.MX6 Android USB Touch eGTo ...
- 通过Wifi调试Android应用
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
- android usb Host模式下与usb Hid 设备的通信
做android 与USB HID设备的通信有段时间了,总结一下遇到的问题和解决方法: 1,第一次遇到的问题:android 版本低不支持usb hid, 被要求做相关项目的时候,就从mUsbMana ...
- 如何通过Chrome远程调试android设备上的Web网站
网上的帖子很多,但很多都是老版本的,试过了,根本不管用,花了一天时间,终于在本机试验通过了,特记录下来,以备用.有需要的朋友也可以参考.先上一张图,看看PC端chrome上调试的效果: 左边是手机的模 ...
随机推荐
- js实现图片滑动显示效果
js实现图片滑动显示效果 今天用户提出一个需求,要实现一个滑动显示新闻列表的效果,具体就是图片新闻自动滑动显示,鼠标移上去就停止滑动,移开就继续滑动:效果如下: 第一:先用HTML和CSS实现显示,主 ...
- bootstrap 的 datetimepicker 结束时间大于开始时间
web的时间js控件,在管理性的项目中频繁用到,总结了一些用到的知识,分享出来,供以后学习: 1.首先引用资源包: bootstrap基础资源包: bootstrap.min.css .bootstr ...
- Java 简单算法--打印回文数字
package cn.magicdu.algorithm; public class CircleNumber { public static void main(String[] args) { f ...
- Java_字符类(Character、String、StringBuffer)_char是基本数据类型,Character是其包装类型。
在java中有三个类负责对字符的操作:Character.String.StringBuffer.其中,Character类是对单个字符进行操作,String是对一个字符序列的操作,Stri ...
- ODBC连接MySQL出现"E_FAIL"错误
ODBC不能处理这种格式的数据:0000-00-00,将其更新为正常的时间即可解决
- jquery动态插入行
这是一个利用jquery动态插入输入内容的代码. html代码: <div title="分表2" class="ui-edit" style=" ...
- 生产项目加入到SVN版本控制
零.介绍 每天定时备份是通过ftp打包和同步的方式,这些都是比较粗的备份,没法恢复到指定时间的文件,所以需要用到svn控制版本. (请不要问我为什么不用git) 一.现有项目文件加入版本控制 因为项目 ...
- osi七层模型和两主机传输过程:
osi七层模型和两主机传输过程: http://www.zhihu.com/question/24002080/answer/31817536 注:笔记部分可能参考其他作者内容的一个记录,仅为加深自 ...
- head 头标签(转发)
HTML head 头标签 paddingme | 04 Oct 2014 HTML head 头部分的标签.元素有很多,涉及到浏览器对网页的渲染,SEO 等等,而各个浏览器内核以及各个国内浏览器厂商 ...
- jquery改变多个css样式
<!DOCTYPE html> <html> <head> <script src="http://ajax.googleapis.com/ajax ...