我的需求是做一个快速拨号界面!list列表显示所有联系人Calllog资料!原来的做法在前面的日志中有提到!大概是先查
Cursor phoneCursor = this.managedQuery(
ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null, null,
null, null);
再根据号码来查联系人
if(0 < phoneCursor.getCount()){
phoneCursor.moveToFirst();
// find all contact list
while (phoneCursor.getPosition() != phoneCursor.getCount()) {
ContactEntity contactentity = new ContactEntity();
contactentity.contact_id = phoneCursor
.getLong(phoneCursor
.getColumnIndex(ContactsContract.CommonDataKinds.Phone.CONTACT_ID));
contactentity.contacts_phone_type = phoneCursor
.getInt(phoneCursor
.getColumnIndex(ContactsContract.CommonDataKinds.Phone.TYPE));
contactentity.contacts_phone_number = phoneCursor
.getString(phoneCursor
.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER)).replace(
"-", "");
contactCursor = this.managedQuery(
ContactsContract.Contacts.CONTENT_URI, null,
ContactsContract.Contacts._ID + "="
+ contactentity.contact_id, null, null);
contactCursor.moveToFirst();
contactentity.contacts_display_name = contactCursor
.getString(contactCursor
.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME)).replace(
"-", "");
Uri uri = ContentUris.withAppendedId(ContactsContract.Contacts.CONTENT_URI,
contactentity.contact_id);
InputStream input = ContactsContract.Contacts.openContactPhotoInputStream(getContentResolver(), uri);
if(null != input){
contactentity.contact_phone_bmp = BitmapFactory.decodeStream(input);
}
// spell name can
contactentity.spellName = PinYin.getInstance(this).getPinyinString(
contactentity.contacts_display_name);
Log.i(TAG, "contactentity.contact_id: " + contactentity.contact_id
+ " contactentity.contacts_phone_type: "
+ contactentity.contacts_phone_type
+ " contactentity.contacts_phone_number: "
+ contactentity.contacts_phone_number
+ "contactentity.contacts_display_name: "
+ contactentity.contacts_display_name
+ "contactentity.contact_phone_bmp: "
+ contactentity.contact_phone_bmp);
phoneCursor.moveToNext();
customArrayList.add(contactentity);
}
经过测试发现性能消耗主要在这个while循环当中!因为在循环当中在加一个查询数据库操作自然慢!
解决方案:
发现在查询ContactsContract.CommonDataKinds.Phone.CONTENT_URI数据库时其实可以吧
ContactsContract.Contacts.DISPLAY_NAME,
ContactsContract.Contacts.PHOTO_ID查询出来
那么把原来的
private final static String[] mContactsProjection = new String[] {
ContactsContract.CommonDataKinds.Phone.CONTACT_ID,
ContactsContract.CommonDataKinds.Phone.TYPE,
ContactsContract.CommonDataKinds.Phone.NUMBER,
};
改为
private final static String[] mContactsProjection = new String[] {
ContactsContract.CommonDataKinds.Phone.CONTACT_ID,
ContactsContract.CommonDataKinds.Phone.TYPE,
ContactsContract.CommonDataKinds.Phone.NUMBER,
ContactsContract.Contacts.DISPLAY_NAME,
ContactsContract.Contacts.PHOTO_ID
};
下面对应改为
while (phoneCursor.getPosition() != phoneCursor.getCount()) {
ContactEntity contactentity = new ContactEntity();
contactentity.contacts_id = phoneCursor.getLong(0);
contactentity.contacts_phone_type = phoneCursor.getInt(1);
contactentity.contacts_phone_number = phoneCursor.getString(2)
.replace("-", "");
contactentity.contacts_display_name = phoneCursor.getString(3).replace("-", "");
contactentity.contacts_photo_id = phoneCursor.getString(4);
// spell name can
contactentity.spellName = PinYin.getInstance(this)
.getPinyinString(contactentity.contacts_display_name);
// Log.i(TAG, "contactentity.contact_id: " +
// contactentity.contact_id
// + " contactentity.contacts_phone_type: "
// + contactentity.contacts_phone_type
// + " contactentity.contacts_phone_number: "
// + contactentity.contacts_phone_number
// + "contactentity.contacts_display_name: "
// + contactentity.contacts_display_name
// + "contactentity.contact_phone_bmp: "
// + contactentity.contact_phone_bmp);
phoneCursor.moveToNext();
customArrayList.add(contactentity);
}
}
这样改变后只读一次数据库!
在1000联系人的情况下耗时打LOG得到不到2000毫秒!
其他优化方向!
1、查询数据库时把managedquerey第二参数projection写时!只查需要的列!不查询全部!
2、在contactentity.contact_id = phoneCursor
.getLong(phoneCursor
.getColumnIndex(ContactsContract.CommonDataKinds.Phone.CONTACT_ID));取值时直接用数组序号0,1,2代替!
3.图片等大数据量数据可放在getview方法中直接赋值而不通过对象传递!
分享到:
相关推荐
【Android性能优化】是Android开发中的重要环节,涵盖了多个关键领域,包括ANR问题解析、crash监控方案、启动速度与执行效率优化、内存优化、耗电优化、网络传输与数据存储优化以及APK大小优化。 **ANR问题解析**是...
Android性能优化学习源码。Android性能优化学习源码。Android性能优化学习源码。Android性能优化学习源码。Android性能优化学习源码。Android性能优化学习源码。Android性能优化学习源码。Android性能优化学习源码。...
Android 应用性能优化 Android 应用性能优化是指通过各种技术和方法来提高 Android 应用程序的运行速度、响应速度和总体性能的过程。这包括优化应用程序的代码、数据库、网络请求、内存管理、图形渲染、缓存机制等...
### Android App性能优化的核心策略与实践 在移动设备上运行的Android应用程序,受限于设备的计算能力、存储空间以及电池续航能力,优化其性能成为开发者不可忽视的重要任务。本篇文章将深入探讨Android应用性能...
1、性能优化专家:具备深度性能优化与体系化APM建设的能力。 2、架构师:具有丰富的应用架构设计经验与心得,对Android Framework层与热门三方库的实现原理与架构设计了如指掌。 3、音视频/图像处理专家:毫无疑问,...
这个"免费:Android性能优化视频百度云下载链接.rar"的压缩包文件提供了一个学习资源,可能是由一系列视频教程组成,帮助开发者深入理解和掌握Android应用的性能调优技巧。虽然没有直接提供视频内容,但包含的"免费...
"Android开发的性能优化" Android系统的性能优化是当前Android开发者所关心的热点话题。随着Android平台的发展和应用功能的强大,性能优化变得越来越重要。以下是Android开发中的性能优化知识点: 1. 高效使用...
总的来说,《Android应用性能优化》是一本全面讲解Android性能提升的指南,它可以帮助开发者构建更加高效、稳定和用户友好的应用程序。虽然技术日新月异,但基本的优化原则和技巧依然有效,对于任何Android开发者来...
android_app性能优化之list篇.ppt
Android性能优化.xmind
根据提供的文件信息,“Android应用性能优化.pdf”这一文档主要聚焦于Android应用的性能优化方法与实践。虽然部分内容涉及社群推广信息,并未直接提供具体的性能优化技术细节,但我们可以通过标题及描述推断出文档的...
本专题将深入探讨Android性能优化的关键知识点,帮助开发者提升应用的运行效率和用户体验。 首先,我们要理解Android性能优化的基本原则:减少资源消耗、提高响应速度、降低内存占用以及提升电池续航。在Java编程...
根据提供的标题“Android应用性能优化【高清】”和描述“Android应用性能优化【高清】”,本文将深入探讨Android应用性能优化的关键技术与实践方法。由于提供的部分内容主要为重复的网站链接,这部分内容将不会被...
Android应用性能优化 开发优秀的Android应用必备指南
android界面及代码优化方案,帮助提升android应用的性能
### Android应用性能优化的重要性 在当今移动互联网时代,Android应用已成为人们生活中不可或缺的一部分。随着市场竞争的日益激烈,用户对应用的体验要求也越来越高。因此,性能优化成为了提升用户体验的关键因素之...