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

一般一个网站从建设到运营要多久简单的网站建设

一般一个网站从建设到运营要多久,简单的网站建设,设计工作室 网站,手机网站微信链接怎么做的目录 一. CAS的概念 二. CAS的原理 三.标准库中的CAS 四. CAS的应用 (1)原子类的使用 (2) 自旋锁的实现 五. CAS的ABA问题 一. CAS的概念 CAS(Compare And Swap)机制是一种无锁的并发控制技术&#…

目录

一. CAS的概念

二. CAS的原理

三.标准库中的CAS

四. CAS的应用

(1)原子类的使用

(2) 自旋锁的实现

 五. CAS的ABA问题


一. CAS的概念

CAS(Compare And Swap)机制是一种无锁的并发控制技术,用于多线程并发编程时数据在无锁的情况下保证线程安全安全运行。

  • CAS是一个特殊的cpu指令,通过比较和交换操作实现特定的功能
  • 整个比较和交换过程必须在一个不可中断的指令中完成(单个cpu指令,本身具有原子性)

下面详细介绍这条特殊指令的原理 


二. CAS的原理

 CAS机制的实现取决于3个核心操作数:内存中的值A、寄存器中的值B、寄存器中的新值C。

        boolean CAS(A,B,C) {if (&A == B) {&A = C;return true;}return false;}

这是一段伪代码,用于表示CAS实现的逻辑 

  1. 比较内存中的值A和寄存器中的值B是否相等,如果相等,将寄存器中的新值C和内存中的值A进行交换,并返回true
  2. 如果不相等,什么也不做,返回false

 画图过程演示:

 判断发现A和B的值相等,故交换A和C的值

 注意:这里的交换可以理解为赋值,因为寄存器C中的数值,使用后会被清空


这里只是演示实现的步骤和机制,这些操作都是通过一条指令实现的(本身就具有原子性)

我们会发现,这一系列的操作,不会出现线程安全问题(原子性),以前的线程安全问题,都是通过通过加锁和解锁的步骤来解决,但是性能会降低,如果可以合理的使用CAS机制(不涉及加锁和解锁,也就不会涉及阻塞),这样效率会大大提高,这样的操作叫做无锁编程


三.标准库中的CAS

  • CAS本身是cpu指令,操作系统对其进行了封装,JVM又对操作系统提供的API又进行了一次封装,放在了Unsafe包
  • Java标准库中,又对CAS的实现进行了封装,提供了一些原子类,让我们可以直接使用,隐藏底层 Unsafe 的复杂性。

Java标准库中的CAS实现主要通过 java.util.concurrent.atomic 包下的原子类完成。 

四. CAS的应用

(1)原子类的使用

AtomicInteger 类(原子类)

常用方法

  • getAndIncrement 方法,自增操作,类似于 i++。
  • getAndDecrement 方法,自减操作,类似于 i--。

案例:在不使用锁的情况下实现两个线程的自增,并返回正确的值

public class Demo1 {//public static int count = 0;public static AtomicInteger count = new AtomicInteger(0);public static void main(String[] args) throws InterruptedException {Thread t1 = new Thread(()->{for (int i = 0; i < 50000; i++){count.getAndIncrement();}});Thread t2 = new Thread(()->{for (int i = 0; i < 50000; i++) {count.getAndIncrement();}});t1.start();t2.start();t1.join();t2.join();System.out.println("count = " + count);}
}

其中的CAS实现的过程,通过伪代码来展示

class AtomicInteger {private int value;public int getAndIncrement() {int oldValue = value;while ( CAS(value, oldValue, oldValue+1) != true) {oldValue = value;}return oldValue;}
}
  • 这样的实现过程,即使在两个进程同时执行的情况下,也不会出现线程安全的问题
  • 在每次的赋值前提下,会有一步比较的过程,如果不是对的值,那么就不会进行交换(赋值)

(2) 自旋锁的实现

自旋锁伪代码: 

public class Lock {private Thread owner = null;public void lock(){while(!CAS(this.owner, null, Thread.currentThread())){}}}
  • 如果ower 为null,CAS返回true,说明资源没有被别的线程持有,那么跳出循环
  • 如果ower不为null,CAS返回false,说明资源被别的线程持有,那么会继续循环(自旋)

通过这样的’忙等‘来实现等待的效果,缺点是会消耗掉很多的cpu资源


 五. CAS的ABA问题

 CAS无法区分数值有没有在变化的途中被修改过

数值从开始到结束一直都是A,还是从A=>B=>A(中间发生了变化)

这种情况类似于 "翻新机",外表看上去和新的一样,但是内部的组件可能发生了更换 

造成ABA问题的本质原因线程执行的过程中,被其他线程穿插进来

举例说明:

  • 有一个单链表 A->B->C,其中A为头节点
  • 线程1:如果头节点为A,则执行删除头节点操作
  • 线程2:执行两次删除头节点操作,再插入节点A

(1)线程2没有穿插进来:

(2)线程2穿插进来:

如果再执行线程1操作的途中,线程2穿插进来,导致线程1没有发觉,可能导致返回后的数据有误

解决方案:

  • 约定数据的变化是单向的,只能增加或者删除,不能又是增加又是减少
  • 对于必须要双向变化的数据,可以引入版本号的概念,在比较的时候不仅要比较内存中的值,还要比较版本号(只能增加,不能减少)

 点赞的宝子今晚自动触发「躺赢锦鲤」buff! 

http://www.dtcms.com/a/613094.html

相关文章:

  • 网站关键词优化代理做淘宝一样的网站有哪些
  • 公司要招个做网站的人公司官网设计模板
  • 网站备案是怎么回事公司已经有域名 怎么建网站
  • 深圳网站建设黄浦网络网上编程课的哪家好
  • 福州做网站的公html网站免费模板下载
  • 怎么创立网站杭州网站建设公司电话
  • 最精品网站建设在rds上安装wordpress
  • 建站公司兴田德润在哪里深圳app设计
  • 襄阳旅游景点网站建设制作个人免费网站展示设计
  • 做一些网站犯法么企业官网建站步骤
  • 互联网网站开发合同动态效果的网站建设技术
  • 网址的输入格式是什么样的seo关键词推广怎么做
  • 莆田网站建设团队门户网站主要包括哪些模块
  • 西安哪家公司网站做的好页游开服表
  • 重庆建设施工安全管理网站上海 专业网站建设
  • 网站开发 技术投标网站中图片加水印
  • 株洲市哪里有做公司官方网站wordpress主题显示不完整
  • 免费注册自己的网站网页制作课程
  • 湖南网站建设服务洛阳做网站公司
  • 小型的游戏网站怎么做网站全站模板
  • 免费网站推广在线观看网站那个做的比较好
  • 网站制作有哪些创新家校互动平台
  • 做 在线观看免费网站有哪些网页开发流程图
  • 公司网站英文学网站开发学费多少
  • 陕西电商网站建设旅游网站开发与建设论文
  • 嘉兴免费自助建站模板网站怎样做关键词优化
  • 免费的网站推广软件营销型网站建设宣传语
  • 做食品生产的网站佛山网站建站
  • 淄博比较好的网站建设公司做网站 什么语言好
  • 深圳高端做网站公司句容住房和城乡建设局网站