-
传统的单例模式和new 创建对象的调用不一样
-
调用者要调用xxx.getInstance才能获得该单例
function Singleton(name) {
this.name = name;
}
Singleton.getInstance = function (name) {
if(this.instace){
return this.instace;
}else {
this.instace = new Singleton(name);
return this.instace;
}
};
var a = Singleton.getInstance('a');
var b = Singleton.getInstance('b');
console.log(a===b); //true
5."透明"的单例模式
-
透明”的单例类,用户从这个类中创建对象的时候,可以像使用其他任何普通类一样
-
直接 new 一个对象
-
不能new 多个对象,扩展性不好
var instace;
function Person(name) {
this.name = name;
if (!instace) {
instace = this;
}
return instace;
}
Person.prototype.getName = function () {
console.log(this.name);
};
var a = new Person('a');
var b = new Person('b');
console.log(a===b);
6.代理模式创建单例模式
-
代理模式:自己不去做,委托中间人做
-
Person是一个普通类,通过new Person可以创建一个对象
-
用代理模式创建CreateSinglePerson方法,通过new CreateSinglePerson可以创建一个单例
function Person(name) {
this.name = name;
}
Person.prototype.getName = function () {
console.log(this.name);
};
var CreateSinglePerson = (function (name) {
var instance;
return function () {
if (!instance) {
instance = new Person(name);
}
return instance;
};
})();
var a = new CreateSinglePerson('a');
var b = new CreateSinglePerson('b');
console.log(a === b);
var c = new Person('c');
var d = new Person('d');
console.log(c === d);
JavaScript中的单例模式
-
单例模式的核心是确保只有一个实例,并提供全局访问
-
在JavaScript可以通过直接创建一个对象来实现单例模式
-
可以用闭包的方式实现私有变量
let MyApp = {
name:'app',
getName:function() {
console.log(this.name);
}
};
let MyApp2 = (function(){
var _name = 'app';
return {
getName:function() {
console.log(_name);
}
}
})();
#####惰性单例
-
惰性单例是指在需要的时候才创建
-
🌰:调用render方法,创建A对象,可以多次调用render方法,A对象是单例的
var createA = (function () {
var instance;
return function () {
if(!instance){
//xxx
instance = 'A';
}
return instance;
};
})();
function render() {
createA();
console.log('b');
}
render();
render();
- 如果要创建B对象,B也是单例
var createB = (function () {
var instance;
return function () {
if(!instance){
//xxx
instance = 'B';
}
return instance;
};
})();
- 我们看到createA和createB的核心代码是相同的,所以可以抽离出通用创建的惰性单例的代码
function getSingleton(fn) {
var result;
return function() {
return result||(result = fn.apply(this,arguments));
}
}
var createA = function () {
var instance;
if(!instance){
//xxx
instance = 'A';
}
return instance;
};
var createB = function () {
var instance;
if(!instance){
//xxx
instance = 'B';
}
return instance;
};
var createASingle = getSingleton(createA);
var createBSingle = getSingleton(createB);
function render() {
createASingle();
createBSingle();
}
render();
render();
小结
单例模式用到了闭包和高阶函数的特性。单例模式是简单但常用到的模式,比如单页应用、websocket连接等等。特别是惰性单例模式,用到时才创建,再次用到是不需要再次创建。创建对象和管理单例的职责分布在不同的方法中,方便扩展和管理。
单例的使用场景
整个项目需要一个共享访问点或者数据
创建一个对象需要耗费的资源太多,比如访问数据库资源等
工具类对象
架构师筑基必备技能
目前Android APP开发主流语言就是Java语言,Java语言最大的特性就是提高了软件的交互可能性,可以说安卓手机几乎所有应用程序都是利用Java语言来进行编写的。
知识要点:
1、深入理解Java泛型
2、注解深入浅出
3、并发编程
4、数据传输与序列化
5、Java虚拟机原理
6、高效IO
结语
看到这篇文章的人不知道有多少是和我一样的Android程序员。
35岁,这是我们这个行业普遍的失业高发阶段,这种情况下如果还不提升自己的技能,进阶发展,我想,很可能就是本行业的职业生涯的终点了。
CodeChina开源项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》
我们要有危机意识,切莫等到一切都成定局时才开始追悔莫及。只要有规划的,有系统地学习,进阶提升自己并不难,给自己多充一点电,你才能走的更远。
千里之行始于足下。这是上小学时,那种一元钱一个的日记本上每一页下面都印刷有的一句话,当时只觉得这句话很短,后来渐渐长大才慢慢明白这句话的真正的含义。
有了学习的想法就赶快行动起来吧,不要被其他的事情牵绊住了前行的脚步。不要等到裁员时才开始担忧,不要等到面试前一晚才开始紧张,不要等到35岁甚至更晚才开始想起来要学习要进阶。
最后免费分享给大家一份系统的Android学习进阶资料,希望这份资料可以给大家提供帮助。
生涯的终点了。
CodeChina开源项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》
我们要有危机意识,切莫等到一切都成定局时才开始追悔莫及。只要有规划的,有系统地学习,进阶提升自己并不难,给自己多充一点电,你才能走的更远。
千里之行始于足下。这是上小学时,那种一元钱一个的日记本上每一页下面都印刷有的一句话,当时只觉得这句话很短,后来渐渐长大才慢慢明白这句话的真正的含义。
有了学习的想法就赶快行动起来吧,不要被其他的事情牵绊住了前行的脚步。不要等到裁员时才开始担忧,不要等到面试前一晚才开始紧张,不要等到35岁甚至更晚才开始想起来要学习要进阶。
最后免费分享给大家一份系统的Android学习进阶资料,希望这份资料可以给大家提供帮助。