结尾
最后,针对上面谈的内容,给大家推荐一个Android资料,应该对大家有用。
首先是一个知识清单:(对于现在的Android及移动互联网来说,我们需要掌握的技术)
泛型原理丶反射原理丶Java虚拟机原理丶线程池原理丶
注解原理丶注解原理丶序列化
Activity知识体系(Activity的生命周期丶Activity的任务栈丶Activity的启动模式丶View源码丶Fragment内核相关丶service原理等)
代码框架结构优化(数据结构丶排序算法丶设计模式)
APP性能优化(用户体验优化丶适配丶代码调优)
热修复丶热升级丶Hook技术丶IOC架构设计
NDK(c编程丶C++丶JNI丶LINUX)
如何提高开发效率?
MVC丶MVP丶MVVM
微信小程序
Hybrid
Flutter
接下来是资料清单:(敲黑板!!!)
1.数据结构和算法
2.设计模式
3.全套体系化高级架构视频;七大主流技术模块,视频+源码+笔记
4.面试专题资料包(怎么能少了一份全面的面试题总结呢~)
不论遇到什么困难,都不应该成为我们放弃的理由!共勉~
如果你看到了这里,觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言。一定会认真查询,修正不足。谢谢。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
import android.content.Intent;
import android.content.SharedPreferences;
import android.util.Log;
import com.jumanyi.merchant.BaseConstants;
import com.xiaomi.mipush.sdk.MiPushCommandMessage;
import com.xiaomi.mipush.sdk.MiPushMessage;
import com.xiaomi.mipush.sdk.PushMessageReceiver;
// Step 2. 重写PushMessageReceiver
public class XiaoMiMessageReceiver extends PushMessageReceiver {
//日志标签
public static final String TAG=XiaoMiMessageReceiver.class.getCanonicalName();
//通知点击事件
@Override
public void onNotificationMessageClicked(Context context, MiPushMessage miPushMessage) {
super.onNotificationMessageClicked(context, miPushMessage);
Log.i(TAG, “=============onNotificationMessageClicked:”+miPushMessage.toString());
//此处的data 可能是服务端传过来的参数
String data = miPushMessage.getExtra().toString();
//点击通知 拉起应用首页,此处能解决我遇到的问题
try{
ComponentName componentName = new ComponentName(context.getPackageName(),“com.jumanyi.merchant.MainActivity”);
Intent intent=new Intent();
//新开一个任务栈,这样当应用处于前台,再次打开MainActivity会走 NewIntent 方法
//当应用处于杀死状态,会走onCreate方法
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
intent.setComponent(componentName);
if(data!=null){
intent.putExtra(BaseConstants.Extras,data);//存入参数
}
context.startActivity(intent);
}catch (Exception e){
Log.i(TAG, “=============Exception:”+e.toString());
}
}
//注册结果监听
@Override
public void onReceiveRegisterResult(Context context, MiPushCommandMessage message) {
super.onReceiveRegisterResult(context, message);
Log.i(TAG, “=============onReceiveRegisterResult:”+message.toString());
//当注册结果到来的时候,我把它存入共享参数
if(message!=null&&message.getCommandArguments()!=null&&message.getCommandArguments().size()>0){
//保存RegisId
saveRegisterId(context,message.getCommandArguments().get(0));
}
}
//保存参数
private void saveRegisterId(Context context,String regId){
if(null==context||regId.isEmpty())return;
//覆盖模式
SharedPreferences preferences = context.getSharedPreferences(BaseConstants.DATA_Reg,Context.MODE_PRIVATE);
SharedPreferences.Editor editor= preferences.edit();
editor.putString(BaseConstants.RegIdTag,regId);
editor.commit();
}
///华丽的分割线
//通知到来监听
//应用在前台时不弹出通知的通知消息到达客户端时也会回调函数
@Override
public void onNotificationMessageArrived(Context context, MiPushMessage miPushMessage) {
super.onNotificationMessageArrived(context, miPushMessage);
Log.i(TAG, “=============onNotificationMessageArrived:”+miPushMessage.toString());
}
@Override
public void onRequirePermissions(Context context, String[] strings) {
super.onRequirePermissions(context, strings);
Log.i(TAG, “=============onRequirePermissions:”+strings.toString());
}
//透传消息
@Override
public void onReceivePassThroughMessage(Context context, MiPushMessage miPushMessage) {
super.onReceivePassThroughMessage(context, miPushMessage);
Log.i(TAG, “=============onReceivePassThroughMessage:”+miPushMessage.toString());
}
@Override
public void onCommandResult(Context context, MiPushCommandMessage miPushCommandMessage) {
super.onCommandResult(context, miPushCommandMessage);
Log.i(TAG, “=============onCommandResult:”+miPushCommandMessage.toString());
}
}
Step3 配置清单文件与服务
权限
<permission android:name=“com.jumanyi.merchant.permission.MIPUSH_RECEIVE”
android:protectionLevel=“signature”/>
替换 AndroidManifest.xml 文件中的 application 之前为:io.flutter.app.FlutterApplication
android:name=“com.jumanyi.merchant.base.BaseApp”
服务
<service
android:name=“com.xiaomi.push.service.XMPushService”
android:enabled=“true”
android:process=“:pushservice” />
<service
android:name=“com.xiaomi.push.service.XMJobService”
android:enabled=“true”
android:exported=“false”
android:permission=“android.permission.BIND_JOB_SERVICE”
android:process=“:pushservice” />
<service
android:name=“com.xiaomi.mipush.sdk.PushMessageHandler”
android:enabled=“true”
android:exported=“true” />
<service
android:name=“com.xiaomi.mipush.sdk.MessageHandleService”
android:enabled=“true” />
<receiver
android:name=“com.xiaomi.push.service.receivers.NetworkStatusReceiver”
android:exported=“true”>
<receiver
android:name=“com.xiaomi.push.service.receivers.PingReceiver”
android:exported=“false”
android:process=“:pushservice”>
<receiver
android:name=“com.jumanyi.merchant.miMsg.XiaoMiMessageReceiver”
android:exported=“true”>
Step4 MainActivity 逻辑
初始化通信通道
在 onCreate 方法中初始化。当 getIntent 有值的时候,将值存入共享参数。
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//注册通信通道
//注册事件通道
new EventChannel(getFlutterEngine().getDartExecutor().getBinaryMessenger(), BaseConstants.PUSH_MSG_EVENT_CHANEL).setStreamHandler(
new EventChannel.StreamHandler() {
@Override
public void onListen(Object arguments, EventChannel.EventSink events) {
//初始化
eventSink = events;
}
@Override
public void onCancel(Object arguments) {
}
}
);
//注册方法通道
new MethodChannel(
getFlutterEngine().getDartExecutor().getBinaryMessenger(), BaseConstants.PUSH_MSG_METHOD_CHANEL
).setMethodCallHandler(
new MethodChannel.MethodCallHandler() {
@Override
public void onMethodCall(@NonNull MethodCall call, @NonNull MethodChannel.Result result) {
if (call.method.equals(“getReciveData”)) {
String content = getPushRecevieMsg();
result.success(content);
} else if (call.method.equals(“getXiaoMiRegId”)) {
String regId = getRegId();
if (!regId.isEmpty()) {
result.success(regId);
}else {
result.success(“没有获取到RegId”);
}
} else {
result.notImplemented();
}
}
}
);
//存贮 从被杀死的应用点击通知,传进来的参数
saveIntentData(getIntent());
}
//存储消息的逻辑
private void saveIntentData(Intent intent) {
if (null != intent && intent.getExtras() != null && intent.getStringExtra(BaseConstants.Extras) != null) {
String content = intent.getStringExtra(BaseConstants.Extras);
Log.i(TAG, "save receive data from push, data = " + content);
SharedPreferences preferences = getSharedPreferences(BaseConstants.DATA_Push, Context.MODE_PRIVATE);
SharedPreferences.Editor editor = preferences.edit();
editor.putString(BaseConstants.PushTag, content);
editor.commit();
} else {
Log.i(TAG, “存储消息错误”);
}
}
重写 onNewIntent 方法
应用处于前台,点击通知后会走该方法,拿到参数后通过 EventChannel 把数据发给 Flutter。
@Override
protected void onNewIntent(@NonNull Intent intent) {
super.onNewIntent(intent);
Log.i(TAG, intent.toString());
//应用处于前台时,直接通过eventChanel 通知flutter
//获取intentData
getIntentData(intent);
}
//获取intentData
private void getIntentData(Intent intent) {
if (null != intent && intent.getExtras() != null && intent.getStringExtra(BaseConstants.Extras) != null) {
String content = intent.getStringExtra(BaseConstants.Extras);
Log.i(TAG, "save receive data from push, data = " + content);
pushMsgEvent(content);
} else {
Log.i(TAG, “intent is null”);
}
}
//发送消息至flutter
private void pushMsgEvent(String content) {
new Handler().postDelayed(
new Runnable() {
@Override
public void run() {
if (eventSink != null) {
eventSink.success(content);
}
}
}
, 500);
}
Flutter 调用 Android 方法的实现
获取 RegisterId 和推送参数。
///获取消息逻辑
private String getPushRecevieMsg() {
SharedPreferences preferences = getSharedPreferences(BaseConstants.DATA_Push, Context.MODE_PRIVATE);
String data = preferences.getString(BaseConstants.PushTag, “”);
SharedPreferences.Editor editor = preferences.edit();
//清理数据
if (!data.isEmpty()) {
editor.remove(BaseConstants.PushTag);
editor.commit();
最后
文章不易,如果大家喜欢这篇文章,或者对你有帮助希望大家多多点赞转发关注哦。文章会持续更新的。绝对干货!!!
- Android进阶学习全套手册
关于实战,我想每一个做开发的都有话要说,对于小白而言,缺乏实战经验是通病,那么除了在实际工作过程当中,我们如何去更了解实战方面的内容呢?实际上,我们很有必要去看一些实战相关的电子书。目前,我手头上整理到的电子书还算比较全面,HTTP、自定义view、c++、MVP、Android源码设计模式、Android开发艺术探索、Java并发编程的艺术、Android基于Glide的二次封装、Android内存优化——常见内存泄露及优化方案、.Java编程思想 (第4版)等高级技术都囊括其中。
-
Android高级架构师进阶知识体系图
关于视频这块,我也是自己搜集了一些,都按照Android学习路线做了一个分类。按照Android学习路线一共有八个模块,其中视频都有对应,就是为了帮助大家系统的学习。接下来看一下导图和对应系统视频吧!!!
-
Android对标阿里P7学习视频
- BATJ大厂Android高频面试题
这个题库内容是比较多的,除了一些流行的热门技术面试题,如Kotlin,数据库,Java虚拟机面试题,数组,Framework ,混合跨平台开发,等
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
模式、Android开发艺术探索、Java并发编程的艺术、Android基于Glide的二次封装、Android内存优化——常见内存泄露及优化方案、.Java编程思想 (第4版)等高级技术都囊括其中。
[外链图片转存中…(img-Td7HEyKy-1715017310882)]
-
Android高级架构师进阶知识体系图
关于视频这块,我也是自己搜集了一些,都按照Android学习路线做了一个分类。按照Android学习路线一共有八个模块,其中视频都有对应,就是为了帮助大家系统的学习。接下来看一下导图和对应系统视频吧!!!
[外链图片转存中…(img-5mUZr5D6-1715017310883)] -
Android对标阿里P7学习视频
[外链图片转存中…(img-xtTqwDc7-1715017310883)]
- BATJ大厂Android高频面试题
这个题库内容是比较多的,除了一些流行的热门技术面试题,如Kotlin,数据库,Java虚拟机面试题,数组,Framework ,混合跨平台开发,等
[外链图片转存中…(img-hgnfLRCa-1715017310883)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!