三个juc

第六天第三个问题

问题描述: 编写一个程序,它打开一个文本文件,逐个字符读取该文件,直到到达文件末尾,然后指出该文件有多少个字符。 解决思路: 1.先建立一个字符数组用于读取用户输入的文件名称 2.打印询问用户文件的名称 3.打开相应文件用cin逐个读取其中的字符,每读取一个就讲记录数加一,读取完成后关闭文件 4.输 ......
三个 问题

发布三个月跳水超1000!苹果M2版Mac mini降到3478元了

快科技4月18日消息,苹果在今年1月17日晚,在官网上架了新款的Mac mini,搭载了M2芯片,起售价4499元。 当时该产品配合上教育优惠,一度被认为是“香爆了”的产品,如今距离发布刚好三个月时间,其价格在电商平台却直接跳水千元。 根据拼多多百亿补贴频道显示,苹果M2版Mac mini如今售价只 ......
三个 苹果 1000 3478 mini

JUC8_阻塞队列

阻塞队列 概念 队列 队列就可以想成是一个数组,从一头进入,一头出去,排队买饭 阻塞队列 BlockingQueue 阻塞队列,排队拥堵,首先它是一个队列,而一个阻塞队列在数据结构中所起的作用大致如下图所示: 线程1往阻塞队列中添加元素,而线程2从阻塞队列中移除元素 当阻塞队列是空时,从队列中获取元 ......
队列 JUC8 JUC

JUC14_Github学习

Github学习 使用Github优秀框架 + 源码 提升自己 常用词含义 watch:会持续收到该项目的动态 fork:复制某个仓库到自己的Github仓库中 star:可以理解为点赞 clone:将项目下载至本地 follow:关注你感兴趣的作者,会收到他们的动态 in关键字限制搜索范围 公式: ......
Github JUC 14

JUC15_乐观锁和悲观锁

乐观锁和悲观锁 乐观锁 概念 乐观锁:顾名思义,就是十分乐观,它总是认为不会出现问题,无论干什么都不去上锁~,如果出现了问题,再次更新值测试,这里使用了version字段。 也就是每次更新的时候同时维护一个version字段 乐观锁实现方式 取出记录时,获取当前的version 更新时,带上这个ve ......
JUC 15

JUC9_Synchronized和Lock的区别与好处

Synchronized和Lock的区别 前言 早期的时候我们对线程的主要操作为: synchronized wait notify 然后后面出现了替代方案 lock await singal 问题 synchronized 和 lock 有什么区别?用新的lock有什么好处?举例说明 synchr ......

JUC7_CountDownLatch_CyclicBarrier_Semaphore使用CyclicBarrier

CyclicBarrier 概念 和CountDownLatch相反,需要集齐七颗龙珠,召唤神龙。也就是做加法,开始是0,加到某个值的时候就执行 CyclicBarrier的字面意思就是可循环(cyclic)使用的屏障(Barrier)。它要求做的事情是,让一组线程到达一个屏障(也可以叫同步点)时被 ......

JUC7_CountDownLatch_CyclicBarrier_Semaphore使用Semaphore

Semaphore:信号量 概念 信号量主要用于两个目的 一个是用于共享资源的互斥使用 另一个用于并发线程数的控制 代码 我们模拟一个抢车位的场景,假设一共有6个车,3个停车位 那么我们首先需要定义信号量为3,也就是3个停车位 /** * 初始化一个信号量为3,默认是false 非公平锁, 模拟3个 ......

JUC11_死锁编码及快速定位

死锁编码及定位分析 概念 死锁是指两个或多个以上的进程在执行过程中,因争夺资源而造成一种互相等待的现象,若无外力干涉那他们都将无法推进下去。如果资源充足,进程的资源请求都能够得到满足,死锁出现的可能性就很低,否则就会因争夺有限的资源而陷入死锁。 产生死锁的原因 系统资源不足 进程运行推进的顺序不对 ......
编码 JUC 11

SR-MPLS前三个小实验

SR-MPLS_OSPF 前四步 第一步:完成基础配置:接口IP和OSPF 第二步:全局使能SR,没错,我们这里面的实验就是MPLS-SR,即使用MPLS-SR框架的SR,所以MPLS框架还是要配置的(所有设备) 第三步:全局使能SR(所有设备) 第四步:启用扩展OSPF(所有设备) CX1: sy ......
三个 SR-MPLS MPLS SR

JUC7_CountDownLatch_CyclicBarrier_Semaphore使用CountDownLatch

CountDownLatch 概念 让一些线程阻塞直到另一些线程完成一系列操作才被唤醒 CountDownLatch主要有两个方法,当一个或多个线程调用await方法时,调用线程就会被阻塞。其它线程调用CountDown方法会将计数器减1(调用CountDown方法的线程不会被阻塞),当计数器的值变 ......

JUC5_TransferValue是什么

值传递和引用传递 举例 /** * 值传递和引用传递 * @author: 陌溪 * @create: 2020-03-14-18:25 */ class Person { private Integer id; private String personName; public Person(St ......
JUC5_TransferValue TransferValue JUC5 JUC

JUC6_Java的锁Java锁之读写锁

独占锁(写锁) / 共享锁(读锁) / 互斥锁 概念 独占锁:指该锁一次只能被一个线程所持有。对ReentrantLock和Synchronized而言都是独占锁 共享锁:指该锁可以被多个线程锁持有 对ReentrantReadWriteLock其读锁是共享,其写锁是独占 写的时候只能一个人写,但是 ......
Java JUC6_Java JUC6 JUC

JUC6_Java的锁Java锁之自旋锁

Java锁之自旋锁 自旋锁:spinlock,是指尝试获取锁的线程不会立即阻塞,而是采用循环的方式去尝试获取锁,这样的好处是减少线程上下文切换的消耗,缺点是循环会消耗CPU 原来提到的比较并交换,底层使用的就是自旋,自旋就是多次尝试,多次访问,不会阻塞的状态就是自旋。 优缺点 优点:循环比较获取直到 ......
Java JUC6_Java JUC6 JUC

JUC1_谈谈Volatile4_Volatile的应用

Volatile的应用 单例模式DCL代码 首先回顾一下,单线程下的单例模式代码 /** * SingletonDemo(单例模式) * * @author: 陌溪 * @create: 2020-03-10-16:40 */ public class SingletonDemo { private ......

JUC2_谈谈CAS5_CAS底层原理

CAS底层原理 概念 CAS的全称是Compare-And-Swap,它是CPU并发原语 它的功能是判断内存某个位置的值是否为预期值,如果是则更改为新的值,这个过程是原子的 CAS并发原语体现在Java语言中就是sun.misc.Unsafe类的各个方法。调用UnSafe类中的CAS方法,JVM会帮 ......
底层 CAS CAS5_CAS 原理 JUC2

JUC1_谈谈Volatile3_Volatile禁止指令重排

Volatile禁止指令重排 计算机在执行程序时,为了提高性能,编译器和处理器常常会对指令重排,一般分为以下三种: 源代码 -> 编译器优化的重排 -> 指令并行的重排 -> 内存系统的重排 -> 最终执行指令 单线程环境里面确保最终执行结果和代码顺序的结果一致 处理器在进行重排序时,必须要考虑指令 ......

JUC1_谈谈Volatile2_Volatile不保证原子性

Volatile不保证原子性 前言 通过前面对JMM的介绍,我们知道,各个线程对主内存中共享变量的操作都是各个线程各自拷贝到自己的工作内存进行操作后在写回到主内存中的。 这就可能存在一个线程AAA修改了共享变量X的值,但是还未写入主内存时,另外一个线程BBB又对主内存中同一共享变量X进行操作,但此时 ......

JUC6_Java的锁Java锁之公平锁和非公平锁

Java锁之公平锁和非公平锁 概念 公平锁 是指多个线程按照申请锁的顺序来获取锁,类似于排队买饭,先来后到,先来先服务,就是公平的,也就是队列 非公平锁 是指多个线程获取锁的顺序,并不是按照申请锁的顺序,有可能申请的线程比先申请的线程优先获取锁,在高并发环境下,有可能造成优先级翻转,或者饥饿的线程( ......
Java JUC6_Java JUC6 JUC

JUC6_Java的锁Java锁之可重入锁和递归锁

可重入锁和递归锁ReentrantLock 概念 可重入锁就是递归锁 指的是同一线程外层函数获得锁之后,内层递归函数仍然能获取到该锁的代码,在同一线程在外层方法获取锁的时候,在进入内层方法会自动获取锁 也就是说:线程可以进入任何一个它已经拥有的锁所同步的代码块 ReentrantLock / Syn ......
Java JUC6_Java JUC6 JUC

JUC3_谈谈原子类的ABA问题6_原子类AtomicInteger的ABA问题

原子类AtomicInteger的ABA问题 连环套路 从AtomicInteger引出下面的问题 CAS -> Unsafe -> CAS底层思想 -> ABA -> 原子引用更新 -> 如何规避ABA问题 ABA问题是什么 狸猫换太子 假设现在有两个线程,分别是T1 和 T2,然后T1执行某个操 ......
原子 问题 AtomicInteger ABA JUC3

JUC4_ArrayList为什么线程不安全ArrayList线程不安全的举例

Collection线程不安全的举例 前言 1、当我们执行下面语句的时候,底层进行了什么操作 new ArrayList<Integer>(); 底层创建了一个空的数组,伴随着初始值为10 当执行add方法后,如果超过了10,那么会进行扩容,扩容的大小为原值的一半,也就是5个,使用下列方法扩容 Ar ......
线程 ArrayList JUC4_ArrayList JUC4 JUC

JUC6_Java的锁Synchronized无法禁止指令重排却能保证有序性

为什么Synchronized无法禁止指令重排,却能保证有序性 前言 首先我们要分析下这道题,这简单的一个问题,其实里面还是包含了很多信息的,要想回答好这个问题,面试者至少要知道一下概念: Java内存模型 并发编程有序性问题 指令重排 synchronized锁 可重入锁 排它锁 as-if-se ......
有序性 Synchronized 指令 JUC6_Java JUC6

JUC1_谈谈Volatile1_Volatile和JMM内存模型的可见性

JUC(java.util.concurrent) 进程和线程 进程:后台运行的程序(我们打开的一个软件,就是进程) 线程:轻量级的进程,并且一个进程包含多个线程(同在一个软件内,同时运行窗口,就是线程) 并发和并行 并发:同时访问某个东西,就是并发 并行:一起做某些事情,就是并行 JUC下的三个包 ......

Java并发工具合集JUC大爆发!!!

并发工具类 通常我们所说的并发包也就是java.util.concurrent(JUC),集中了Java并发的各种工具类, 合理地使用它们能帮忙我们快速地完成功能 。 作者: 博学谷狂野架构师 GitHub:GitHub地址 (有我精心准备的130本电子书PDF) 只分享干货、不吹水,让我们一起加油 ......
工具 Java JUC

LPL新十年首冠诞生,JDG卫冕成功!斩获队史第三个联赛冠军

4月15日,在线下万余名观众的见证下,LPL十周年纪念盛典暨2023LPL春季赛总决赛于上海梅赛德斯-奔驰文化中心圆满落幕。这也是自2021LPL春季赛总决赛后,总决赛再度回归线下并开放观众入场。最终经过四局激烈的比拼,JDG以3-1的比分成功击败对手BLG,夺得LPL新十年的第一座银龙杯,同时也是 ......
联赛 三个 冠军 LPL JDG

MPLS-TE前三个基础实验

MPLS-TE的基础配置 实验目标: 所有的路由器都运行MPLS-TE 实现从AR1到10.0.4.4的MPLS-TE负载 基础配置 # R1 sys sysn AR1 int l0 ip add 10.0.1.1 32 int g0/0/1 ip add 10.0.15.1 24 int g0/0 ......
三个 MPLS-TE 基础 MPLS TE

win10 2004更新后会导致蓝屏 微软确定有三个问题

最近因为win10 2004版本系统的更新推送,很多用户们都选择的更新win10 2004版本系统,但一些用户们更新后,电脑设备等却出现了蓝屏,微软方面确定了一些问题,快来看看详细内容吧~ win10 2004更新后会导致蓝屏 微软确定有三个问题: 今天微软推出了Windows 10 五月更新,不过 ......
蓝屏 三个 问题 2004 win

android: minSdkVersion、targetSdkVersion、CompileSdkVersion三个api版本号的区别

一,minSdkVersion: app可以安装的最低的api版本: 1,安装:google play和应用市场会根据用户的api版本, 判断用户是否可以看到你的app 2, 运行:在minSdkVersion指定版本的api上运行时, 如果使用了更高版本的api,会导致报错: java.lang. ......

两阶段鲁棒优化程序 本程序采用微网为模型,主要将安装成本、运营成本以及综合效益三个方面纳入考虑范围

两阶段鲁棒优化程序 本程序采用微网为模型,主要将安装成本、运营成本以及综合效益三个方面纳入考虑范围,建立两阶段鲁棒优化模型,采用的是CCG方法,本程序为matlab编制ID:67480641450782375 ......
成本 程序 效益 模型 范围