Blog Archives

Android,google

Android内存泄漏问题的排查

稍好效果,请点击这里下载PDF版本 首先先检查下你有没有犯这些错误(内存泄露的主要原因): 生命周期过长的对象(static),尤其是集合对象(List/Map等)作为cache等使用,如果没有将某个对象主动的从中清除的话,这个集合就会占用越来越多的内存,可以用WeakReference,如WeakHashMap,使得它持有的对象不增加对象的引用数。 Scope定义不对,方法的局部变量定义成类的变量,类的静态变量等。尽量使得变量作用域别太大。 异常时没有加finally{}来释放某些资源,比如Cursor。 Listener没有显式remove;内部类持有外部对象的隐式引用,不论是什么,如果有add方法,一定要想想是否需要remove方法。 图像对象是否在不用的时候释放了(((BitmapDrawable) d).getBitmap().recycle();) 以下是正文 1. 获取hprof信息 1.1. 使用脚本get_hprof.sh ./get_hprof.sh --脚本内容见附录 运行此脚本之前,需要根据你的实际情况修改脚本,设置一下几个变量: # where is you sdk SDKPATH=. 这个是需要制定sdk/tools目录的位置,需要执行其下的adb和hprof-conv命令 # where will you want to save the log file TARGET_LOG_DIR=./hproflog log的保存位置 # which process will you

Posted in Android Tagged with: , , , , ,

android内存泄露(memory leak)之进程HProf (Heap Profile) 信息

因为性能问题(主要是内存泄漏),需要采集程序堆栈等信息,代码如下,只是简单说几个地方: 1.默认的HProf (Heap Profile) 放在/data/misc,需要改写权限为777 2.kill -10 pid 即可生成.prof文件 3.需要用android sdk的hprof-conf将android的hprof转化为标准的(能在MAT中用的) #!/bin/sh   # author liubin (http://liubin.nanshapo.com) # get_hprof.sh 2010/12/17   ######################################################## ###########                              ############### ###########   you

Posted in Android Tagged with: ,

在pc上操作实机

实机屏幕花了,没法操作,还好有 androidscreencast 这个软件。 这个软件,可以在pc上模拟操作真机,不仅是menu,back键,屏幕操作也可以,很方便。 我手工装的jdk1.5好像不太好用,启动出错;安装了openjdk-6-jdk之后,用它打开,就可以启动了: sudo apt-get install openjdk-6-jdk /usr/lib/jvm/java-6-openjdk/bin/javaws androidscreencast.jrlp

Posted in Android

手动启动媒体扫描

adb shell am broadcast -a android.intent.action.MEDIA_MOUNTED -d file:///sdcard Development\src\com\android\development\MediaScannerActivity.java中: @Override     public void onResume() {         super.onResume();           ……..           sendBroadcast(new Intent(Intent.ACTION_MEDIA_MOUNTED, Uri.parse("file://" + Environment.getExternalStorageDirectory())));         ……..

Posted in Android

logcat tips

写程序少不了调试,相对与debug,打log可能最简单。 adb 的logcat能查看所有的log,然后,很多时候可能不是我们想看的,所以,特总结了一些小窍门 1. 只看某一TAG的log adb logcat TWE:* *:S 在运行logcat的时候在前两列的信息中你就可以看到 logcat 的标签列表和优先级别, 它是这样标出的:/ . 下面是一个logcat输出的例子,它的优先级就似乎I,标签就是ActivityManage: I/ActivityManager( 585): Starting activity: Intent { action=android.intent.action…} 标签就是log.d的第一个参数了。 logcat过滤器的语法是tag:priority,所以,TWE:*,就表示标签TAW的所有级别的log。 *:S 的用处是确保日志输出的时候按照过滤器的进行限制。 或者logcat -s “TAG:PRIORITY” 2.清楚所有log logcat -c 3.将log保存到指定的文件中 logcat -f [filename] 4.在log中显示时间 默认的情况下是不显示打印时间的,需要用-v参数来设置格式: logcat -v

Posted in Android

从命令行给模拟器拨打电话

从Eclips的DDMS视图虽然可以给模拟器打电话,发短信,但是毕竟要去编辑源代码的换还要切换模式。 其实可以从命令行进行。 首先,登录到模拟器: telnet localhost 5554 进入后,按help可以得到帮助 help Android console command help: help|h|? print a list of commands event simulate hardware events geo Geo-location commands gsm GSM related commands kill kill the emulator instance gsm2 GSM2 related commands network manage

Posted in Android

sqlite的PHONE_NUMBERS_EQUAL函数

怎么才叫两个电话号码相等?用=肯定不行,86 138xxx 和0138xxx应该是相等的 android里在c实现了PHONE_NUMBERS_EQUAL函数,这个函数有3个参数。 前两个自然是需要比较的电话号码了,第三个参数有些特别,可选值为0或者1。 查看源代码可见,这个参数名为accept_thailand_case,看来和泰国有关了 各个国家的电话号码规则都不一样,看来移植的时候这个文件是必须被修改的。 在我们这里,第三个参数用0就可以了 代码位置在external\sqlite

Posted in Android

创建android home程序

需要在manifest.xml里加入: <intent-filter>      <action android:name="android.intent.action.MAIN" />      <category android:name="android.intent.category.HOME" />      <category android:name="android.intent.category.DEFAULT" />  </intent-filter>

Posted in Android, Tech

android的HttpClient

在pC上,从服务器取得的内容用 比如: String xml = EntityUtils.toString(httpResponse.getEntity()); xml = new String(xml.getBytes(“ISO-8859-1″),”UTF-8″); 就能得到正常的中文了,但是android下好像不对 试了下,这样就可以了: String xml = EntityUtils.toString(httpResponse.getEntity(),”unicode”); 只用了一行

Posted in Android Tagged with: , , ,

Android中一些关于sqlite的总结-1

1.数据库文件 位于:/data/data/{package} /databases文件夹中 2.SQLiteOpenHelper 的onCreate,onUpgrade  你可以扩展SQLiteOpenHelper类,它是一个Android辅助类,主要用于数据库创建和版本管理。实际上,你可以覆盖onCreate()和onUpgrade()方法 onCreate在数据库第一次被创建的时候才会调用,不用担心每次都掉用。 因为很多例子都是create table的语句,重复调用显然原来的数据会没的。 而onUpgrade则是升级的时候才会调用,看如下代码: @Override         public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {             Log.w(TAG, "Upgrading database from version " + oldVersion + " to

Posted in Android, Tech

无觅相关文章插件,快速提升流量