android进阶_android进阶解密 - CSDN
精华内容
参与话题
  • 经常在群里听到大家对Android抱有一些消极的态度,想要换个方向,但是如果换个方向就能变成大牛的话,那大家都换就好了。其实任何方向都存在”二八“定律,总有20%混的很好...
        

    经常在群里听到大家对Android抱有一些消极的态度,想要换个方向,但是如果换个方向就能变成大牛的话,那大家都换就好了。


    其实任何方向都存在”二八“定律,总有20%混的很好的人,我们要努力成为那20%,所以对自己的要求要逐渐提高,走出舒适区,尝试破局!


    现在已经不能停留在熟练使用RxJava,Retrofit,OkHttp以及各种图片库了,而是要源码级彻底掌握他们。要清楚,一个库再牛逼,那也是作者牛逼,所以我们要尽可能懂其中的原理。


    给大家几个建议哈,首先要耐得住寂寞,不要被外界所干扰;其次要制定长期系统的学习计划并持之以恒;最后,注意学习方式,不要休闲式学习,很多人只看书看博客,但是从来不去动手实践一下,那理解肯定不会太深刻,时间久了就容易忘。


    下面给大家推荐一个网易云的免费直播课程,包含一些库的深度剖析,应该对大家有用。免费福利:



    福利1


    《Android进阶免费直播课》

    适听人群:Android初、中级开发工程师

    4.23-4.29连续7天每晚8点准时直播

    1.4月23日 走进面向接口编程,实战多样式Adapter架构

    2.4月24日 OkHttp网络访问框架原理解析(请求队列处理,重试机制)

    3.4月25日 解密通信框架领域独秀LiveDataBus

    4.4月26日 面试必考:图片缓存框架原理(逐行剖析、来龙去脉、了然于心)

    5.4月27日 高性能NIO编程详解,实现无服务器文件传输

    6.4月28日 解耦的套路,核心的代理——手撸Retrofit核动力

    7.4月29日 BAT大型安卓项目的开发之旅-组件化架构


    福利2


    Android开发进阶资料包



    640?wx_fmt=png


    报名方式:

    扫描下方二维码添加助教小姐姐微信,

    通过审核后即可免费报名

    640?wx_fmt=jpeg

    微信号:weizhuanye056

    免费课程,名额有限,先到先得~~2_06.png

    展开全文
  • Android学习汇总,进阶之路

    千次阅读 2018-08-01 16:55:00
    学习知识汇总 1、Java se基础 1).Java基本数据类型与表达式,分支循环。 2).String和StringBuffer的使用、正则表达式。 3)....构造函数、this关键字、方法和方法的参数传递过程、static关键字、内部类。...

    学习知识汇总

    1、Java se基础

    1).Java基本数据类型与表达式,分支循环。
    2).String和StringBuffer的使用、正则表达式。
    3).面向对象的抽象,封装,继承,多态,类与对象,对象初始化和回收;构造函数、this关键字、方法和方法的参数传递过程、static关键字、内部类。
    4).对象实例化过程、方法的覆盖、final关键字、抽象类、接口、继承的优点和缺点剖析;对象的多态性:子类和父类之间的转换、抽象类和接口在多态中的应用、多态带来的好处。
    5).Java异常处理,异常的机制原理。
    6).常用的设计模式:Singleton、Template、Strategy模式。
    7).JavaAPI介绍:种基本数据类型包装类,System和Runtime类,Date和DateFomat类等。
    8).Java集合介绍:Collection、Set、List、ArrayList、LinkedList、Hashset、Map、HashMap、Iterator等常用集合类API。
    9).JavaI/O输入输出流:File和FileRandomAccess类,字节流InputStream和OutputStream,字符流Reader和Writer,以及相应实现类,IO性能分析,字节和字符的转化流,包装流的概念,以及常用包装类,计算机编码。
    10).Java高级特性:反射和泛型。
    11).多线程原理:如何在程序中创建多线程(Thread、Runnable),线程安全问题,线程的同步,线程之间的通讯、死锁。

    2、android UI编程

    1)、Android开发环境搭建:Android介绍,Android开发环境搭建,第一个Android应用程序,Android应用程序目录结构。

    2)、Android初级控件的使用:

    TextView控件的使用
    Button控件的使用方法
    EditText控件的使用方法
    ImageView的使用方法
    RadioButton的使用方法
    Checkbox的使用方法
    Menu的使用方法

    3)、Android高级控件的使用:

    ListView的使用方法
    GridView的使用方法
    Adapter的使用方法
    Spinner的使用方法
    Gallary的使用方法
    ScrollView的使用方法
    RecyclerView

    4、对话框与菜单的使用:

    Dialog的基本概念
    BlockquoteAlertDialog的使用方法
    DatePickerDialog的使用方法
    Menu的使用方法
    自定义Menu的实现方法

    5.控件的布局方法:

    线性布局的使用方法
    相对布局的使用方法

    6.多Acitivity管理:

    AndroidManifest.xml文件的作用
    Intent的使用方法
    使用Intent传递数据的方法
    启动Activity的方法
    IntentFilter的使用方法
    Activity Group的使用方法

    7、自定义控件实现方法:

    自定义ListView的实现方法
    可折叠ListView的使用方法
    自定义Adapter的实现方法
    自定义View的实现方法
    动态控件布局的上实现方法
    上拉刷新下拉加载更多

    3、android网络编程与数据存储

    1).基于Android平台的HTTP通讯:

    Http协议回顾
    使用Get方法向服务器提交数据的方法
    使用POST方法向服务器提交数据的实现方法
    使用Http协议实现多线程下载
    使用Http协议实现断点续传

    2).Android数据存储技术:

    SQLite3数据库简介
    SQL语句回顾
    SQLite3编程接口介绍
    SQLite3事务管理
    SQLite3游标使用方法
    SQLite3性能分析
    访问SDCard的方法
    访问SharedPreferences的方法

     

    进阶之路(初级->中级->高级)

    1、初级工程师

    小明之前完全没接触过Android开发,是个应届生,他的待遇是13k,然后小明以校招的身份进入了百度,然后小明需要怎么学习才能成为初级工程师呢?这个时候,小明对编程基础、数据结构、C语言都有一定基础,Java语法什么的也都掌握的比较好,Android才有java语言,无奈的是小明并不会搞Android。

    小明首先需要购买一本Android入门的书籍,为了更快地学习Android,小明业余时间也都用来一边看书一边照着书中的例子敲代码,结果2周时间小明就把这本书学了一遍。看完这本书后,小明对Android的历史、结构、代码规范等都有了一个大概的了解,并且,小明已经可以写出一些简单的Activity了。这个时候在小明眼里,Android开发很简单很好玩,通过在xml中摆放一些按钮文本框什么的就可以做一些界面了。

    小明开始跟着他的技术导师做需求,一些简单的小需求小明自然是不在话下了。突然有一天来了一个需求,该需求要求小明在Activity中为一个button加一个动画效果,小明慌了:“完全没接触过,书上也没有讲,怎么办呢?”小明冷静了下,打开了百度搜索,输入“Android 动画”,打开前几个链接,小明恍然大悟,照着网上的例子把需求给实现了。后来导师告诉他:“学好Android,官方文档是必须看的,既全面又权威”。然后小明如获至宝,花了一年时间把上面的guide和training都看了一遍,并且他还动手抄了几个小例子。

    有一天,小明又需要做一个动画相关的需求,这可难不倒小明,它熟练地打开了百度一下,你就知道,输入“Android 动画”,突然他楞了一下:”总不能每次写动画都要百度一下吧!“,于是他在CSDN开了一个博客,把动画相关的知识点都写上去,为的是后面再写动画相关的代码就不用百度去搜了,事实如何呢?后面再写动画相关的代码,小明的确不用再去百度搜了,因为通过写一篇动画博客,他把动画相关的细节都已经记住了,这样他就可以不用再去参考任何文档了,后来小明还学会了把一些琐碎的不方便放在博客上的东西写到了印象笔记上面,什么时候忘了10秒钟以内都可以快速找回来,而不是花10分钟去再次搜索一遍。

    这里总结一下,Android入门的时候,需要有一本入门书,好好学习书中的内容,同时花一年时间把Android官方文档中的training和guide看一遍,同时通过写博客和记笔记的方式来做总结,建议让自己的每篇博客都有价值些。通过一年时间的学习,相信每个人都可以达到中级工程师的水平。

    技术要求:
    - 基本知识点
    比如四大组件如何使用、如何创建Service、如何进行布局、简单的自定义View、动画等常见技术
    - 书籍推荐
    《第一行代码 Android》、《疯狂Android》

    2、中级工程师

    小明经过一年的努力学习终于成为Android中级工程师了,月薪变成了17k。到了中级工程师,已经可以在公司里干很多体力活了,但是一些很重要的任务小明还不能一个人承担起来,这个时候小明需要学习的内容就很多了,如下所示:
    - AIDL:熟悉AIDL,理解其工作原理,懂transact和onTransact的区别;
    - Binder:从Java层大概理解Binder的工作原理,懂Parcel对象的使用;
    - 多进程:熟练掌握多进程的运行机制,懂Messenger、Socket等;
    - 事件分发:弹性滑动、滑动冲突等;
    - 玩转View:View的绘制原理、各种自定义View;
    - 动画系列:熟悉View动画和属性动画的不同点,懂属性动画的工作原理;
    - 懂性能优化、熟悉mat等工具
    - 懂点常见的设计模式

    学习方法

    阅读进阶书籍,阅读Android源码,阅读官方文档并尝试自己写相关的技术文章,需要有一定技术深度和自我思考。在这个阶段的学习过程中,有2个点是比较困扰大家的,一个是阅读源码,另一个是自定义View以及滑动冲突。

    如何阅读源码呢?这是个头疼的问题,但是源码必须要读。阅读源码的时候不要深入代码细节不可自拔,要关注代码的流程并尽量挖掘出对应用层开发有用的结论。另外仔细阅读源码中对一个类或者方法的注释,在看不懂源码时,源码中的注释可以帮你更好地了解源码中的工作原理,这个过程虽然艰苦,但是别无他法。

    如何玩转自定义View呢?我的建议是不要通过学习自定义view而学习自定义view。为什么这么说呢?因为自定义view的种类太多了,各式各样的绚丽的自定义效果,如何学的玩呢!我们要透过现象看本质,更多地去关注自定义view所需的知识点,这里做如下总结:
    - 搞懂view的滑动原理
    - 搞懂如何实现弹性滑动
    - 搞懂view的滑动冲突
    - 搞懂view的measure、layout和draw
    - 然后再学习几个已有的自定义view的例子
    - 最后就可以搞定自定义view了,所谓万变不离其宗

    大概再需要1-2年时间,即可达到高级工程师的技术水平。我个人认为通过《Android开发艺术探索》和《Android群英传》可以缩短这个过程为0.5-1年。注意,达到高级工程师的技术水平不代表就可以立刻成为高级工程师(受机遇、是否跳槽的影响),但是技术达到了,成为高级工程师只是很简单的事。

    技术要求:
    - 稍微深入的知识点
    AIDL、Messenger、Binder、多进程、动画、滑动冲突、自定义View、消息队列等
    - 书籍推荐
    《Android开发艺术探索》、《Android群英传》

    3、高级工程师

    小明成为了梦寐以求的高级工程师,月薪达到了20k,还拿到了一丢丢股票。这个时候小明的Android水平已经不错了,但是小明的目标是资深工程师,小明听说资深工程师月薪可以达到30k+。

    为了成为Android资深工程师,需要学习的东西就更多了,并且有些并不是那么具体了,如下所示:
    - 继续加深理解”稍微深入的知识点“中所定义的内容
    - 了解系统核心机制:
    1. 了解SystemServer的启动过程
    2. 了解主线程的消息循环模型
    3. 了解AMS和PMS的工作原理
    4. 能够回答问题”一个应用存在多少个Window?“
    5. 了解四大组件的大概工作流程
    6. …

    • 基本知识点的细节

      1. Activity的启动模式以及异常情况下不同Activity的表现
      2. Service的onBind和onReBind的关联
      3. onServiceDisconnected(ComponentName className)和binderDied()的区别
      4. AsyncTask在不同版本上的表现细节
      5. 线程池的细节和参数配置
    • 熟悉设计模式,有架构意识学习方法

    这个时候已经没有太具体的学习方法了,无非就是看书、看源码和做项目,平时多种总结,尽量将知识融会贯通从而形成一种体系化的感觉。同时这个阶段对架构是有一定要求的,架构是抽象的,但是设计模式是具体的,所以一定要加强下设计模式的学习。关于设计模式的学习,最近一本新书推荐给大家《Android 源码设计模式解析与实战》,既可以学习设计模式,又可能体会到Android源码中的设计思想,我最近也在阅读此书。

    技术要求:
    - 稍微深入的知识点
    - 系统核心机制
    - 基本知识点的细节
    - 设计模式和架构
    - 书籍推荐
    《Android开发艺术探索》、《Android 源码设计模式解析与实战》、《Android内核剖析》

     

    学习视频跟书籍

    当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的,我这里给你们整理了大概80G的学习视频跟书籍,赶快点我点我点我。。。下载。。

    转自 https://www.zhihu.com/question/30891730/answer/105245167

    展开全文
  • 最近有一个这样的小功能,动态监听App在前台运行还是后台运行,然后做对应业务逻辑操作,故此全文主讲Android app 前后台监听 ~ up ~ 提要了解入门项目进阶 - A项目进阶 - B 提要 在Android中从你打开App的那一霎那...

    最近有一个这样的小功能,动态监听App在前台运行还是后台运行,然后做对应业务逻辑操作,故此全文主讲Android app 前后台监听 ~

    提要

    在Android中从你打开App的那一霎那就已经调用了Application的基本配置,随后又调用了对应四大组件,当然在调用对应类时肯定是先走的 onCreate()生命周期了 ~

    故此在一切正式开始之前,首先我们要创建一个属于我们的Application继承于系统Application,这里我创建的是MyApplication,创建好之后将其注入到清单文件中 ~

    <?xml version="1.0" encoding="utf-8"?>
    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
        package="nk.com.activitylifecycle">
        
        <!--将我们创建好的Application在application标签内进行声明 - android:name=".MyApplication"-->
        <application
            android:name=".MyApplication"
            android:allowBackup="true"
            android:icon="@mipmap/ic_launcher"
            android:label="@string/app_name"
            android:roundIcon="@mipmap/ic_launcher_round"
            android:supportsRtl="true"
            android:theme="@style/AppTheme">
            <activity android:name=".MainActivity">
                <intent-filter>
                    <action android:name="android.intent.action.MAIN" />
    
                    <category android:name="android.intent.category.LAUNCHER" />
                </intent-filter>
            </activity>
        </application>
    
    </manifest>
    

    关于前后台监听,主要涉及三种场景

    • 用户将app放于多任务界面
    • 用户将app返回手机主页界面
    • 用户将app返回app应用内部界面

    关于前后台监听的功能,主要涉及的API:registerActivityLifecycleCallbacks(ActivityLifecycleCallbacks callback) ,从字面意思不难看出就是注册Activity生命周期的监听回调 ~

    通过Application的源码可以发现内部有注册的时候,自然少不了注销,一般这样的开闭方法都减少了内存方面可能隐藏的Bug,注销方法可以看场景使用,可以用在MainActivity销毁的时候,也可以不用 ~
    在这里插入图片描述

    嘘,还有一点要注意
    因为我们监听前后台的目的主要是要做一些业务逻辑,但是有的业务逻辑针对的是整个项目,有的业务逻辑可能只是针对某一个或者某几个类,所以当业务逻辑涉及到仅仅某些类的话,可以采用接口回调或者EventBus进行事件处理 ~ 个人建议是采用EventBus,因为接口回调有些朋友容易绕晕,同时代码会冗余较多,而EventBus的话发展至今已经比较完善了,所以为自己少点烦恼 ~

    了解

    以下代码是一个最简单的实现,你通过切换App场景可以发现已经实现了监听前后台的功能,但是!它是存在很严重的缺陷!当我们存在多个Activity且相互进行跳转的时候,通过Log可以发现频繁的调用了生命周期的监听方法 ~ 故此方法只用于基础理解,可以在看下方入门 ~

    Look here:频繁调用方法,也就意味着内部的逻辑也会重复调用,从而大大增加了bug率 ~

    package nk.com.activitylifecycle;
    
    import android.app.Activity;
    import android.app.Application;
    import android.os.Bundle;
    import android.util.Log;
    
    /**
     * @author MrLiu
     * @date 2020/10/12
     * desc
     */
    public class MyApplication extends Application {
        @Override
        public void onCreate() {
            super.onCreate();
            
            //监听Activity生命周期
            registerActivityLifecycleCallbacks(new ActivityLifecycleCallbacks() {
    
                //当前Activity个数
                private int activityNumber = 0;
    
                @Override
                public void onActivityCreated(Activity activity, Bundle bundle) {
    
                }
    
                @Override
                public void onActivityStarted(Activity activity) {
                   Log.e("tag", "ActivityLifecycleCallbacksAdapter:后台 --> 前台");
                }
    
                @Override
                public void onActivityResumed(Activity activity) {
    
                }
    
                @Override
                public void onActivityPaused(Activity activity) {
    
                }
    
                @Override
                public void onActivityStopped(Activity activity) {
                   Log.e("tag", "ActivityLifecycleCallbacksAdapter:前台 --> 后台");
                }
    
                @Override
                public void onActivitySaveInstanceState(Activity activity, Bundle bundle) {
    
                }
    
                @Override
                public void onActivityDestroyed(Activity activity) {
    
                }
            });
        }
    }
    

    入门

    与上方的不同点在于监听前后台切换时,如果用户多Activity切换的话就不会被重复调用切后台监听内的逻辑方法,从而减少了部分bug,但是此入门方式仅仅解决了最基础的需求,如果在项目中使用的话还可以在优化一下,不过还是先看入门,然后在继续往进阶看吧~

    package nk.com.activitylifecycle;
    
    import android.app.Activity;
    import android.app.Application;
    import android.os.Bundle;
    import android.util.Log;
    
    /**
     * @author MrLiu
     * @date 2020/10/12
     * desc
     */
    public class MyApplication extends Application {
    
        @Override
        public void onCreate() {
            super.onCreate();
    
            this.registerActivityLifecycleCallbacks(new ActivityLifecycleCallbacks() {
    
                private int activityNumber = 0;
    
                @Override
                public void onActivityCreated(Activity activity, Bundle bundle) {
    
                }
    
                @Override
                public void onActivityStarted(Activity activity) {
                    if (activityNumber++ == 0) {
                        Log.e("tag", "app回到前台");
                        Log.e("tag", "activityNumber = " + activityNumber);
                    }
                }
    
                @Override
                public void onActivityResumed(Activity activity) {
    
                }
    
                @Override
                public void onActivityPaused(Activity activity) {
    
                }
    
                @Override
                public void onActivityStopped(Activity activity) {
                    if (--activityNumber == 0) {
                        // app回到后台
                        Log.e("tag", "app回到后台");
                        Log.e("tag", "activityNumber = " + activityNumber);
                    }
                }
    
                @Override
                public void onActivitySaveInstanceState(Activity activity, Bundle bundle) {
    
                }
    
                @Override
                public void onActivityDestroyed(Activity activity) {
    
                }
            });
        }
    }
    

    项目进阶 - A

    与上方的不同在于对Application内方法进行了抽离,内部使用了单例模式,减少了内存开销,同时将该业务进行了剥离,算是一个代码优化把 - -,这个阶段的代码基本可以投入项目使用了

    LifecycleMonitor

    package nk.com.activitylifecycle;
    
    import android.app.Activity;
    import android.app.Application;
    import android.os.Bundle;
    import android.util.Log;
    
    /**
     * @author MrLiu
     * @date 2020/10/12
     * desc
     */
    public class LifecycleMonitor {
    
        private int resumeActivityCount = 0;
    
        private static LifecycleMonitor lifecycleHelper;
    
        public static LifecycleMonitor getInstance() {
            if (lifecycleHelper == null) {
                lifecycleHelper = new LifecycleMonitor();
            }
            return lifecycleHelper;
        }
    
        public void register(Application application) {
            if (application != null)
            	//这里对ActivityLifecycleCallbacksAdapter进行了二次包装,不必实现原有的抽象方法,仅需实现我们需要的方法即可!
                application.registerActivityLifecycleCallbacks(new ActivityLifecycleCallbacksAdapter() {
                    @Override
                    public void onActivityStarted(Activity activity) {
                        if (resumeActivityCount++ == 0) {
                            // 执行切换到前台的逻辑
                            Log.e("tag", "后台 --> 前台" + resumeActivityCount);
                            // ... 使用EventBus传递数据
                        }
                    }
    
                    @Override
                    public void onActivityStopped(Activity activity) {
                        if (--resumeActivityCount == 0) {
                            // 执行切换到后台的逻辑
                            Log.e("tag", "前台 --> 后台" + resumeActivityCount);
                            // ... 使用EventBus传递数据
                        }
                    }
                });
        }
    
        /**
         * Activity 生命周期监听,用于监控app前后台状态切换(对应Activity生命周期)
         */
        public static class ActivityLifecycleCallbacksAdapter implements Application.ActivityLifecycleCallbacks {
    
            @Override
            public void onActivityCreated(Activity activity, Bundle bundle) {
            }
    
            @Override
            public void onActivityStarted(Activity activity) {
            }
    
            @Override
            public void onActivityResumed(Activity activity) {
            }
    
            @Override
            public void onActivityPaused(Activity activity) {
            }
    
            @Override
            public void onActivityStopped(Activity activity) {
            }
    
            @Override
            public void onActivitySaveInstanceState(Activity activity, Bundle bundle) {
            }
    
            @Override
            public void onActivityDestroyed(Activity activity) {
            }
        }
    }
    

    MyApplication

    package nk.com.activitylifecycle;
    
    import android.app.Activity;
    import android.app.Application;
    import android.os.Bundle;
    import android.util.Log;
    
    /**
     * @author MrLiu
     * @date 2020/10/12
     * desc
     */
    public class MyApplication extends Application {
    
        @Override
        public void onCreate() {
            super.onCreate();
            LifecycleMonitor.getInstance().register(this);
        }
    }
    

    项目进阶 - B

    与上方相比,此处调用主要采取了static的方式进行调用,同时加入了内部的俩个监听回调(个人感觉有点画蛇添足,但是从一定层面其实有达到了解耦的效果,所以仁者见仁智者见智咯),可能这个方法不是最好的,但是对于我这种懒人可能是最合适的 ~ 所以当前代码也可投入项目使用 ~

    AppStateTracker

    package nk.com.activitylifecycle;
    
    import android.app.Activity;
    import android.app.Application;
    import android.os.Bundle;
    import android.util.Log;
    
    /**
     * @author MrLiu
     * @date 2020/10/10
     * desc
     */
    public class AppStateMonitor {
        public static final int STATE_FOREGROUND = 0;
    
        public static final int STATE_BACKGROUND = 1;
    
        private static int currentState;
    
        public static int getCurrentState() {
            return currentState;
        }
    
        public interface AppStateChangeListener {
            void appTurnIntoForeground();
    
            void appTurnIntoBackGround();
        }
    
        public static void track(Application application, final AppStateChangeListener appStateChangeListener) {
    
            application.registerActivityLifecycleCallbacks(new SimpleActivityLifecycleCallbacks() {
    
                private int resumeActivityCount = 0;
    
                @Override
                public void onActivityStarted(Activity activity) {
    //                if (resumeActivityCount == 0) {
    //                    currentState = STATE_FOREGROUND;
    //                    appStateChangeListener.appTurnIntoForeground();
    //                }
    //                resumeActivityCount++;
    
                    if (resumeActivityCount++ == 0) {
                        currentState = STATE_FOREGROUND;
                        appStateChangeListener.appTurnIntoForeground();
                    }
                }
    
    
                @Override
                public void onActivityStopped(Activity activity) {
    //                resumeActivityCount--;
    //                if (resumeActivityCount == 0) {
    //                    currentState = STATE_BACKGROUND;
    //                    appStateChangeListener.appTurnIntoBackGround();
    //                }
                    
                    if (--resumeActivityCount == 0) {
                        currentState = STATE_BACKGROUND;
                        appStateChangeListener.appTurnIntoBackGround();
                    }
                }
            });
        }
    
        private static class SimpleActivityLifecycleCallbacks implements Application
                .ActivityLifecycleCallbacks {
    
            @Override
            public void onActivityCreated(Activity activity, Bundle bundle) {
    
            }
    
            @Override
            public void onActivityStarted(Activity activity) {
    
            }
    
            @Override
            public void onActivityResumed(Activity activity) {
    
            }
    
            @Override
            public void onActivityPaused(Activity activity) {
    
            }
    
            @Override
            public void onActivityStopped(Activity activity) {
    
            }
    
            @Override
            public void onActivitySaveInstanceState(Activity activity, Bundle bundle) {
    
            }
    
            @Override
            public void onActivityDestroyed(Activity activity) {
    
            }
        }
    }
    

    MyApplication

    package nk.com.activitylifecycle;
    
    import android.app.Application;
    import android.util.Log;
    
    /**
     * @author MrLiu
     * @date 2020/10/12
     * desc
     */
    public class MyApplication extends Application {
    
        @Override
        public void onCreate() {
            super.onCreate();
    
            AppStateMonitor.track(this, new AppStateMonitor.AppStateChangeListener() {
                @Override
                public void appTurnIntoForeground() {
                    // 处理app到前台的逻辑
                    Log.e("tag", "App - 处于前台");
                }
    
                @Override
                public void appTurnIntoBackGround() {
                    // app处理到到后台的逻辑
                    Log.e("tag", "App - 处于后台");
                }
            });
        }
    }
    

    小课堂

    因为监听的去重方式使用到了++、–故此科普一下自增++、自减-- 前后位置作用

    自加(++)自减(–)运算
    自加: ++
    对原有的数据进行+1
    自减:- -
    对原有的数据进行-1

    使用场景

    • 单独使用
      放在操作数的前面和后面效果一样(这种用法是我们比较常见的)
    • 参与运算使用
      放在操作数的前面(++1||- -1),先自增或者自减,然后再参与运算
      放在操作数的后面(1++||1- -),先参与运算,再自增或者自减

    在查询监听前后台的功能实现时 也查到了以下的这种方法,此方法主要是在监听BaseActivity内的生命周期,理论上也是可行的,但是我并没有亲自尝试,故此当做饭后甜点吧 ~

    不过有人指出在Android6.0的机器上,在某些情景下使用无法获取到当前正在运行的包名,如在屏幕暗下后,使用下方代码中的isAppOnForeground方法内的获取进程的方法后,可能会获取不到正确的进程列表 ~

    public class BaseActivity extends Activity {
     	//全局变量
        public static boolean isActive; 
     
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_base);
        }
     
        @Override
        protected void onResume() {
            if (!isActive) {
                //app 从后台唤醒,进入前台
                isActive = true;
                Log.i("ACTIVITY", "程序从后台唤醒");
            }
            super.onResume();
        }
     
        @Override
        protected void onStart() {
            super.onStart();
        }
     
        @Override
        protected void onPause() {
            super.onPause();
        }
     
        @Override
        protected void onStop() {
            if (!isAppOnForeground()) {
                //app 进入后台
                isActive = false;//记录当前已经进入后台
                Log.i("ACTIVITY", "程序进入后台");
            }
            super.onStop();
        }
     
        @Override
        protected void onDestroy() {
            super.onDestroy();
        }
     
        /**
         * APP是否处于前台唤醒状态
         *
         * @return
         */
        public boolean isAppOnForeground() {
            ActivityManager activityManager = (ActivityManager) getApplicationContext().getSystemService(Context.ACTIVITY_SERVICE);
            String packageName = getApplicationContext().getPackageName();
            List<ActivityManager.RunningAppProcessInfo> appProcesses = activityManager.getRunningAppProcesses();
                    
            if (appProcesses == null)
                return false;
     
            for (ActivityManager.RunningAppProcessInfo appProcess : appProcesses) {
                // The name of the process that this object is associated with.
                if (appProcess.processName.equals(packageName)
                        && appProcess.importance == ActivityManager.RunningAppProcessInfo.IMPORTANCE_FOREGROUND) {
                    return true;
                }
            }
            return false;
        }
    }
    

    查询当前进程名

    根据功能查询到早期处理方式,也可以使用getRunningTasks,不过后来随着更新此方式已经废弃!然后又有了通过getRunningTasks和RunningAppProcessInfo结合的处理方式(兼容API22+和API22-),不过有人说这种方法在Android6.0的机器黑屏时获取不到正确的进程列表 ~ 所以还是 建议使用上方的项目进阶 A 和 B 把 ~

    /**
         * 查询当前进程名
         * 
         * @param context
         * @return
         */
        public static String getCurrentPkgName(Context context) {
            ActivityManager am = (ActivityManager) context
                    .getSystemService(Context.ACTIVITY_SERVICE);
            String pkgName = null;
            if (Build.VERSION.SDK_INT >= 22) {
                ActivityManager.RunningAppProcessInfo currentInfo = null;
                Field field = null;
                int START_TASK_TO_FRONT = 2;
                try {
                    field = ActivityManager.RunningAppProcessInfo.class
                            .getDeclaredField("processState");
                } catch (Exception e) {
                    e.printStackTrace();
                }
    
                List<RunningAppProcessInfo> appList = am.getRunningAppProcesses();
                for (ActivityManager.RunningAppProcessInfo app : appList) {
                    if (app.importance == ActivityManager.RunningAppProcessInfo.IMPORTANCE_FOREGROUND) {
                        Integer state = null;
                        try {
                            state = field.getInt(app);
                        } catch (Exception e) {
                            e.printStackTrace();
                        }
                        if (state != null && state == START_TASK_TO_FRONT) {
                            currentInfo = app;
                            break;
                        }
                    }
                }
                if (currentInfo != null) {
                    pkgName = currentInfo.processName;
                }
            } else {
                List<RunningTaskInfo> runTaskInfos = am.getRunningTasks(1);
                // 拿到当前运行的任务栈
                ActivityManager.RunningTaskInfo runningTaskInfo = runTaskInfos
                        .get(0);
                // 拿到要运行的Activity的包名
                pkgName = runningTaskInfo.baseActivity.getPackageName();
            }
            return pkgName;
        }
    
    展开全文
  • Android中高级进阶知识点整理

    千次阅读 2020-07-19 23:43:34
    作为Android 开发者,该怎样规划自己的学习路线,然后一步一个脚印的向高级进阶呢? 那么接下来的文章就是高级进阶,其中或者引用或者举例说明或者分析源码,总之目标是:掌握知识并且能应用知识。 一.View的绘制 ...

    作为Android 开发者,该怎样规划自己的学习路线,然后一步一个脚印的向高级进阶呢?

    那么接下来的文章就是高级进阶,其中或者引用或者举例说明或者分析源码,总之目标是:掌握知识并且能应用知识。

    一.View的绘制

    1)setContentView()的源码分析
    2)SnackBar的源码分析
    3)利用decorView机制实现底部弹出框
    4)换肤框架(一)之Support v7库解析
    5)小红书欢迎页的视差效果实现
    6)换肤框架(二)之换肤框架实现解析
    7)View和ViewGroup的绘制原理源码分析
    8)自定义ViewGroup(一)之卡牌

    二.事件的分发

    1)从场景到源码分析事件分发
    2)事件分发实例之侧滑菜单
    3)自定义behavior的源码分析
    4)玩转自定义behavior之顶部停靠

    三.动画框架

    1)属性动画的基础使用方法
    2)属性动画源码分析(Choreographer"编舞者")
    3)直播间气泡效果
    4)共享元素转场动画

    四.Handler机制[will be written by Ticoo]

    1)Handler,MessageQueue,与Looper三者关系分析
    2)HandlerThread源码分析
    3)IntentService源码分析
    4)Handler常见应用场景和常见问题分析

    五.Binder机制

    1)从framework分析AIDL生成文件

    六.流行框架源码分析

    1)EventBus3.0源码解析
    2)AsynTask源码分析
    3)编译期注解的使用例子分析
    4)Butterknife源码分析(一)
    5)Butterknife源码分析(二)
    6)多进程的sharedprefrence解决方案DPreference
    7)Volley源码解析
    8)OkHttp源码分析
    9)Retrofit2源码解析
    10)AOP在代码中的使用分析
    11)Builder建造者设计模式
    12)Observer观察者设计模式
    13)责任链设计模式
    14)Proxy代理设计模式
    15)Strategy策略模式
    16)Decorator装饰模式
    17)英语流利说文件下载器源码解析

    七.性能优化[will be written by 无心追求 and ZJ_Rocky]

    1)冷启动优化
      1.1.APP启动分析工具(TraceView,Systrace)
      1.2.布局优化(扁平化,Merge的使用,ViewStub的使用)
      1.3.APP启动速度优化实例解析
      1.4.各种布局的性能对比(LinerLayout,RelativeLayout)
    2)内存优化
      2.1.LeakCanary原理分析
      2.2.Android DiskLruCache 源码解析 硬盘缓存的绝佳方案[转]
      2.3.LruCache源码分析
      2.4.内存泄漏的一些坑
      2.5.MAT内存泄漏分析(一)
     2.6.MAT内存泄漏分析(二)
    3)网络优化
    4)图片压缩性能优化
    5)数据传输性能优化
    6)减小APK体积
    7)渲染优化
      7.1.UI卡顿原理分析
      7.2.UI卡顿检测分析
      7.3.BlockCanary原理分析
      7.4.卡顿优化实例解析
    8)电量优化
      8.1.APP耗电分析方法与工具(第三方,Google官方Battery Historian)
      8.2.Android Doze源码分析
      8.3.AlarmManager研究 [转]
      8.4.在Android Lollipop中使用JobScheduler
      8.5.JobScheduler的源码分析
      8.6.耗电优化实例解析
    9)Android ANR在线监控原理
    10)AndroidGodEye解析之帧率(fps)
    11)AndroidGodEye解析之流畅度(sm)
    12)即将推出GodEye的分析,敬请期待...

    八.网络编程[will be written by 无心追求and ZJ_Rocky]

    1.TCP问题分析
    2.OkHttp源码分析
    3.网络传输数据加密策略(对称加密AES,DES,非对称加密RSA)
    4.二进制协议(mqtt协议),协议编解码(tlv编解码)
    5.Java Socket编程(IO,NIO)
    6.Java多线程编程(队列,同步锁,线程池)
    7.Android中使用HttpDns

    九.Android推送SDK[will be written by 无心追求]

    1.SDK架构设计
    2.心跳策略
    3.重连策略
    4.tcpdump抓包分析
    5.进程保活
    6.多进程通信
    7.TCP连接多路复用
    8.Android系统休眠
    9.TCP网络问题
    10.DHCP租约到期自动续租问题导致TCP连接异常

    十.FrameWork层源码的分析

    1)应用程序内Activity的启动流程
    2)startService的流程分析
    3 ) 注册广播接收器的源码分析
    4)广播发送过程源码解析
    5)广播处理过程源码解析
    6)AssetManager加载资源过程
    7)ClassLoader及dex加载过程
    8)插件化框架VirtualApk之初始化
    9)插件化框架VirtualApk之插件加载
    10)插件化框架VirtualApk之Activity启动
    11)插件化框架VirtualApk之Service管理
    12)热修复框架AndFix完全解析
    13)InstantRun源码分析[转]
    14)Google新组件下的架构思考

    十一.Launcher3桌面开发[will be written by Ticoo]

    1)Launcher3桌面开发简述
    2)Launcher3 桌面加载流程分析(上)
    3)Launcher3 桌面加载流程分析(下)
    4)Launcher3 抽屉型桌面改造成横屏桌面
    5)Launcher3 负一屏的定制开发
    6)Launcher3 添加主题功能
    7)Launcher3 添加左右滑动特效

     

    资源集

    文章

    官方

    面试题集

    数据结构与算法

    安卓App热补丁动态修复

    多渠道打包

    面试经验

    简历模板

     

    展开全文
  • 2016年我开始建立了自己的知识体系,所有的文章都是围绕着这个体系来写,随着这个体系的慢慢成长,开始有很多出版社联系我写书,因为比较看好电子工业出版社,就顺理成章的开始了《Android进阶之光》这本书的编写。...
  • 在家修复 wanandroid bug,顺便更新一些优质博客内容,把所有 Android 领域方向的...作者的出发点是针对网上那么多的资料和博文,希望能够整理出一篇完备的 Android进阶知识图谱;https://github.com/feelschaotic/A...
  • 首先声明,下面文字转载于:APK瘦身实践http://www.jayfeng.com/2015/12/29/APK%E7%98%A6%E8%BA%AB%E5%AE%9E%E8%B7%B5/APP终极瘦身指南http://www.jayfeng.com/2016/03/01/Android-APP%...
  • Android进阶二部曲第一部《Android进阶之光》介绍 :点击这里 ...Android进阶二部曲包括《Android进阶之光》和本书,因此写这本书的原因和《Android进阶之光》有些关联,主要有以下几点: 《Android进阶之...
  • 这本书是Android进阶三部曲的第三部,书名叫《Android进阶指北》,内容算是对前两本的补充。其实我一直想在书中建立一个知识体系,但是凭借进阶之光和进阶解密是形成不了成规模的知识体系的,而进阶指北的出版将会...
  • Android进阶

    2018-05-23 13:30:49
    https://github.com/JsonChao/Awesome-Android-Exercise
  • 1.第三本书《进阶指北》今天完稿了 耗时1年半,我的第三本书《进阶指北》终于在今天完稿了。前两本书每本都是耗时1年左右,完成这本书的时间增加了些,主要还是自己懒癌犯了,这里跟大家说声抱歉,让大家久等了。...
  • Android 进阶

    2017-12-13 16:01:23
    这是最好的Android相关原创知识体系(100+篇)知识体系从2016年开始构建,所有的文章都是围绕着这个知识体系来写,目前共收入了100多篇原创文章,其中有一部分未收入的文章在我的新书《Android进阶之光》中。...
  • 高清彩版 Android 进阶之光
  • android进阶

    2019-02-15 10:46:55
    进阶 想必也有很多朋友对阿里推出的X-Deep Learning提不起特别大的兴致。之前就有腾讯发布的开源框架QMUI_Android ,最近又有很热门的谷歌开源的flutter框架喊着大家去学,难免会产生疲劳感。尤其是现在行业不景气...
  • Android进阶三部曲第一部《Android进阶之光》介绍 :点击这里 本书源码地址:github.... 为什么写这本书 Android进阶三部曲包括《Android进阶之光》和本书,因此写这本书的原因和《Android进阶之光》有些...
  • Android 进阶之光笔记

    2018-07-06 16:39:07
    1 View 的事件分发机制–TouchEvent从顶层传递到底层: ... 但viewGroup中的child数组-数组中元素是同层的,高标号的是最子层(视觉上,布局文件上顺序)的view,也就是说底层的是ViewGroup,顶层的是控件。...
  • Android 面试题总结之Android 进阶(一)

    万次阅读 多人点赞 2016-06-08 16:28:51
    Android 面试题总结之Android 进阶(一) 在前几篇文章中都是讲的基础,大家应该会觉得非常熟悉,但往往我们可能对于基础某些细节认识不够彻底或贯穿不全,我一直认为基础都是比较难的,那么本章节终于到进阶啦,...
  • 》,整理了Android开发中的一些知识点,包括Java基础、Android基础、Android进阶、开源框架和工具类库等几个大的方面。罗列了其中的包含的知识点,文章有点长,覆盖了Android 知识面较广,为了将各个知识点梳理得更...
  • Android进阶知识点

    2018-01-09 10:04:18
    Activity、View、Window的理解,Activity 是如何生成一个 view 的? 1)Activity在attch方法的时候,会创建一个phonewindow(window的子类) 2)onCreate中的setContentView方法,会创建DecorView ...
1 2 3 4 5 ... 20
收藏数 45,273
精华内容 18,109
关键字:

android进阶