【Android 应用开发】Android 开发错误集锦(一)

本文涉及的产品
阿里云百炼推荐规格 ADB PostgreSQL,4核16GB 100GB 1个月
简介: 【Android 应用开发】Android 开发错误集锦(一)

1. eclipse的Device中不显示手机


在eclipse中连接不上手机,出现adb server didn't ACK  fail to start daemon 错误.


出现这种原因是因为adb所使用的5037端口被占用了.


使用adb kill-server 关闭adb服务 , 使用adb start-server开启adb命令 ; 如果5037端口被占用则会出现启动失败, 报出上述错误;


查看哪些进程占用了端口 : netstat -ano | findstr "5037" 会出现下面的结果


G:\Documents and Settings\Administrator>netstat -ano | findstr "5037"

 TCP    127.0.0.1:1939         127.0.0.1:5037         ESTABLISHED     5748

 TCP    127.0.0.1:1978         127.0.0.1:5037         ESTABLISHED     3000

 TCP    127.0.0.1:5037         0.0.0.0:0              LISTENING       5748

 TCP    127.0.0.1:5037         127.0.0.1:1939         ESTABLISHED     5748

 TCP    127.0.0.1:5037         127.0.0.1:1977         CLOSE_WAIT      5748

 TCP    127.0.0.1:5037         127.0.0.1:1978         ESTABLISHED     5748

可以看到 5748 3000 两个进程占用了5037端口.


打开进程管理器, 点击查看,选择列,将PID进程标示符勾选上,然后根据pid终止相应的进程.


这两个进程分别是豌豆荚 和 QQ , 同时将adb.exe 和 tadb.exe 进程干掉.


此时执行 adb start-server 命令即可启动adb服务 , 之后启动就会启动成功.






2. java.lang.OutOfMemoryError: thread creation failed 错误



10-17 09:51:58.830: E/AndroidRuntime(15695): FATAL EXCEPTION: Thread-316
10-17 09:51:58.830: E/AndroidRuntime(15695): java.lang.OutOfMemoryError: thread creation failed
10-17 09:51:58.830: E/AndroidRuntime(15695):  at java.lang.VMThread.create(Native Method)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at java.lang.Thread.start(Thread.java:1050)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.alarm.AlarmPlayer.enqueue(AlarmPlayer.java:201)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.alarm.AlarmPlayer.resume(AlarmPlayer.java:192)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.director.MpmDirector.filterMpmHealthData(MpmDirector.java:270)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.director.MpmDirector.onHealthDataDecoded(MpmDirector.java:72)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.decoder.BaseDecoder.notifyAllDataDecodedListener(BaseDecoder.java:89)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.decoder.MpmEcgDecoder.caculateEcgResult(MpmEcgDecoder.java:394)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.decoder.MpmEcgDecoder.casulateResult(MpmEcgDecoder.java:269)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.decoder.MpmEcgDecoder.processBigPackageOfEcgData(MpmEcgDecoder.java:100)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.decoder.MpmEcgDecoder.processData(MpmEcgDecoder.java:87)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.decoder.MpmDecoder.operator(MpmDecoder.java:135)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.BqfjApplication$2.receiveData(BqfjApplication.java:148)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.bluetooth.BqfjBluetoothManager.notifyReceivers(BqfjBluetoothManager.java:281)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.bluetooth.BqfjConnectionManager$DataPump.run(BqfjConnectionManager.java:397)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at com.ivt.mHealth.util.ReusableThread.run(ReusableThread.java:85)
10-17 09:51:58.830: E/AndroidRuntime(15695):  at java.lang.Thread.run(Thread.java:856)
10-17 09:51:58.920: V/StagefrightPlayer(1875): isPlaying
10-17 09:51:58.920: V/MediaPlayerService(1875): [20] isPlaying: 0
10-17 09:51:58.920: V/MediaPlayer(15695): isPlaying: 0
10-17 09:51:58.920: V/MediaPlayer-JNI(15695): isPlaying: 0
10-17 09:51:58.925: D/dalvikvm(2219): GC_FOR_ALLOC freed 1595K, 30% free 26891K/37895K, paused 77ms, total 77ms
10-17 09:51:58.930: E/SQLiteLog(15695): (14) cannot open file at line 30241 of [00bb9c9ce4]
10-17 09:51:58.930: E/SQLiteLog(15695): (14) os_unix.c:30241: (2) open(/NotificationPermissions.db) - 
10-17 09:51:58.930: D/STATUSBAR-NetworkController(2441): refreshSignalCluster: data=-1 bt=false



开发中遇到了上述错误 , 后来发现是 使用了TraceView导致的


不知道在代码的什么地方添加了TraceView的相关代码 , 去掉之后 , 就好了


我在Activity中的onCreate()方法中添加了 :


Debug.startMethodTracing();


在onDestroy()方法中添加了 :

Debug.stopMethodTracing();


去掉了上述两行代码 , 就不会出现上述错误了 ;





3. Call requires API level 8 (current min is 1)错误



导入了一个程序 , 每次运行之后都会出现该错误 .


点击clean 错误就会消失 , 但是执行该错误的时候该错误就会重新出现 .


这个错误需要在AndroidManifest.xml配置文件中修改 user-sdk 标签


给user-sdk 添加一个android:minSdkVersion="8" 属性





4. 奇怪的空指针异常



今天出现一个奇怪的错误, 很简单空指针异常, 我只负责编码, 不管编译, 然后上传到SVN上, 结果出了下面的错误 , 看了半天 , 木有看懂 :




11-13 10:39:53.337: E/AndroidRuntime(11030): FATAL EXCEPTION: Thread-394
11-13 10:39:53.337: E/AndroidRuntime(11030): java.lang.NullPointerException
11-13 10:39:53.337: E/AndroidRuntime(11030):  at com.ivt.mHealth.widget.aa.b(Unknown Source)
11-13 10:39:53.337: E/AndroidRuntime(11030):  at com.ivt.mHealth.widget.DisplaySurfaceView.a(Unknown Source)
11-13 10:39:53.337: E/AndroidRuntime(11030):  at com.ivt.mHealth.widget.ae.run(Unknown Source)


我一看 蒙了 , 这是什么错误 , 没定义过这个类啊 , 后来才想起来 这是代码混淆以后的效果 .

有点无语 ... 想了半小时才反应过来


我直接从SVN上down了一下代码, 重新编译下 , ╮(╯▽╰)╭ 拨云见日


11-13 10:41:57.432: E/AndroidRuntime(11507): FATAL EXCEPTION: Thread-398
11-13 10:41:57.432: E/AndroidRuntime(11507): java.lang.NullPointerException
11-13 10:41:57.432: E/AndroidRuntime(11507):  at com.ivt.mHealth.widget.BpmSurface.drawMpmBpm(BpmSurface.java:169)
11-13 10:41:57.432: E/AndroidRuntime(11507):  at com.ivt.mHealth.widget.BpmSurface.drawToSurfaceView(BpmSurface.java:109)
11-13 10:41:57.432: E/AndroidRuntime(11507):  at com.ivt.mHealth.widget.DisplaySurfaceView.drawToSurface(DisplaySurfaceView.java:183)
11-13 10:41:57.432: E/AndroidRuntime(11507):  at com.ivt.mHealth.widget.DisplaySurfaceView.access$1(DisplaySurfaceView.java:178)
11-13 10:41:57.432: E/AndroidRuntime(11507):  at com.ivt.mHealth.widget.DisplaySurfaceView$RenderThread.run(DisplaySurfaceView.java:144)


以后千万不要看编译出来的产品的log , 都是混效过的 ........




这是少上传了一行代码到SVN上啊 ...... 泪奔 .... 半小时就这么浪费了



5. 内存溢出错误



adb shell dumpsys meminfo com.ivt.mHealth



08-12 12:48:52.798: I/dalvikvm-heap(15260): Clamp target GC heap from 64.996MB to 64.000MB
08-12 12:48:52.798: D/dalvikvm(15260): GC_FOR_ALLOC freed 1K, 3% free 63863K/65543K, paused 190ms, total 190ms
08-12 12:48:52.798: I/dalvikvm-heap(15260): Forcing collection of SoftReferences for 21473-byte allocation
08-12 12:48:52.988: I/dalvikvm-heap(15260): Clamp target GC heap from 64.987MB to 64.000MB
08-12 12:48:52.988: D/dalvikvm(15260): GC_BEFORE_OOM freed 9K, 3% free 63853K/65543K, paused 186ms, total 186ms
08-12 12:48:52.988: E/dalvikvm-heap(15260): Out of memory on a 21473-byte allocation.
08-12 12:48:52.988: I/dalvikvm(15260): "main" prio=5 tid=1 RUNNABLE
08-12 12:48:52.988: I/dalvikvm(15260):   | group="main" sCount=0 dsCount=0 obj=0x40efd508 self=0x40d62778
08-12 12:48:52.988: I/dalvikvm(15260):   | sysTid=15260 nice=0 sched=0/0 cgrp=apps handle=1074577200
08-12 12:48:52.988: I/dalvikvm(15260):   | schedstat=( 21710980394 3466435126 36123 ) utm=1846 stm=324 core=1
08-12 12:48:52.988: I/dalvikvm(15260):   at com.ivt.mHealth.util.ByteArrayBuffer.expand(ByteArrayBuffer.java:~28)
08-12 12:48:52.988: I/dalvikvm(15260):   at com.ivt.mHealth.util.ByteArrayBuffer.append(ByteArrayBuffer.java:62)
08-12 12:48:52.988: I/dalvikvm(15260):   at com.ivt.mHealth.util.BqfjHttpHeaderPacker.packHttpHeader(BqfjHttpHeaderPacker.java:185)
08-12 12:48:52.988: I/dalvikvm(15260):   at com.ivt.mHealth.datacommunication.impl.BqfjSendRTMpmDataMessageHandler$PacketTransController.sendPacket(BqfjSendRTMpmDataMessageHandler.java:770)
08-12 12:48:52.988: I/dalvikvm(15260):   at com.ivt.mHealth.datacommunication.impl.BqfjSendRTMpmDataMessageHandler$PacketTransController.onPacketReceived(BqfjSendRTMpmDataMessageHandler.java:814)
08-12 12:48:52.988: I/dalvikvm(15260):   at com.ivt.mHealth.datacommunication.impl.BqfjSendRTMpmDataMessageHandler$1.handleMessage(BqfjSendRTMpmDataMessageHandler.java:526)
08-12 12:48:52.988: I/dalvikvm(15260):   at android.os.Handler.dispatchMessage(Handler.java:99)
08-12 12:48:52.988: I/dalvikvm(15260):   at android.os.Looper.loop(Looper.java:137)
08-12 12:48:52.988: I/dalvikvm(15260):   at android.app.ActivityThread.main(ActivityThread.java:4921)
08-12 12:48:52.988: I/dalvikvm(15260):   at java.lang.reflect.Method.invokeNative(Native Method)
08-12 12:48:52.988: I/dalvikvm(15260):   at java.lang.reflect.Method.invoke(Method.java:511)
08-12 12:48:52.988: I/dalvikvm(15260):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1038)
08-12 12:48:52.988: I/dalvikvm(15260):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:805)
08-12 12:48:52.988: I/dalvikvm(15260):   at dalvik.system.NativeStart.main(Native Method)
08-12 12:48:52.988: D/AndroidRuntime(15260): Shutting down VM
08-12 12:48:52.988: W/dalvikvm(15260): threadid=1: thread exiting with uncaught exception (group=0x40efc2a0)
08-12 12:48:52.993: V/BluetoothSocket.cpp(15260): readNative
08-12 12:48:52.993: E/AndroidRuntime(15260): FATAL EXCEPTION: main
08-12 12:48:52.993: E/AndroidRuntime(15260): java.lang.OutOfMemoryError
08-12 12:48:52.993: E/AndroidRuntime(15260):  at com.ivt.mHealth.util.ByteArrayBuffer.expand(ByteArrayBuffer.java:28)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at com.ivt.mHealth.util.ByteArrayBuffer.append(ByteArrayBuffer.java:62)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at com.ivt.mHealth.util.BqfjHttpHeaderPacker.packHttpHeader(BqfjHttpHeaderPacker.java:185)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at com.ivt.mHealth.datacommunication.impl.BqfjSendRTMpmDataMessageHandler$PacketTransController.sendPacket(BqfjSendRTMpmDataMessageHandler.java:770)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at com.ivt.mHealth.datacommunication.impl.BqfjSendRTMpmDataMessageHandler$PacketTransController.onPacketReceived(BqfjSendRTMpmDataMessageHandler.java:814)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at com.ivt.mHealth.datacommunication.impl.BqfjSendRTMpmDataMessageHandler$1.handleMessage(BqfjSendRTMpmDataMessageHandler.java:526)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at android.os.Handler.dispatchMessage(Handler.java:99)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at android.os.Looper.loop(Looper.java:137)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at android.app.ActivityThread.main(ActivityThread.java:4921)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at java.lang.reflect.Method.invokeNative(Native Method)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at java.lang.reflect.Method.invoke(Method.java:511)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1038)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:805)
08-12 12:48:52.993: E/AndroidRuntime(15260):  at dalvik.system.NativeStart.main(Native Method)
08-12 12:48:53.013: E/android.os.Debug(2224): !@Dumpstate > dumpstate -k -t -z -d -o /data/log/dumpstate_app_error
08-12 12:48:53.018: I/dumpstate(308): begin






相关实践学习
阿里云百炼xAnalyticDB PostgreSQL构建AIGC应用
通过该实验体验在阿里云百炼中构建企业专属知识库构建及应用全流程。同时体验使用ADB-PG向量检索引擎提供专属安全存储,保障企业数据隐私安全。
AnalyticDB PostgreSQL 企业智能数据中台:一站式管理数据服务资产
企业在数据仓库之上可构建丰富的数据服务用以支持数据应用及业务场景;ADB PG推出全新企业智能数据平台,用以帮助用户一站式的管理企业数据服务资产,包括创建, 管理,探索, 监控等; 助力企业在现有平台之上快速构建起数据服务资产体系
目录
相关文章
|
28天前
|
搜索推荐 前端开发 API
探索安卓开发中的自定义视图:打造个性化用户界面
在安卓应用开发的广阔天地中,自定义视图是一块神奇的画布,让开发者能够突破标准控件的限制,绘制出独一无二的用户界面。本文将带你走进自定义视图的世界,从基础概念到实战技巧,逐步揭示如何在安卓平台上创建和运用自定义视图来提升用户体验。无论你是初学者还是有一定经验的开发者,这篇文章都将为你打开新的视野,让你的应用在众多同质化产品中脱颖而出。
53 19
|
28天前
|
JSON Java API
探索安卓开发:打造你的首个天气应用
在这篇技术指南中,我们将一起潜入安卓开发的海洋,学习如何从零开始构建一个简单的天气应用。通过这个实践项目,你将掌握安卓开发的核心概念、界面设计、网络编程以及数据解析等技能。无论你是初学者还是有一定基础的开发者,这篇文章都将为你提供一个清晰的路线图和实用的代码示例,帮助你在安卓开发的道路上迈出坚实的一步。让我们一起开始这段旅程,打造属于你自己的第一个安卓应用吧!
56 14
|
28天前
|
开发框架 Android开发 iOS开发
安卓与iOS开发中的跨平台策略:一次编码,多平台部署
在移动应用开发的广阔天地中,安卓和iOS两大阵营各占一方。随着技术的发展,跨平台开发框架应运而生,它们承诺着“一次编码,到处运行”的便捷。本文将深入探讨跨平台开发的现状、挑战以及未来趋势,同时通过代码示例揭示跨平台工具的实际运用。
|
29天前
|
搜索推荐 前端开发 测试技术
打造个性化安卓应用:从设计到开发的全面指南
在这个数字时代,拥有一个定制的移动应用不仅是一种趋势,更是个人或企业品牌的重要延伸。本文将引导你通过一系列简单易懂的步骤,从构思你的应用理念开始,直至实现一个功能齐全的安卓应用。无论你是编程新手还是希望拓展技能的开发者,这篇文章都将为你提供必要的工具和知识,帮助你将创意转化为现实。
|
29天前
|
搜索推荐 Android开发 开发者
安卓应用开发中的自定义控件实践
在安卓应用开发的广阔天地中,自定义控件如同璀璨的星辰,点亮了用户界面设计的夜空。它们不仅丰富了交互体验,更赋予了应用独特的个性。本文将带你领略自定义控件的魅力,从基础概念到实际应用,一步步揭示其背后的原理与技术细节。我们将通过一个简单的例子——打造一个具有独特动画效果的按钮,来展现自定义控件的强大功能和灵活性。无论你是初学者还是资深开发者,这篇文章都将为你打开一扇通往更高阶UI设计的大门。
|
29天前
|
Java Android开发 开发者
探索安卓开发:构建你的第一个“Hello World”应用
在安卓开发的浩瀚海洋中,每个新手都渴望扬帆起航。本文将作为你的指南针,引领你通过创建一个简单的“Hello World”应用,迈出安卓开发的第一步。我们将一起搭建开发环境、了解基本概念,并编写第一行代码。就像印度圣雄甘地所说:“你必须成为你希望在世界上看到的改变。”让我们一起开始这段旅程,成为我们想要见到的开发者吧!
35 0
|
2月前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
2月前
|
缓存 前端开发 Android开发
安卓开发中的自定义视图:从零到英雄
【10月更文挑战第42天】 在安卓的世界里,自定义视图是一块画布,让开发者能够绘制出独一无二的界面体验。本文将带你走进自定义视图的大门,通过深入浅出的方式,让你从零基础到能够独立设计并实现复杂的自定义组件。我们将探索自定义视图的核心概念、实现步骤,以及如何优化你的视图以提高性能和兼容性。准备好了吗?让我们开始这段创造性的旅程吧!
30 1
|
2月前
|
搜索推荐 Android开发 开发者
探索安卓开发中的自定义视图:打造个性化UI组件
【10月更文挑战第39天】在安卓开发的世界中,自定义视图是实现独特界面设计的关键。本文将引导你理解自定义视图的概念、创建流程,以及如何通过它们增强应用的用户体验。我们将从基础出发,逐步深入,最终让你能够自信地设计和实现专属的UI组件。
|
2月前
|
IDE Java 开发工具
移动应用与系统:探索Android开发之旅
在这篇文章中,我们将深入探讨Android开发的各个方面,从基础知识到高级技术。我们将通过代码示例和案例分析,帮助读者更好地理解和掌握Android开发。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和技巧。让我们一起开启Android开发的旅程吧!