当前位置: 首页 > news >正文

做雨棚的网站/游戏推广员一个月能赚多少

做雨棚的网站,游戏推广员一个月能赚多少,搜索引擎优化实训,做医疗的网站单例模式(3) 实现集群环境下的分布式单例类 如何理解单例模式中的唯一性? 单例模式创建的对象是进程唯一的。以springboot应用程序为例,他是一个进程,可能包含多个线程,单例代表在这个进程的某个类是唯一…

单例模式(3)

实现集群环境下的分布式单例类

如何理解单例模式中的唯一性?
  • 单例模式创建的对象是进程唯一的。以springboot应用程序为例,他是一个进程,可能包含多个线程,单例代表在这个进程的某个类是唯一的,在不同的线程中类是相同的。
如何实现线程唯一的单例?
/*** 线程中的单例*/
public class ThreadIdGenrator {private static final Map<Long, ThreadIdGenrator> map = new ConcurrentHashMap<>();private AtomicInteger id = new AtomicInteger(0);public static ThreadIdGenrator getInstance() {long threadId = Thread.currentThread().getId();ThreadIdGenrator threadIdGenrator = map.putIfAbsent(threadId, new ThreadIdGenrator());return threadIdGenrator;}public int nextInt() {return id.incrementAndGet();}
}
如何实现集群环境下的单例?
  • 我们需要把这个单例对象序列化并存储到外部共享存储区(比如文件)。进程在使用这个单例对象的时候,需要先从外部共享存储区中将它读取到内存,并反序列化成对象,然后再使用,使用完成之后还需要再存储回外部共享存储区。

  • 为了保证任何时刻,在进程间都只有一份对象存在,一个进程在获取到对象之后,需要对对象加锁,避免其他进程再将其获取。在进程使用完这个对象之后,还需要显式地将对象从内存中删除,并且释放对对象的加锁。

  • 问题:这里为什么要加锁

    • 理由:如果多个进程读取同一份序列化文件,得到的对象的地址是不一样的,这样子就无法保证全局的唯一性;
    • 序列化后的对象与原对象只是值相等但是对象的地址是不相等
    • 为了保证全局的唯一性,必须保证在集群下,在使用单例对象时,需要加锁,当多线程使用时,只有一个线程可以使用成功,其他线程必须阻塞
import java.util.concurrent.atomic.AtomicLong;public class IdGenerator {private AtomicLong id = new AtomicLong(0);private static IdGenerator instance;private static SharedObjectStorage storage = FileSharedObjectStorage(/* 入参省略 */);private static DistributedLock lock = new DistributedLock();private IdGenerator() {}public static IdGenerator getInstance() {if (instance == null) {lock.lock();instance = storage.load(IdGenerator.class);lock.unlock(); // 放置于try-finally块内确保解锁}return instance;}public void freeInstance() {lock.lock();try {storage.save(this, IdGenerator.class);instance = null; // 释放对象} finally {lock.unlock();}}public long getId() {return id.incrementAndGet();}
}
如何实现一个多例模式?
  • 多例的理解
    • “多例”指的就是,一个类可以创建多个对象,但是个数是有限制的
    • 同一类型的只能创建一个对象,不同类型的可以创建多个对象
      • 类型:同一个 name 获取到的对象实例是相同的
      • 以ID生成器为例:我希望在用户注册时使用的是一个ID生成器;在增加商品时,使用的是另一个ID生成器,即根据场景划分使用不同的ID生成器
public class DuoLiIdGenertor {private static final Map<String, DuoLiIdGenertor> map = new ConcurrentHashMap<>();private AtomicInteger id = new AtomicInteger(0);public static DuoLiIdGenertor getInstance(String name) {map.putIfAbsent(name, new DuoLiIdGenertor());return map.get(name);}public int nextInt() {return id.incrementAndGet();}}public static void main(String[] args) {DuoLiIdGenertor user = getInstance("user");DuoLiIdGenertor goods = getInstance("goods");DuoLiIdGenertor user1 = getInstance("user");System.out.println(user.hashCode());System.out.println(goods.hashCode());System.out.println(user1.hashCode());}   

在这里插入图片描述

http://www.ho-use.cn/article/668.html

相关文章:

  • 响应式网站模板dede/关键词优化网站排名
  • 网站建设和谷歌优化/seo博客是什么意思
  • 精通网站建设 100%全能建站密码pdf/网站seo推广营销
  • axure怎么做响应式网站/网络销售话术900句
  • 网页端登录/惠州网站seo
  • 宜宾网站建设价格/如何制作网页教程
  • wordpress 爆破脚本/网站优化的方法与技巧
  • 武汉做网站建设的公司/抖音搜索排名优化
  • 网站建设案例算命网站/关键词首页排名代发
  • 建设网站思路/广东公共广告20120708
  • 动感十足的网站/企业seo推广外包
  • 上海建筑设计院有限公司停工/长沙百度搜索排名优化
  • 丛台专业做网站/360免费建站官网
  • 网站客户端ip做爬虫/网站怎样才能在百度被搜索到
  • 襄阳网站建设公司哪家好/专门搜索知乎内容的搜索引擎
  • 做时时彩网站需要加盟网页制作教程书籍
  • 罗定市建设局网站/女孩短期技能培训班
  • 山东网络优化/上海优化排名网站
  • wordpress 结构解析/网站快速排名优化
  • 运营策划/搜索引擎优化方案
  • 怎么样做网站管理员/关键词seo资源
  • 霸州住房和城乡建设厅网站/设计网站模板
  • 网站制作价格上海/广东疫情中高风险地区最新名单
  • 设计网站的流程/谷歌手机版浏览器官网
  • 深圳网站制作工具/成都关键词优化报价
  • 网站被墙 怎么做301/宁波seo网络推广咨询价格
  • 做动态网站的app/网上引流推广怎么做
  • 西安做网站商标/外包网络推广营销
  • 一个人可以做网站吗/廊坊关键词优化排名
  • 国家部委政府网站群建设工作/如何加入广告联盟赚钱