JAVA并发基础, 从源码分析清楚AbstractQueuedSynchronizer
在日常开发的过程中,java.util.concurrent(J.U.C)是我们在并发编程中用的最多的,如果我们想熟练的掌握JAVA并发基础,少不了需要了解 AbstractQueuedSynchronizer(以下简写AQS)这个抽象类,因为它是 Java 并发包的基础工具类,是实现 ReentrantLock、CountDownLatch、Semaphore、FutureTask 等类的基础。
当然这篇文章是我自己对AQS的理解,有错误之处,请评论区留言交流。
AbstractQueuedSynchronizer的类结构
//比较重要的属性都在这里
// 头结点,我是把它当成当前持有锁的线程
private transient volatile Node head;// 阻塞队列的尾节点,每个新的等待线程节点进来都插入到最后
private transient volatile Node tail;// 代表当前锁的状态,0代表没有被占用,大于 0 代表有线程持有当前锁
// 并且这个值是可以大于 1,是因为锁是可以重入的,每次重入都加上 1
private volatile int state;// 代表当前持有独占锁的线程
private transient Thread exclusiveOwnerThread;
用图片来阐述这个结构的话如下(有点丑,管用就行):
线程的每一个等待节点都被包装成了一个Node,Node类结构如下
static final class Node {static final Node SHARED = new Node();//标识节点当前在独占模式下static final Node EXCLUSIVE = null;//代码此线程取消了争抢这个锁static final int CANCELLED = 1;//表示当前这个node的后继节点对应的线程需要被唤醒static final int SIGNAL = -1;//表示这个节点在条件队列,后面说static final int CONDITION = -2;//后面分析static final int PROPAGATE = -3;//// 这么理解,暂时只需要知道如果这个值 大于0 代表此线程取消了等待 // 如同我们日常买东西排队一样可以排到一半,我不想买了不排队了volatile int waitStatus;// 前驱节点的引用volatile Node prev;// 后继节点的引用volatile Node next;// 线程本身volatile Thread thread;}
前面讲的都是概念,但是如果不清楚这些概念,后面可能会看不下去所以还是不要略过,下面就是真正开始分析源码了
以ReentrantLock为例子,它是我们平常用得比较多的轻量级锁,它可以分为公平锁和非公平锁,并且它是可重入的,ReentrantLock 在内部用了内部类 Sync 来管理锁,所以真正的获取锁和释放锁是由 Sync 的实现类来控制的。因为ReentrantLock可以分为公平锁和非公平锁,可以再构造ReentrantLock的时候指定
public ReentrantLock(boolean fair) {sync = fair ? new FairSync() : new NonfairSync();
}
下面我们从非公平锁的实现 FairSync切入源码
ReentrantLock加锁
static final class FairSync extends Sync {private static final long serialVersionUID = -3000897897090466540L;//加锁final void lock() {acquire(1);}public final void acquire(int arg) { // 首先调用tryAcquire(1)一下,顾名思义,先尝试加锁// 因为此时有可能没有线程竞争有可能直接就成功了呢,也就不需要进等待队列排队了// tryAcquire(1)没有成功,这个时候需要把当前线程挂起,放到阻塞队列中。if (!tryAcquire(arg) &&acquireQueued(addWaiter(Node.EXCLUSIVE), arg)) {selfInterrupt();}}// 尝试直接获取锁,返回值是boolean,代表是否获取到锁// 返回true:1.没有线程在等待锁;2.重入锁// 返回false 没有抢到锁 protected final boolean tryAcquire(int acquires) {final Thread current = Thread.currentThread();int c = getState();// c == 0 表名此时此刻没有线程持有锁if (c == 0) {// 虽然此时此刻锁是可以用的,但是这是公平锁,既然是公平,就得讲究先来后到,// 调用hasQueuedPredecessors()看看有没有别人在队列中等待if (!hasQueuedPredecessors() &&// 如果没有线程在等待,那就用CAS尝试一下,成功了就获取到锁了,// 不成功的话,只能说明一个问题,就在刚刚几乎同一时刻有个线程抢先了compareAndSetState(0, acquires)) {// 到这里就是获取到锁了,标记一下现在是当前这个想成占用了锁setExclusiveOwnerThread(current);//返回 return true;}}// 会进入这个分支,说明当前是有线程占用锁的,// 但是会不会是同一个线程重入了,如果是重入的线程直接state+1else if (current == getExclusiveOwnerThread()) {int nextc = c + acquires;if (nextc < 0)throw new Error("Maximum lock count exceeded");setState(nextc);return true;}}// 假设tryAcquire(arg) 返回false,那么代码将执行:// acquireQueued(addWaiter(Node.EXCLUSIVE), arg),// 此方法的作用是把线程包装成node,同时进入到队列中// 参数mode此时是Node.EXCLUSIVE,代表独占模式private Node addWaiter(Node mode) {Node node = new Node(Thread.currentThread(), mode);// 以下几行代码想把当前node加到链表的最后面去,也就是进到阻塞队列的最后Node pred = tail;if (pred != null) { // 将当前的队尾节点,设置为自己的前驱 node.prev = pred; // 用CAS把自己设置为队尾, 如果成功了,tail == node// 这个节点成为阻塞队列新的尾巴if (compareAndSetTail(pred, node)) { // 进到这里说明设置成功,当前node==tail, 将自己与之前的队尾相连,// 上面已经有 node.prev = pred,加上下面这句,也就实现了和之前的尾节点双向连接了pred.next = node;// 线程入队了,可以返回了return node;}}// 仔细看看上面的代码,如果会到这里,// 说明 (pred = tail)==null(队列是空的) 或者 CAS失败(有线程在竞争入队)enq(node);return node;}// 能走到这个方法只有两种可能:等待队列为空,或者有线程竞争入队,// 这里会自旋配合CAS设置将自己设置为tail,竞争一次竞争不到,我就多次竞争,总会排到的private Node enq(final Node node) {for (;;) {Node t = tail;// 之前说过,队列为空也会进来这里if (t == null) { // 一开始 head 和 tail都是 null 的// 还是一步CAS,你懂的,现在可能是很多线程同时进来呢if (compareAndSetHead(new Node()))// 给后面用:这个时候head节点的waitStatus==0// 这个时候有了head,但是tail还是null,设置一下,// 把tail指向head,放心,马上就有线程要来了,到时候tail就要被抢了// 设置完了以后,继续for循环,下次就到下面的else分支了tail = head;} else {// CAS设置自己为队尾,没有设置成功的话重复尝试直到成功node.prev = t;if (compareAndSetTail(t, node)) {t.next = node;return t;}}}}// 走完addWaiter之后,回到这段代码了,// 这个时候当前节点肯定是已经成功进入了等待队列的// if (!tryAcquire(arg) // && acquireQueued(addWaiter(Node.EXCLUSIVE), arg)) // selfInterrupt();// 如果acquireQueued(addWaiter(Node.EXCLUSIVE), arg))返回true的话,// 此时将进入selfInterrupt()// 所以正常情况下,acquireQueued(addWaiter(Node.EXCLUSIVE), arg))应该返回false// 继续跟进看看吧final boolean acquireQueued(final Node node, int arg) {boolean failed = true;try {boolean interrupted = false;for (;;) {final Node p = node.predecessor();// p == head 说明当前节点是阻塞队列的第一个,因为它的前驱是head// 我的理解是阻塞队列其实并不包含head节点// head一般指的是占有锁的线程,head后面的才称为阻塞队列(个人理解,勿喷)// 所以这个当前节点其实可以去尝试抢一下锁// 为什么可以尝试去抢一下锁呢// 首先,它是队头,其次,当前的head有可能是刚刚初始化的node,// enq(node) 方法里面有提到,head是延时初始化的,而且new Node()的时候没有设置任何线程// 也就是说,当前的head不属于任何一个线程,所以作为队头,可以去试一试,// tryAcquire已经分析过了, 忘记了请往前看一下,就是简单用CAS试操作一下stateif (p == head && tryAcquire(arg)) {setHead(node);p.next = null; // help GCfailed = false;return interrupted;}// 到这里,说明上面的if分支没有成功,要么当前node本来就不是队头,// 要么就是tryAcquire(arg)没有抢赢别人,继续往下看if (shouldParkAfterFailedAcquire(p, node) &&parkAndCheckInterrupt())interrupted = true;}} finally {// 什么时候 failed 会为 true???// tryAcquire() 方法抛异常的情况if (failed)cancelAcquire(node);}}// 会到这里就是没有抢到锁,判断是否需要挂起当前线程// 第一个参数是前驱节点,第二个参数才是代表当前线程的节点private static boolean shouldParkAfterFailedAcquire(Node pred, Node node) {int ws = pred.waitStatus;// 进入阻塞队列排队的线程会将他的前驱节点设为Node.SIGNAL// 也就是说如果自己可以抢锁了就让前面的节点提醒自己,自己则被挂起等待唤醒// 前驱节点的 waitStatus == -1 ,说明前驱节点状态正常,可以直接返回if (ws == Node.SIGNAL)return true;// 前驱节点 waitStatus大于0 ,说明前驱节点取消了排队。// 前面的人都取消排队了,但是你还得依赖它来唤醒呢,// 往前遍历总能找到一个没有取消排队的节点,来提醒自己if (ws > 0) {do {node.prev = pred = pred.prev;} while (pred.waitStatus > 0);pred.next = node;} else {// 到了这里说明前驱节点的waitStatus不等于Node.SIGNAL和CANCEL// 那也就是只可能是0,-2,-3// 都没有看到有设置waitStatus的,所以每个新的node入队时,waitStatu都是0// 用CAS将前驱节点的waitStatus设置为Node.SIGNAL(也就是-1),让前面的提醒自己compareAndSetWaitStatus(pred, ws, Node.SIGNAL);}// 这个方法返回 false,那么会再走一次 for 循序,// 然后再次进来此方法,此时会从第一个分支返回 truereturn false;}// if (shouldParkAfterFailedAcquire(p, node) &&// parkAndCheckInterrupt())// interrupted = true;// 如果shouldParkAfterFailedAcquire(p, node)返回true,// 就会执行parkAndCheckInterrupt():// 这个方法很简单,因为前面返回true,所以需要挂起线程,这个方法就是负责挂起线程的// 这里用了LockSupport.park(this)来挂起线程,然后就停在这里了,等待被唤醒=======private final boolean parkAndCheckInterrupt() {LockSupport.park(this);return Thread.interrupted();}// 为什么shouldParkAfterFailedAcquire(p, node)返回false的时候不直接挂起线程:// 是为了应对在经过这个方法后,node已经是head的直接后继节点了,还需要挂起干嘛,直接可以尝试抢锁了。
}
解锁操作
// 解锁操作相比加锁还是比较简单的
public void unlock() {sync.release(1);
}
//没什么说的,继续
public final boolean release(int arg) {if (tryRelease(arg)) {Node h = head;if (h != null && h.waitStatus != 0)unparkSuccessor(h);return true;}return false;
}// 回到ReentrantLock看tryRelease方法
protected final boolean tryRelease(int releases) {int c = getState() - releases;// 没有抢到锁的不配解锁if (Thread.currentThread() != getExclusiveOwnerThread())throw new IllegalMonitorStateException();// 是否完全释放锁boolean free = false;// 其实就是重入的问题,如果c==0,也就是说没有嵌套锁了,可以释放了,否则还不能释放掉if (c == 0) {free = true;setExclusiveOwnerThread(null);}setState(c);return free;
}// 唤醒后继节点
// 从上面调用处知道,参数node是head头结点
private void unparkSuccessor(Node node) {int ws = node.waitStatus;// 如果head节点当前waitStatus<0, 将其修改为0if (ws < 0)compareAndSetWaitStatus(node, ws, 0);// 下面的代码就是唤醒后继节点,但是有可能后继节点取消了等待(waitStatus==1)// 从队尾往前找,找到waitStatus<=0的所有节点中排在最前面的Node s = node.next;if (s == null || s.waitStatus > 0) {s = null;for (Node t = tail; t != null && t != node; t = t.prev)if (t.waitStatus <= 0)s = t;}if (s != null)// 唤醒线程LockSupport.unpark(s.thread);
}//这个时候线程被唤醒的时候是在这里private final boolean parkAndCheckInterrupt() {LockSupport.park(this);return Thread.interrupted();}final boolean acquireQueued(final Node node, int arg) {boolean failed = true;try {boolean interrupted = false;for (;;) {final Node p = node.predecessor();if (p == head && tryAcquire(arg)) {setHead(node);p.next = null; // help GCfailed = false;return interrupted;}if (shouldParkAfterFailedAcquire(p, node) &&//这里被唤醒了,然后继续检查前驱是不是头节点,尝试获取锁parkAndCheckInterrupt())interrupted = true;}} finally {if (failed)cancelAcquire(node);}}
至此公平锁下的加锁操作和解锁操作就都解析完了
公平锁总结
公平锁主要注意的就是下面三个方面
- 锁状态。成员变量 “state”,它为 0 的时候代表没有线程占有锁,可以去争抢这个锁,用 CAS 将 state 设为 state + args,如果 CAS 成功,说明抢到了锁,这样其他线程就抢不到了,如果锁重入的话,state进行 +1 就可以,解锁就是减 1,直到 state 又变为 0,代表释放锁。
- 线程的阻塞和解除阻塞。AQS 中采用了 LockSupport.park() 来挂起线程,用 LockSupport.unpark() 来唤醒线程。
- 阻塞队列。因为争抢锁的线程可能很多,但是只能有一个线程拿到锁,其他的线程都必须等待,这个时候就需要一个 足赛队列 来管理这些线程节点,AQS 用的其实就是一个链表队列,每个 node 都持有后继节点和前驱节点的引用,大家都在里面公平的排队等待加锁,只有排到了第一个才有资格去加锁。
接下来是非公平锁,待续。。。。。。。
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- Go典型并发任务
文章目录仅运行一次仅需任意任务完成所有任务完成对象池sync.Pool对象缓存 仅运行一次 最容易联想到的单例模式: type Singleton struct { }var singleInstance *Singleton var once sync.Oncefunc GetSingletonObj() *Singleton {once.Do(func() {fmt.Println("Create O…...
2024/4/24 6:23:59 - Linux vim
首先引用菜鸟的vim教程,这里都是些vim基础操作,讲解齐全,适合新手:点此进入 简单使用可以参考:然后是些实用操作: 普通命令模式: :r +文件名 将etc/issuc 文件中的内容导入到光标所在位置:!+ 命令 在vim模式下执行…...
2024/4/24 6:23:55 - 多线程并发编程----如何解决wait()死锁等待问题
一、首先大家浏览一下我的上一篇博文,这里有“事故”现场:https://blog.csdn.net/jason_jiahongfei/article/details/106302871二、为了解决wait()死锁问题,首先咱们得了解死锁产生的原因,先从线程的状态流转说起:最本质的两个方法:lock.wait()//必须等待别人唤醒,生活完…...
2024/5/1 7:06:25 - SpringBoot 加载Mysql脚本的两种方式
1. 使用自动配置加载sql脚本文件命名规则 Schema-.sql data-.sql org\springframework\boot\autoconfigure\jdbc\DataSourceInitializer.java getScripts默认规则:schema.sql schema-all.sql2. 使用配置文件来加载 spring:datasource:url: jdbc:mysql://ip:port/jdbcusernam…...
2024/4/24 6:23:54 - 街景字符识别task2学习笔记
对baseline的模型进行了数据扩增和loss设计的改进,但不知为啥效果不好。 1.增加albumentations数据扩增方式: def __getitem__(self, index):img = Image.open(self.img_path[index]).convert(RGB)#PIL读取数据为‘RGBA’格式img = np.asarray(img)#img = cv2.imread(self.im…...
2024/5/1 9:24:20 - 进程管理
一 进程实体为什么需要进程没有配置OS之前,资源属于当前运行的程序配置OS之后,引入多道程序设计的概念合理的隔离资源,运行环境,提高资源利用率进程是系统进行资源分配和调度的基本单位进程作为程序独立运行的载体,保障程序正常执行。进程的存在使得操作系统资源的利用率大…...
2024/4/24 6:23:51 - 虚拟机打开时报错Operation inconsistent with current state。
虚拟机报错Operation inconsistent with current state。 有时候突然打开虚拟机会出现这个状况 我看过很多博客,也用过很多方法,下面根据自身经验给大家介绍一下怎么解决这个问题。 出现这个问题很可能是因为你上次虚拟机没有关好,直接关闭VMWare或者直接关机。 解决方法: …...
2024/5/1 7:57:05 - java-06-java程序的基本规则
最简单的Java程序 class Test{ }java Test 会报错 java命令解释的时候,必须有 public static void main(String[] args){}main方法,且必须这种格式 Java源文件命名 必须.java后缀 源文件名称可随意,但是如果源文件有public类,名称必须和类名一样 这也限制了一个源文件中只能…...
2024/5/1 9:53:14 - Scala 系列 - 标识符与操作符
本章主要操作符的相关概念以及实现自己的操作符的方法标识符变量,函数和类等的名称统称为标识符。 在 Python 中,标识符都是字母和数字字符的序列,以字母或者下划线开头。 Scala 可以使用 Unicode 字符,例如如下定义都是合法的 val ** = 1 val ∮ = 2再例如我们都知道的1-&…...
2024/5/1 9:38:53 - maven 处理资源过滤
<build><resources><resource><!-- xml放在java目录下--><directory>src/main/java</directory><includes><include>**/*.xml</include></includes></resource><!--指定资源的位置(xml放在resources下,…...
2024/5/1 10:04:19 - dockerfile构建镜像
一、docker不建议用户通过commit方式构建镜像原因如下:1.这是一种手工创建镜像的方式,容易出错,效率低且可重复性弱,比如要在Debian bash 镜像中也加入vi,害的重复前面的所有步骤2.更重要的:使用者并不知道镜像是如何创建出来的,里面是否有恶意程序。也就是说无法对镜像…...
2024/5/1 6:23:15 - 学习keras问题之一:Layer was called with an input that is not a symbolic tensor
最近在使用keras搭建模型的时候出现了这个问题:ValueError: Layer model_3 was called with an input that isnt a symbolic tensor. Received type: <class numpy.ndarray>. Full input:(后边是一个输出的数组,不方便展示了)将问题定位到代码的136行。这是一个模型引…...
2024/4/16 23:07:54 - 实例132带参数的Command命令:OledbParameter
OleDbParameter 类https://docs.microsoft.com/zh-cn/dotnet/api/system.data.oledb.oledbparameter?view=dotnet-plat-ext-3.1OleDbParameter对象要配合OleDbComrnand对象一起使用。OLeDbParameter类具有一个名为 Parameters 的属性, 该属性为 OleDbParameterCollection …...
2024/5/1 5:10:10 - 书友汇备天之小白进阶Matplotlib绘图,一目了然!
我之幸运是因为一直坚持梦想! 每一次开始写博都是一次进步,时间在点滴中流走,技能在时间长河中增加,这就是记忆的力量,也是学习的幸运! 不用害怕困难,经过我的检验发现,所有的困难都是懒惰思想所致,一切困难都可以通过克服解决! 不觉间对于学习又心生无限乐趣,因为无…...
2024/5/1 8:53:39 - Python小游戏之乱序猜单词
游戏规则:电脑随机给定一个乱序单词,用户来猜测。 输出:猜对单词的个数cnt。 基础知识:random.choice()random.randrange() 源代码: import random#可以自己设定 words=[abandon,admire,acid,beach,bless,bomb,chemical,chemist,collect,delete,diary,distinct] cnt=0 whi…...
2024/4/16 23:08:06 - 【php】php使用阿里云OSS对象存储
up.php(前端上传)<!DOCTYPE html> <html> <head><meta charset="utf-8"> </head> <body> <form action="oss.php" method="post" enctype="multipart/form-data">请选择文件:<input …...
2024/4/24 6:23:50 - Reverse基础(四)
学习IDA的使用,寻找flag之旅first blood_reverse_1 拉入查壳工具可以看到64位,拖入IDA 从字符串入手,找到形式神似flag的一串字符,双击进入汇编页面 找到该字符串地址,双击进入包含它的函数 F5反汇编,查看伪代码 即可得到flag为{hello world} reverse_2 查壳发现是64位,…...
2024/5/1 9:57:21 - 用实践带领你进入numpy的世界——(五):numpy广播运算讲解(加法为例)
numpy——科学计算库的讲解(五)创建初始数据矩阵创建用于行广播的矩阵数据创建用于列广播的矩阵数据加法广播行广播运算行广播加法运算总结列广播运算列广播加法运算总结最后小结QQ:3020889729 …...
2024/4/24 6:23:47 - 嵌入式linux开机自动加载自己的模块
① 将模块xxx.ko复制到目录/lib/modules/4.1.15-gbedf008/ 下 ② vi /etc/init.d/rc.local ③ 在最后一行添加 insmod /lib/modules/4.1.15-gbedf008/xxx.ko ④ 重启 成功!...
2024/4/24 6:23:49 - 单周期CPU设计(一)
单周期CPU设计(一) 设计过程分两步,首先,根据所设计的所有汇编指令的功能及指令格式,完成CPU的数据通路设计;其次,根据指令功能和数据通路设计控制部件。 数据通路的一般设计方法: 1.根据指令的功能,确定每条指令在执行过程中所需要的部件。 2.所用的部件用表格列出,并…...
2024/4/16 23:07:42
最新文章
- 【工具类】正则表达式过滤器(过滤日志、过滤文件)
1. 【工具类】正则表达式过滤器(过滤日志、过滤文件) 1. 【工具类】正则表达式过滤器(过滤日志、过滤文件) 1.1. 划重点1.2. 参数说明1.3. 正则表达式 regular.json 内容如下1.4. 举例1.5. 代码说明 1.1. 划重点 功能: python实现的支持对文件进行正则表达式过滤…...
2024/5/1 10:36:06 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - 华为海思2024春招数字芯片岗机试题(共9套)
huawei海思2024春招数字芯片岗机试题(共9套,有答案和解析,答案非官方,未仔细校正,仅供参考)(WX:didadidadidida313,加我备注:CSDN huawei数字题目,谢绝白嫖哈)…...
2024/5/1 10:20:41 - ssm框架中各层级介绍
1、Spring(业务逻辑层): Spring框架提供了依赖注入(DI)和面向切面编程(AOP)等功能,可以帮助管理Java应用程序中的对象依赖关系和提供横切关注点的支持。 在SSM框架中,S…...
2024/4/30 2:49:54 - STL--vector有哪些应用场景
vector 在 C 中是一种非常灵活和强大的容器,适用于多种不同的应用场景。以下是一些常见的应用场景: 1 动态数据集合:当你不确定数据集的大小,或者数据集的大小会随时间变化时,vector 是理想的选择。例如,在…...
2024/4/30 3:33:36 - 【外汇早评】美通胀数据走低,美元调整
原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...
2024/4/29 23:16:47 - 【原油贵金属周评】原油多头拥挤,价格调整
原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...
2024/4/30 18:14:14 - 【外汇周评】靓丽非农不及疲软通胀影响
原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...
2024/4/29 2:29:43 - 【原油贵金属早评】库存继续增加,油价收跌
原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...
2024/4/30 18:21:48 - 【外汇早评】日本央行会议纪要不改日元强势
原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...
2024/4/27 17:58:04 - 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响
原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...
2024/4/27 14:22:49 - 【外汇早评】美欲与伊朗重谈协议
原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...
2024/4/28 1:28:33 - 【原油贵金属早评】波动率飙升,市场情绪动荡
原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...
2024/4/30 9:43:09 - 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试
原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...
2024/4/27 17:59:30 - 【原油贵金属早评】市场情绪继续恶化,黄金上破
原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...
2024/4/25 18:39:16 - 【外汇早评】美伊僵持,风险情绪继续升温
原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...
2024/4/28 1:34:08 - 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势
原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...
2024/4/26 19:03:37 - 氧生福地 玩美北湖(上)——为时光守候两千年
原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...
2024/4/29 20:46:55 - 氧生福地 玩美北湖(中)——永春梯田里的美与鲜
原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...
2024/4/30 22:21:04 - 氧生福地 玩美北湖(下)——奔跑吧骚年!
原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...
2024/5/1 4:32:01 - 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!
原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...
2024/4/27 23:24:42 - 「发现」铁皮石斛仙草之神奇功效用于医用面膜
原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...
2024/4/28 5:48:52 - 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者
原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...
2024/4/30 9:42:22 - 广州械字号面膜生产厂家OEM/ODM4项须知!
原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...
2024/4/30 9:43:22 - 械字号医用眼膜缓解用眼过度到底有无作用?
原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...
2024/4/30 9:42:49 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57