性能优化处理

性能优化处理


图片的性能优化

  • 一个activity 空置时 只需要3M的空间(当然这里是包括Application所占用的空间的)

例子:本地添加一个比较大的图,900K ,在登录显示的时候 直接加载这张图(加载的方式 是直接获取本地的drawable 和 bitmap),看内存消耗,80M。

  • 直接加载drawable 消耗内存21M

  • 直接加载bitmap(编码格式是ARGB8888 一个像素点占4个字节) 消耗内存21m(大图显示不全 有白边)

    针对图片的做处理

  • 针对Bitmap做编码格式的处理(ARGB565 一个像素点占2个字节) 消耗内存5M (效果和 ARGB8888差不多,且没有白边)针对当前情况 把图片放置在不同的drawable的密度下,看看加载的情况(加载时内存消耗一致 但是和 将图片放置在drawable中不一致 在drawable中会变大)
    1)drawable-hdpi下 5.26M
    1)drawable-xhdpi下 5.26M
    1)drawable-xxhdpi下 5.26M
    不同分辨率下的图片加载 耗费内存:
    1)增加分辨率之后 耗费内存是 8.02M

    针对图片处理,建议1.在不太要求精度的情况下 ,尽量使用AGB565处理 2.图片进行分类,放置在drawable-hdpi drawable-xhdpi下 drawable-xxhdpi下
    

2 内存使用的优化
1)几个Context的认识:(上下文,就是能够获取到系统资源的类)
a)结构如下;
-Object
-Context
-MockContext
-ContextWrapper
-TintContextWrapper
-IsolatedContext
-MutableContextWrapper
-ContextThemeWrapper
-Activity -----------------------
-Service -----------------------
-Application-----------------------
-BackupAgent
上边的几个Context是经常使用到的Activity Service Application

b)生命周期:
  Application 是在一个在app启动时就创建的context实例,并且application会一直存在,直到用户将其杀死。
  Activity 正常情况下,一个activity的生命周期是随着启动时创建,在不再使用,应该退出activity栈时,就会被销毁
  Service 正常情况下 service在启动时创建,在停止时终止。(service 和ntentService 的生命周期 有区别,service是可以自己stopSelf 也可以通过Intent停止服务,
          但是IntentService是跟绑定的宿主生命周期关联,会随着宿主的生命周期的结束而结束自己的生命周期)
c)获取
 在Activity中,直接使用Activity.this,getBaseContext(){因为Activity都是ContextWrapper的基类,所以这里的getBaseContext都是获取基类中的mBase参数},
 看老罗的博客中 得到这样的一个结果:activity是一个context,activity的父类是ContextWrapperTheme,而ContextWrapperTheme的父类是ContextWrapper,ContextWrapper的父类是Context.
  在ContextWrapper 中有一个方法也是获取Context的,叫getBaseContext() 返回的是类变量mBase,这个Context是在Activity创建是 系统创建的,与Activity是两个不同的Context。
  通过分配的内存地址可以看出,两个不一样。
  Activity的创建 不是通过new一个对象这么简单的创建,看代码是
  public class Instrumentation {  
    ......  
  
    public Activity newActivity(ClassLoader cl, String className,  
            Intent intent)  
            throws InstantiationException, IllegalAccessException,  
            ClassNotFoundException {  
        return (Activity)cl.loadClass(className).newInstance();  
    }  
  
    ......  
} 是通过class.newInstance()来创建的。Activity是一个复杂的类,包含了很多东西。是在ActivityThread 中创建的,创建过程可以看看源码:
public final class ActivityThread {  
......  

Instrumentation mInstrumentation;  
......  

private final Activity performLaunchActivity(ActivityClientRecord r, Intent customIntent) {  
    ......  

    ComponentName component = r.intent.getComponent();  
    ......  

    Activity activity = null;  
    try {  
        java.lang.ClassLoader cl = r.packageInfo.getClassLoader();  
        activity = mInstrumentation.newActivity(  
                cl, component.getClassName(), r.intent);  
        ......  
    } catch (Exception e) {  
        ......  
    }  

    try {  
        Application app = r.packageInfo.makeApplication(false, mInstrumentation);  
        ......  

        if (activity != null) {  
            ContextImpl appContext = new ContextImpl();  
            ......  
            appContext.setOuterContext(activity);  
            ......  
            Configuration config = new Configuration(mConfiguration);  
            ......  

            activity.attach(appContext, this, getInstrumentation(), r.token,  
                    r.ident, app, r.intent, r.activityInfo, title, r.parent,  
                    r.embeddedID, r.lastNonConfigurationInstance,  
                    r.lastNonConfigurationChildInstances, config);  
            ......  

            mInstrumentation.callActivityOnCreate(activity, r.state);  

            ......    
        }  

        ......  
    } catch (SuperNotCalledException e) {  
        ......  
    } catch (Exception e) {  
        ......  
    }  

    return activity;  
}  

} 这里创建了很多的东西,咱们的Context 和 getBasseContext 之所以不同,在这里就有体现。
同时这里还创建了一个Application 这样一个ApplicationContext,这样ApplicationContext 和 之前
所说的两个Activity 及getBaseContext分别是不一样的。

d)在Service中 获取的Context 和getBaseContext 也是不同的地址,所以不是指的同一个变量。在Activity中启动Service之后,
  分别对Activity和Service获取Context 及 getBaseContext来比较,是个Context的地址都不一样。    
  启动Service的源码没有找到,但是看Service中存在的各变量和Activity中存在的各变量是类似,没有找到启动Service中 比较深层次的源码,
  所以这里不能给出确切的认定,service和Activity启动一样(只不过Activity中有Window可以承载UI,但是Service就不能)。
  
e)因为存在Context的生命周期的说法,所以这里要说的是创建某个对象时 如果这个对象是全局的,就应该要使用全局的Context,如果对象是局部的
  那么就应该要用局部的Context.
  内存泄漏的实例是:  推送的manager 及统计的manager 在创建的时候 是在引导页。而传入的Context直接就是引导页的this.导致
  推送的manager 统计的manager 因为是静态单例,所以就一直持有引导页的context,不被释放。导致内存泄漏。
  
  查看工具:
   AS中存在这样一个Dump java heap的工具,这个工具能抓取手机中正在运行的 所有应用的在内存中15秒的分配情况。通过class package 可以很方便的找到
   当前的应用的包下存在哪些对象,对象的个数。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容

  • HereAndroid的内存优化是性能优化中很重要的一部分,而避免OOM又是内存优化中比较核心的一点。这是一篇关于...
    HarryXR阅读 3,802评论 1 24
  • 转载: 原文地址:http://www.csdn.net/article/2015-09-18/2825737/3...
    666swb阅读 1,435评论 0 10
  • 如何避免OOM 一、减小对象的内存占用 1、使用更加轻量的数据结构 例如,我们可以考虑使用ArrayMap/Spa...
    吕侯爷阅读 733评论 0 5
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,398评论 25 707
  • 1 要说小城和莫昆的故事应该从那年的暑假开始吧。有一天莫昆发了一条朋友圈,具体不清楚什么内容了,只记得好像在抱怨什...
    榆念芗行阅读 530评论 4 4