12-14 13:45:03.313 21756-21756/? I/lgq: builertttt===李四…18
3、单例模式的实现步骤
===========
1、静态实例
2、私有化构造方法
3、静态获取实例的函数,双重null判断synchronize同步处理——
使用synchronized 进行同步处理,并且双重判断是否为null,我们看到synchronized (Singleton.class)里面又进行了是否为null的判断,这是因为一个线程进入了该代码,如果另一个线程在等待,这时候前一个线程创建了一个实例出来完毕后,另一个线程获得锁进入该同步代码,实例已经存在,没必要再次创建,因此这个判断是否是null还是必须的。
public class Singleton {
private static volatile Singleton instance = null;
private Singleton(){
}
public static Singleton getInstance() {
if (instance == null) {
synchronized (Singleton.class) {
if (instance == null) {
instance = new Singleton();
}
}
}
return instance;
}
}
activity管理类
public class ActivityManager {
private static volatile ActivityManager instance;
private Stack mActivityStack = new Stack();
private ActivityManager(){
}
public static ActivityManager getInstance(){
if (instance == null) {
synchronized (ActivityManager.class) {
if (instance == null) {
instance = new ActivityManager();
}
}
return instance;
}
public void addActicity(Activity act){
mActivityStack.push(act);
}
public void removeActivity(Activity act){
mActivityStack.remove(act);
}
public void killMyProcess(){
int nCount = mActivityStack.size();
for (int i = nCount - 1; i >= 0; i–) {
Activity activity = mActivityStack.get(i);
activity.finish();
}
mActivityStack.clear();
android.os.Process.killProcess(android.os.Process.myPid());
}
}
4、观察者模式
=======
主要三个类
1、
public interface Observer {
void update(int id,String param);
}
2、
public interface Subject {
/**
* 注册一个观察者
*/
void addObserver(Observer observer);
/**
* 删除一个观察者
*
* @return 是否删除成功
*/
boolean removeObserver(Observer observer);
/**
* 通知所有的观察者
*
* @param id 对应观察者的id
*/
void notifyObserver(int id,String param);
}
3、
public class TestObServernotice implements Subject {
private static Subject subject;
private List observers = new ArrayList<>();
private TestObServernotice() {
// TODO Auto-generated constructor stub
}
public static Subject getInstance() {
if (null == subject) {
synchronized (TestObServernotice.class) {
if (null == subject)
subject = new TestObServernotice();
}
}
return subject;
}
@Override
public void addObserver(Observer observer) {
// TODO Auto-generated method stub
observers.add(observer);
}
@Override
public boolean removeObserver(Observer observer) {
// TODO Auto-generated method stub
return observers.remove(observer);
}
@Override
public void notifyObserver(int id,String param) {
// TODO Auto-generated method stub
for (Observer observer : observers) {
observer.update(id,param);
}
}
}
观察者中注册Observer,如MainActivity中注册
private Observer deleteObserver = new Observer() {
@Override
public void update(int id,String param) {
tomapte.setText(“sssssymd”+param);//dosomething
}
};
TestObServernotice.getInstance().addObserver(deleteObserver);
同时注意删除观察者
@Override
protected void onDestroy() {
super.onDestroy();
TestObServernotice.getInstance().removeObserver(deleteObserver);
deleteObserver = null;
Log.v(“lgq”, “…11…onDestroy…”);
}
调用,通知观察者,主要在receiver中调用,fragment,activity都可以调用,跨界面刷新数据
TestObServernotice.getInstance().notifyObserver(0,bundle.getString(“cn.jpush.android.ALERT”));
5、命令模式
实现步骤:
(1)创建命令接受者:
//命令接收者Receiver
public class Tv {
public int currentChannel = 0;
public void turnOn() {
System.out.println(“lgqThe televisino is on.”);
}
public void turnOff() {
System.out.println(“The television is off.”);
}
public void changeChannel(int channel) {
this.currentChannel = channel;
System.out.println("Now TV channel is " + channel);
}
}
(2)定义命令的接口,声明执行的方法。
//执行命令的接口
public interface Command {
void execute();
}
(3)命令接口实现对象
//开机命令ConcreteCommand,获取接受者类,实现命令
public class CommandOn implements Command {
private Tv myTv;
public CommandOn(Tv tv) {
myTv = tv;
}
public void execute() {
myTv.turnOn();
}
}
(4)要求命令对象执行请求,通常会持有命令对象
//可以看作是遥控器Invoker
public class Control {
private Command onCommand, offCommand, changeChannel;
public Control(Command on) {
onCommand = on;
}
public void turnOn() {
onCommand.execute();
}
// public void turnOff() {
// offCommand.execute();
最后
文章不易,如果大家喜欢这篇文章,或者对你有帮助希望大家多多点赞转发关注哦。文章会持续更新的。绝对干货!!!
- 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行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
学习。接下来看一下导图和对应系统视频吧!!!
[外链图片转存中…(img-EC0oJYFQ-1714190060664)]
- Android对标阿里P7学习视频
[外链图片转存中…(img-YTKMR4zx-1714190060664)]
- BATJ大厂Android高频面试题
这个题库内容是比较多的,除了一些流行的热门技术面试题,如Kotlin,数据库,Java虚拟机面试题,数组,Framework ,混合跨平台开发,等
[外链图片转存中…(img-ipPuxnAT-1714190060665)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!