JUC多线程编程总结

JUC:java.util.concurrent多线程工具包的使用

测试demo:https://gitee.com/aqq/mytest.git

1、守护线程

java中有两类线程:用户线程、守护线程

只有当前JVM中存在用户线程没结束,守护线程就会全部工作,只有当最后一个用户线程结束之后,守护线程随着JVM结束工作,比如JVM中的垃圾回收(GC)就是守护线程。

Thread thread = new Thread();
// 设定 thread 为 守护线程,default false(非守护线程)
thread.setDaemon(true)//判断某个线程是否是守护线程用isDaemon
thread.isDaemon();

注意:

1、thread.setDaemon(true)必须在thread.start()之前,否则会抛出IllegalThreadStateException异常,不能把正在运行的线程设置为守护线程

2、在Daemon线程中产生的新线程也是守护线程

3、不要任务所有的线程都可以分配给Daemon来进行服务,比如读写操作或者计算逻辑

2、Synchronized的使用

模拟三个售票员卖30张票的场景

/*** 模拟 三个售票员卖30张票的情景* 1、首先定义资源,以及资源属性**/
public class SaleTickets {public static void main(String[] args) {Tickets tickets = new Tickets();Thread thread1 = new Thread(new SaleThread(tickets), "AA");Thread thread2 = new Thread(new SaleThread(tickets), "BB");Thread thread3 = new Thread(new SaleThread(tickets), "CC");thread1.start();thread2.start();thread3.start();}
}
class SaleThread implements Runnable{private Tickets tickets;public SaleThread(Tickets tickets) {this.tickets = tickets;}@Overridepublic void run() {for(int i = 0;i<120;i++){tickets.sail();}}
}
class Tickets{private int numbers = 100;public synchronized void sail(){if(numbers>0){System.out.println(Thread.currentThread().getName() + "卖出:1张,剩余:" + (numbers--) + "张");}}
}
3、Lock的使用

ReentrantLock(可重入锁)的使用:同样是模拟三个售票员卖30张票的场景

调用lock.lock()方法,必须要有释放锁的调用(lock.unlock()),最好写在finally中

public class LSaleTickets {public static void main(String[] args) {Tickets tickets = new Tickets();Thread thread1 = new Thread(new SaleThread(tickets), "AA");Thread thread2 = new Thread(new SaleThread(tickets), "BB");Thread thread3 = new Thread(new SaleThread(tickets), "CC");thread1.start();thread2.start();thread3.start();}
}/*** 创建资源对象**/
class Tickets{//票数量private int numbers = 30;//创建可重入锁private final ReentrantLock lock = new ReentrantLock();//买票public void sale(){lock.lock();try{//判断是否有票if (numbers > 0) {System.out.println(Thread.currentThread().getName() + "卖出:1张,剩余:" + (numbers--) + "张");}}finally {lock.unlock();}}
}
//定义卖票的线程
class SaleThread implements Runnable{private Tickets tickets;public SaleThread(Tickets tickets) {this.tickets = tickets;}@Overridepublic void run() {for(int i = 0;i<40;i++){tickets.sale();}}
}
4、线程间通信,虚假唤醒

线程间通信,主要是通过wait()和notifyAll()方法,或者Condition类的await()和signalAll()来控制线程的等待和唤醒,从而实现线程间的通信

案例1:通过synchronized关键字和wait和notify方法实现一个+1,一个-1的操作

package com.vike.juctest.sync;
/*** 模拟线程间通信* if(num!=0){*     this.wait();//在哪里睡,就在哪里唤醒* }* 采用if的话会存在虚假唤醒的问题,因为if条件只判断一次,应该为while* while(num!=0){*     this.wait();* }*/
public class ThreadTransf {public static void main(String[] args) {Share share = new Share();new Thread(()->{for (int i =0;i<10;i++){try {share.incr();} catch (InterruptedException e) {e.printStackTrace();}}},"AA").start();new Thread(()->{for (int i=0;i<10;i++){try {share.decr();} catch (InterruptedException e) {e.printStackTrace();}}},"BB").start();new Thread(()->{for (int i =0;i<10;i++){try {share.incr();} catch (InterruptedException e) {e.printStackTrace();}}},"CC").start();new Thread(()->{for (int i=0;i<10;i++){try {share.decr();} catch (InterruptedException e) {e.printStackTrace();}}},"DD").start();}
}
/*** 创建资源类*/
class Share{private int number = 0;/*** +1 方法*/public synchronized void incr() throws InterruptedException {while (number != 0) {this.wait();}number++;System.out.println(Thread.currentThread().getName()+"::数据+1后::"+number);this.notifyAll();}/*** -1 方法*/public synchronized void decr() throws InterruptedException {while (number != 1) {this.wait();}number--;System.out.println(Thread.currentThread().getName()+"::数据-1后::"+number);this.notifyAll();}
}

案例二:通过Lock的方式实现,需要用到Condition类的await()和signalAll()方法等待和唤醒

package com.vike.juctest.lock;import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;/*** 线程间通信2 采用lock的形式*/
public class ThreadTransf2 {public static void main(String[] args) {Share share = new Share();new Thread(() -> {for (int i = 0; i < 10; i++) {share.incy();}}, "AA").start();new Thread(()->{for (int i=0;i<10;i++){share.decy();}},"BB").start();new Thread(() -> {for (int i = 0; i < 10; i++) {share.incy();}}, "CC").start();new Thread(()->{for (int i=0;i<10;i++){share.decy();}},"DD").start();}
}/*** 定义资源*/
class Share{private int number = 0;final ReentrantLock lock = new ReentrantLock();final Condition condition = lock.newCondition();/*** 定义加1的方法*/public void incy(){lock.lock();try {while (number!=0){//当前线程等待condition.await();}number++;System.out.println(Thread.currentThread().getName()+"::数据+1后::"+number);//唤醒其他线程condition.signalAll();} catch (InterruptedException e) {e.printStackTrace();} finally {lock.unlock();}}/*** 定义减1的方法*/public void decy(){//上锁lock.lock();try {while (number != 1) {//线程等待condition.await();}number--;//唤醒其他线程condition.signalAll();System.out.println(Thread.currentThread().getName()+"::数据-1后::"+number);} catch (Exception e) {e.printStackTrace();} finally {//解锁lock.unlock();}}
}

案例3:线程之间定制化通信

  • 线程之间定制化通信

  • AA、BB、CC三个线程按顺序执行

  • 状态为1, AA执行5次,状态改为2,通知BB执行,

  • 状态为2, BB执行10次,状态改为3,通知CC执行

  • 状态为3, CC执行15次,状态改为1,通知AA执行

    public class ThreadTransf3 {public static void main(String[] args) {ShareResource shareResource = new ShareResource();new Thread(()->{for (int i =1;i<3;i++){try {shareResource.printAA(i);} catch (InterruptedException e) {e.printStackTrace();}}},"AA").start();new Thread(()->{for (int i =0;i<2;i++){try {shareResource.printBB(i);} catch (InterruptedException e) {e.printStackTrace();}}},"BB").start();new Thread(()->{for (int i =0;i<2;i++){try {shareResource.printCC(i);} catch (InterruptedException e) {e.printStackTrace();}}},"CC").start();}
    }/*** 定义资源类*/
    class ShareResource{//定义线程状态 1:AA线程执行   2:BB线程执行   3:CC线程执行private int flag = 1;final ReentrantLock lock = new ReentrantLock();final Condition conditionA = lock.newCondition();final Condition conditionB = lock.newCondition();final Condition conditionC = lock.newCondition();public void printAA(int loop) throws InterruptedException {lock.lock();try {//判断条件while (flag != 1) {conditionA.await();}//干活for (int i=1;i<6;i++){System.out.println(Thread.currentThread().getName() + "::轮数" + loop + ",打印:" + i);}flag=2;//通知其他线程conditionB.signal();}finally {lock.unlock();}}public void printBB(int loop) throws InterruptedException {lock.lock();try {//判断条件while (flag != 2) {conditionB.await();}//干活for (int i=1;i<11;i++){System.out.println(Thread.currentThread().getName() + "::轮数" + loop + ",打印:" + i);}flag=3;//通知其他线程conditionC.signal();}finally {lock.unlock();}}public void printCC(int loop) throws InterruptedException {lock.lock();try {//判断条件while (flag != 3) {conditionC.await();}//干活for (int i=1;i<16;i++){System.out.println(Thread.currentThread().getName() + "::轮数" + loop + ",打印:" + i);}flag=1;//通知其他线程conditionA.signal();}finally {lock.unlock();}}
    }
    
5、集合安全
List:

ArrayList线程不安全,替代方案有三个

1)Vector vector = new Vector();
2)Collections工具类:List list = Collections.synchronizedList(new ArrayList<>());

3)CopyOnWriteArrayList: List list = new CopyOnWriteArrayList();

Set:

HashSet线程不安全,替代方案用CopyOnWriteSet

Map:

HashMap线程不安全,替代方案用:ConcurrentHashMap

package com.vike.juctest.collection;import java.util.*;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.CopyOnWriteArrayList;
import java.util.concurrent.CopyOnWriteArraySet;/*** 集合的线程安全问题**/
public class ThreadCollertion {public static void main(String[] args) {ThreadCollertion threadCollertion = new ThreadCollertion();
//        threadCollertion.mainList();
//        threadCollertion.mainSet();threadCollertion.mainmap();}public void mainList(){//        List list = new ArrayList();//        List list = new Vector();//        List list = Collections.synchronizedList(new ArrayList<>());List list = new CopyOnWriteArrayList();for (int i = 0; i < 30; i++) {new Thread(()->{list.add(UUID.randomUUID().toString().substring(0, 8));System.out.println(list);}, String.valueOf(i)).start();}}public void mainSet(){
//        Set<String> set = new HashSet<>();Set<String> set = new CopyOnWriteArraySet<>();for (int i = 0; i < 30; i++) {new Thread(()->{set.add(UUID.randomUUID().toString().substring(0, 8));System.out.println(set);},String.valueOf(i)).start();}}public void mainmap(){
//        Map<String, String> map = new HashMap<>();Map<String, String> map = new ConcurrentHashMap<>();for (int i = 0; i < 30;i++) {String key = String.valueOf(i);new Thread(() -> {map.put(key, UUID.randomUUID().toString().substring(0, 8));System.out.println(map);}, String.valueOf(i)).start();}}
}
6、多线程锁

公平锁和非公平锁,案例:买票案例,线程AA可能把所有的票卖完,BB和CC则没卖出去票,

公平锁:效率低,需要判定是否公平

非公平锁:效率高,线程饿死

private final ReentrantLock lock = new ReentrantLock(false);//非公平锁

private final ReentrantLock lock = new ReentrantLock(true);//公平锁

死锁:两个或者两个以上的进程在执行过程中,因为争夺资源而造成一种互相等待的现象,如果没有外力干涉,他们无法再执行下去

死锁可以通过jps -l 查看java线程id,然后通过jstack 线程id 查看线程死锁

public class DeadLock {public static void main(String[] args) {Object a = new Object();Object b = new Object();new Thread(()->{synchronized (a){System.out.println(Thread.currentThread().getName()+":持有锁a,试图获取锁b");try {TimeUnit.SECONDS.sleep(1);} catch (InterruptedException e) {e.printStackTrace();}synchronized (b){System.out.println(Thread.currentThread().getName()+":获取锁b");}}},"a").start();new Thread(()->{synchronized (b){System.out.println(Thread.currentThread().getName()+":持有锁b,试图获取锁a");try {TimeUnit.SECONDS.sleep(1);} catch (InterruptedException e) {e.printStackTrace();}synchronized (a){System.out.println(Thread.currentThread().getName()+":获取锁a");}}},"b").start();}
}
7、方式实现多线程

实现多线程的四种方式

Runnable和Callable两种方式比较

1)有无返回参数:Callable有返回参数

2)对外是否返回异常:Callable调用call方法返回异常

3)实现方式不同,一个是run方法,一个是call方法

######1)集成Thread类

class MyThread extends Thread{@Overridepublic void run() {System.out.println("线程执行");}
}

######2)实现Runnable接口

class TheradRunnable implements Runnable{@Overridepublic void run() {System.out.println(Thread.currentThread().getName() + " run方法执行");}
}

######3)实现Callable接口

class ThreadCallable implements Callable<Integer>{@Overridepublic Integer call() throws Exception {System.out.println(Thread.currentThread().getName() + " call方法执行");return 200;}
}

######4)线程池的方式

下边详细说明

8、辅助类(计数器、循环栅栏、信号灯)的使用
1)CountDownLatch(计数器)

模拟场景:现场有6个同学,最后一个同学离开之后,班长锁门

public class CountDownLatchDemo {public static void main(String[] args) throws InterruptedException {CountDownLatchDemo demo = new CountDownLatchDemo();
//        demo.test1();demo.test2();}/*** 不采用CountDownLatch的时候*/public void test1(){for (int i = 1; i < 7; i++) {new Thread(() -> {System.out.println(Thread.currentThread().getName() + "号同学离开教室");}, String.valueOf(i)).start();}System.out.println("班长锁门");}/*** 不采用CountDownLatch的时候,班长不是最后锁门的* 采用CountDownLatch的时候*/public void test2() throws InterruptedException {CountDownLatch countDownLatch = new CountDownLatch(6);for (int i = 1; i < 7; i++) {new Thread(() -> {System.out.println(Thread.currentThread().getName() + "号同学离开教室");countDownLatch.countDown();System.out.println("剩下同学人数:"+countDownLatch.getCount());}, String.valueOf(i)).start();}System.out.println("班长等待最后同学离开");countDownLatch.await();System.out.println("班长锁门");}
}
2)CyclicBarrier(循环栅栏)
/*** 循环栅栏CyclicBarrier* CyclicBarrier看英文单词,大概可以看出是循环阻塞的意思,在使用中CyclicBarrier的构造方法第一个参数是目标障碍数,如果阻塞达到目标* 障碍数,才会执行cyclicBarrier.await()之后的语句,可以将CyclicBarrier理解为加1操作** 模拟场景:集齐7颗龙珠可以召唤神龙*/
public class CyclicBarrierDemo {private static final Integer NUMBER = 7;public static void main(String[] args) {CyclicBarrier cyclicBarrier = new CyclicBarrier(NUMBER,()->{System.out.println("集齐7颗龙珠,可以召唤神龙了");});for (int i = 1; i < 8; i++) {new Thread(() -> {try {System.out.println(Thread.currentThread().getName() + "星珠已经收集到了");cyclicBarrier.await();} catch (Exception e) {e.printStackTrace();}}, String.valueOf(i)).start();}}
}
3)Semaphore(信号灯)
/*** Semaphore 信号灯* 一个计数信号量,从概念上讲,信号量维护了一个许可集,如果有必要,在许可可用前会阻塞一个acquire(),然后再获取该许可* 每个release()添加一个许可,从而可能释放一个正在阻塞的获取着,但是,不使用实际的许可对象,Semaphore只对可用许可号码进行计数,* 并采取相应的行动** 例子:六辆汽车抢三个停车位**/
public class SemaphoreDemo {public static void main(String[] args) {//创建Semaphore,设置许可数量Semaphore semaphore = new Semaphore(3);for (int i = 0; i < 6; i++) {new Thread(() -> {try {//抢占许可semaphore.acquire();System.out.println(Thread.currentThread().getName() + " 抢到了车位");int timeForTC = new Random().nextInt(5);System.out.println(Thread.currentThread().getName() + "停车" + timeForTC + "秒钟");//随机设置停车时间TimeUnit.SECONDS.sleep(timeForTC);System.out.println(Thread.currentThread().getName()+" -----------离开了车位");} catch (InterruptedException e) {e.printStackTrace();}finally {semaphore.release();}}, String.valueOf(i + 1)).start();}}
}
9、读写锁

1、读锁是共享锁,写锁是独占锁

2、读写互斥,读读共享

/*** 读写锁* 读锁是共享锁,可以多个线程共享* 写锁时独占锁,只能单个线程占用* 读写是互斥的* 读读是共享的* synchronized和ReentrantLock都是独占锁*/
public class ReadWriteLockDemo {public static void main(String[] args) {MyCache cache = new MyCache();//创建存放线程for (int i = 0; i < 3; i++) {final int num =i;new Thread(() -> {cache.put(String.valueOf(num), String.valueOf(num));}, String.valueOf(i)).start();}//创建读取线程for (int i = 0; i < 3; i++) {final int num =i;new Thread(() -> {Object o = cache.get(String.valueOf(num));}, String.valueOf(i)).start();}}
}/*** 定义资源类*/
class MyCache {private volatile Map<String, Object> map = new HashMap<>();ReentrantReadWriteLock reentrantReadWriteLock = new ReentrantReadWriteLock();/*** map中放值*/public void put(String key,Object value){ReentrantReadWriteLock.WriteLock writeLock = reentrantReadWriteLock.writeLock();try {writeLock.lock();System.out.println(Thread.currentThread().getName() + "正在写操作" + key);TimeUnit.MICROSECONDS.sleep(300);map.put(key, value);System.out.println(Thread.currentThread().getName() + "写完了" + key);} catch (InterruptedException e) {e.printStackTrace();}finally {writeLock.unlock();}}/*** map中取值*/public Object get(String key){Object result = null;ReentrantReadWriteLock.ReadLock readLock = reentrantReadWriteLock.readLock();try {readLock.lock();System.out.println(Thread.currentThread().getName() + "正在读操作" + key);TimeUnit.MICROSECONDS.sleep(300);result = map.get(key);System.out.println(Thread.currentThread().getName() + "读完了" + key + ",值是" + result);} catch (InterruptedException e) {e.printStackTrace();}finally {readLock.unlock();}return result;}
}
10、阻塞队列

阻塞队列BlockingQueue

当队列中元素已满的时候再往里放值会阻塞

当队列中元素为空的时候再取值会阻塞

队列:先进先出 栈:后进先出

队列中的API分为四组

  • 抛异常:add(e),remove(),element()

  • 返回特殊值:offer(e),poll(),peek()

  • 阻塞:put(e),take()

  • 超时退出:offer(e,time,unit),poll(time,unit)

    public class BlockingQueueDemo {public static void main(String[] args) throws InterruptedException {ArrayBlockingQueue<String> queue = new ArrayBlockingQueue<>(3);/*** 第一组:add():放值,当队列已满的时候会抛异常* remove():取值,当队列为空的时候会抛异常* elemeng():判断队列是否有值*///        System.out.println(queue.add("a"));
    //        System.out.println(queue.add("b"));
    //        System.out.println(queue.add("c"));//        System.out.println(queue.add("w"));
    //        System.out.println(queue.remove());
    //        System.out.println(queue.remove());
    //        System.out.println(queue.remove());
    //        System.out.println(queue.remove());
    //        System.out.println(queue.add("a"));
    //        System.out.println(queue.element());
    //        System.out.println(queue.element());/*** 第二组:* offer():放值,如果未满返回true,否则返回false* poll():取值,如果为空返回null,否则返回true* peek():判断是否有值,如果有值返回true,否则返回null*/
    //        System.out.println(queue.offer("a"));
    //        System.out.println(queue.offer("b"));
    //        System.out.println(queue.offer("c"));
    //        System.out.println(queue.offer("w"));
    //        System.out.println(queue.poll());
    //        System.out.println(queue.poll());
    //        System.out.println(queue.offer("a"));
    //        System.out.println(queue.peek());/*** 第三组* put(e):放值* take():取值*/queue.put("a");queue.put("a");queue.put("a");
    //        queue.put("a");/*** 第四组:* offer(e,time,unit):放值,如果阻塞超过unit时间,则不再等待* poll(time,unit):取值,如果阻塞超过unit时间,则不再等待*/queue.offer("a", 1l, TimeUnit.SECONDS);queue.offer("a", 1l, TimeUnit.SECONDS);queue.offer("a", 1l, TimeUnit.SECONDS);queue.offer("a", 1l, TimeUnit.SECONDS);}
    }
    
11、线程池
  • 优点:

  • 1.降低资源消耗,通过复用已创建的线程降低线程创建和销毁造成的消耗

  • 2.提高响应速度,当任务达到时,任务可以不需要等待线程创建就可以立刻执行

  • 3.提高线程的可管理性,线程属于稀缺资源,如果无限制的创建,不仅会消耗系统资源,还会降低系统的稳定性

    创建线城池采用工具列Executers,线程池分类:

    • 1)newFixedThreadPool(常用):创建一个可重用的固定线程数的线程池,以共享无界队列的方式运行这些线程,线程池内部线程都处于运行状态

    • 当再次新增附加线程,则线程在队列中等待,直到有可用线程为止

    • 特征:1、线程池中的线程数量是固定的,可以很好的控制线程的并发量

    • 2、线程可以重复使用,在显式关闭之前,线程一直存在

    • 3、超出一定量的线程被提交的时候需在队列中等待

    • 2)newSingleThreadExecutor(),单一线程的线程池
      *

      1. newCachedThreadPool(),可变线程数量的线程池

      三个线程池的构造方法都是通过ThreadPoolExecutor类实现的

      ThreadPoolExecutor类的构造方法参数详解

      • int corePoolSize:核心线程数量,常驻线程数量

      • int maximumPoolSize:线程池最大线程数量

      • long keepAliveTime:线程存活时间,当线程数超过核心线程数之后,并且处于非活跃状态超过keepAliveTime之后被回收

      • TimeUnit unit:线程存活时间单位

      • BlockingQueue workQueue:阻塞队列

      • ThreadFactory threadFactory:线程工厂,用于创建线程

      • RejectedExecutionHandler handler:拒绝策略,当线程达到最大线程数时的拒绝策略

      • 核心线程 > 阻塞队列 > 最大线程数 > 拒绝策略

      • 1、当有线程请求时,首先通过核心线程运行

      • 2、当核心线程达到最大时,新线程添加到阻塞队列中

      • 3、当阻塞队列达到最大时,并且线程池没达到最大线程数,则新建线程,优先新线程执行

      • 4、当线程池达到最大线程数时,再有新线程到达时,采用拒绝策略

       ```javapublic class Demo1 {public static void main(String[] args) {//可重用固定容量线程池ExecutorService executorService = Executors.newFixedThreadPool(5);//单一线程的线程池//        ExecutorService executorService = Executors.newSingleThreadExecutor();//长度可变的线程池//        ExecutorService executorService = Executors.newCachedThreadPool();try{for (int i = 0; i < 10; i++) {executorService.execute(()->{System.out.println(Thread.currentThread().getName() + " 正在执行!");try {TimeUnit.SECONDS.sleep(2);} catch (InterruptedException e) {e.printStackTrace();}});}}catch (Exception e){e.printStackTrace();}finally {System.out.println("====================程序执行完毕");executorService.isShutdown();}}}```
      

线程池在使用的时候一般不采用工具类的形式,大都采用自定义的方式,如下

public class Demo1 {public static void main(String[] args) {//可重用固定容量线程池ExecutorService executorService = Executors.newFixedThreadPool(5);//单一线程的线程池
//        ExecutorService executorService = Executors.newSingleThreadExecutor();//长度可变的线程池
//        ExecutorService executorService = Executors.newCachedThreadPool();try{for (int i = 0; i < 10; i++) {executorService.execute(()->{System.out.println(Thread.currentThread().getName() + " 正在执行!");try {TimeUnit.SECONDS.sleep(2);} catch (InterruptedException e) {e.printStackTrace();}});}}catch (Exception e){e.printStackTrace();}finally {System.out.println("====================程序执行完毕");executorService.isShutdown();}}
}
12、分支与合并
  • 线程的分支及合并

  • 场景模拟:从1到100,实现相加,如果两数相差大于10,则分支,采用二分查找法,对数值进行分支

  • 1.。。10 11.。。。20 。。。。 91.。。。。100

  • 用到类

  • ForkJoinPool 分支合并池

  • RecursiveTask extends ForkJoinTask

    public class Demo1 {public static void main(String[] args) throws ExecutionException, InterruptedException {long startTimes1 = System.currentTimeMillis();MyTask2 task = new MyTask2(0, 100);Integer compute = task.compute();System.out.println(compute);long endTimes1 = System.currentTimeMillis();System.out.println("单线程用时:" + (endTimes1 - startTimes1));long startTimes = System.currentTimeMillis();//创建task对象MyTask myTask = new MyTask(0, 100);//创建分支合并池对象ForkJoinPool forkJoinPool = new ForkJoinPool();ForkJoinTask<Integer> forkJoinTask = forkJoinPool.submit(myTask);//获取最终合并结果Integer integer = forkJoinTask.get();System.out.println(integer);//关闭分支合并池forkJoinPool.shutdown();long endTimes = System.currentTimeMillis();System.out.println("多线程用时:" + (endTimes - startTimes));}
    }/*** 任务执行类*/
    class MyTask extends RecursiveTask<Integer> {private static final Integer LIMIT = 10;private int start;private int end;private int result;public MyTask(int start,int end){this.start=start;this.end=end;}@Overrideprotected Integer compute() {if((end-start)>LIMIT){int middle = (end+start)/2;MyTask myTask1 = new MyTask(start, middle);MyTask myTask2 = new MyTask(middle + 1, end);myTask1.fork();myTask2.fork();result = myTask1.join() + myTask2.join();}else {for (int i = start; i <=end; i++) {result = result + i;}}return result;}
    }/*** 任务执行类*/
    class MyTask2 {private static final Integer LIMIT = 10;private Integer start;private Integer end;private Integer result;public MyTask2(Integer start,Integer end){this.start=start;this.end=end;}protected Integer compute() {if((end-start)>LIMIT){Integer middle = (end+start)/2;MyTask myTask1 = new MyTask(start, middle);MyTask myTask2 = new MyTask(middle + 1, end);result = myTask1.compute() + myTask2.compute();}else {for (int i = start; i <=end; i++) {result = result + i;}}return result;}
    }
    

13、异步回调

线程的同步与异步,采用CompletableFuture类

异步是调用completableFuture.whenComplete().get()方法,其中whenComplete传参为消费性函数式编程对象

其中T:异步调用成功返回值

U:异常时的异常信息

public class CompletableFutureDemo {public static void main(String[] args) throws ExecutionException, InterruptedException {CompletableFutureDemo completableFutureDemo = new CompletableFutureDemo();
//        completableFutureDemo.synchronize();
//        System.out.println("------------------------------------------------------");completableFutureDemo.asynchronous();}/*** Synchronize* 线程同步调用,调用completableFuture.get()方法时线程会阻塞,等到子线程执行完之后再继续执行*/private void synchronize() throws ExecutionException, InterruptedException {//同步调用//runAsync 同步调用CompletableFuture<Void> completableFuture = CompletableFuture.runAsync(()->{try {TimeUnit.SECONDS.sleep(3);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName() + "线程调用!");});System.out.println("线程执行2");//同步调用返回结构completableFuture.get();System.out.println("线程调用3");}/*** asynchronous* whenComplete 实现异步回调* 参数解析:*      t:成功返回值*      u:失败的异常信息*/private void asynchronous() throws ExecutionException, InterruptedException {CompletableFuture<Integer> completableFuture = CompletableFuture.supplyAsync(()->{try {TimeUnit.SECONDS.sleep(3);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName() + "子线程调用");return 200;});System.out.println("线程执行2");completableFuture.whenComplete((Object t,Object u)->{System.out.println(t);System.out.println(u);}).get();System.out.println("线程执行结束");}
}
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 程序员这条路,技术往深度走还是广度走会比较好?看完这篇文章你就明白了

    有人认为程序员应该对自己的技术始终保持忠诚&#xff0c;有人认为集百家武学于一身才是正道&#xff0c;如何权衡技术深度与广度&#xff1f;这是大多数程序员都会面临和思考的问题。 在有限的时间里能学习的东西也是有限的&#xff0c;那么在我们决定去学习之前&#xff0c;…...

    2024/4/15 1:36:53
  2. FFmpeg视频转码

    视频转码 ffmpeg -i input.ogv -vcodec h264 output.mp4 ffmpeg -i input.ogv -vcodec mpeg4 output.mp4 ffmpeg -i input.ogv -vcodec libxvid output.mp4 ffmpeg -i input.mp4-vcodec wmv1 output.wmv ffmpeg -i input.mp4-vcodec wmv2 output.wmvi&#xff1a;输入文件名vc…...

    2024/4/19 11:28:07
  3. 计算机网络复习知识点

    声明&#xff1a; 这些东西是我期末复习周在B站看王道408讲解视频做的一些笔记和知识点&#xff0c;当中也有期末考试考点。所以有想期末突击的欢迎来康康&#xff0c;这也是我写的第一篇文章&#xff0c;有问题欢迎指证&#xff01; 第一章 概论 一、概论 1.1速率定义&…...

    2024/5/1 14:59:47
  4. 机器视觉学习笔记(四)-- 数据结构

    3.1.1 图像 很直观地&#xff0c;图像通道可以被简单看作是一个二维数组&#xff0c;这也是程序设计语言中表示图像时所使用的数据结构。因此&#xff0c;在像素(r&#xff0c;c)处的灰度值可以被解释为矩阵&#xff1a;中的一个元素。使用更正规的描述方式&#xff0c;我们能…...

    2024/5/1 8:47:57
  5. VisionMaster二次开发流程运行完毕回调事件使用

    首先强调一下&#xff0c;海康的VisionMaster视觉库已经覆盖绝大部分视觉检测应用&#xff0c;有点向康耐视VisionPro及Designer挑战的意思&#xff0c;当然二次开发起来也是非常方便&#xff0c;赞赞赞。 原先对VM套路不太熟悉的时候&#xff0c;流程Run后延时500ms再获取结果…...

    2024/4/18 0:28:58
  6. 腾讯面试,万字攻略详解, offer到碗里来

    本文一万字&#xff0c;以非腾讯在职人的身份&#xff0c;来聊腾讯面试的流程、攻略和建议&#xff0c;但愿能助有缘人。 标题涉及的范围很广&#xff0c;对多数面试腾讯的人而言&#xff0c;都有参考价值&#xff0c;看完本文之后&#xff0c;必有所得。 退一步来讲&#xf…...

    2024/4/15 1:37:03
  7. 力扣题33搜索旋转排序数组

    整数数组 nums 按升序排列&#xff0c;数组中的值 互不相同 。 在传递给函数之前&#xff0c;nums在预先未知的某个下标 k&#xff08;0 < k<nums.length&#xff09;上进行了旋转&#xff0c;使数组变为[nums[k],nums[k1], ..., nums[n-1], nums[0], nums[1], ..., num…...

    2024/4/15 1:36:53
  8. gh4163磁导率gh4163用途是什么

    一&#xff1a;牌号&#xff1a;Nimonic263/alloy263/gh4163/n07263/2.4650镍基沉淀硬化型变形高温合金 二&#xff1a;化学成分&#xff1a; C&#xff1a;≤0.04&#xff5e;0.08 Cr&#xff1a;19&#xff5e;21 Ni&#xff1a;余量 Mo&#xff1a;5.6&#xff5e;6…...

    2024/5/1 12:55:22
  9. Visual Studio插件CodeRush今年第二个重大版本发布——v21.2.3

    CodeRush是一个强大的Visual Studio .NET 插件&#xff0c;它利用整合技术&#xff0c;通过促进开发者和团队效率来提升开发者体验。CodeRush能帮助你以极高的效率创建和维护源代码。Consume-first 申明&#xff0c;强大的模板&#xff0c;智能的选择工具&#xff0c;智能代码分…...

    2024/4/5 6:04:01
  10. 2353409-72-8,N-(DBCO-PEG4)-N-Biotin-PEG4-NHS点击化学生物素化试剂,PEG试剂衍生物

    英文名称&#xff1a;N-(DBCO-PEG4)-N-Biotin-PEG4-NHS 化学式&#xff1a;C50H71N5O14S 分子量&#xff1a;998.2 CAS&#xff1a;2353409-72-8 纯度&#xff1a;95% 储存条件&#xff1a;-20C 运输&#xff1a;环境温度 结构式&#xff1a; 产品简介&#xff1a;N-&am…...

    2024/4/17 12:31:30
  11. Java+Swing+Mysql学生成绩管理系统(DAY 3)

    package com.test;import java.awt.*;import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JPanel;public class FlowLayoutTest extends JFrame{//JPanel默认流式布局管理器FLowLayout/*FlowLayout()参数1&#xff1a;对齐方式&#xff0c;默认居中对…...

    2024/4/15 1:37:03
  12. maven之发布

    https://zhuanlan.zhihu.com/p/141676033...

    2024/4/28 7:37:37
  13. BigDecimal比较建议用compareTo及与equals区别

    作者&#xff1a;坚持就是胜利 juejin.im/post/5d5a3882f265da03d60effb0 前言 前两天测试发现一个Bug&#xff0c;告诉我说他明明只修改了订单详情中商品的数量&#xff0c;为什么提示说订单中商品单价不能修改&#xff08;后台限制了特殊单子的单价不能修改&#xff09;&…...

    2024/4/17 9:19:08
  14. javaweb概述

    1.POST传输数据大小无限制 2.POST比GET请求方式更安全 3.使用GET方式传送的数据有限&#xff0c;最多不能超过2KB 状态代码&#xff1a;&#xff08;由3位数字组成&#xff09; 1xx&#xff1a;成功接收请求&#xff0c;要求客户端继续提交下一次请求才能完成整个处理过程2x…...

    2024/4/18 4:47:59
  15. Linux权限详解

    在理解权限之前我们要知道linux中的用户组&#xff1a; 在Linux中每个用户都属于一个组&#xff0c;Linux中每个文件都都有所有者、所有组、其他组。这几个概念我们可以用现实中的例子来理解。比如说你有一本书&#xff0c;那么你就是这本书的所有者&#xff0c;你有这本书的最…...

    2024/4/19 19:00:59
  16. D-Link DCS系列监控 账号密码信息泄露漏洞

    漏洞简介 D-Link DCS-2200是一款监控摄像机&#xff0c;成像色彩为彩色 是一款网络摄像机&#xff0c; 根据VULDB 所看到的信息原文如下 A vulnerability, which was classified as problematic, was found in D-Link DCS-2530L and DCS-2670L (the affected version unknow…...

    2024/4/15 1:37:23
  17. leetcode刷题:1218. 最长定差子序列

    题目 给你一个整数数组 arr 和一个整数 difference&#xff0c;请你找出并返回 arr 中最长等差子序列的长度&#xff0c;该子序列中相邻元素之间的差等于 difference 。 子序列 是指在不改变其余元素顺序的情况下&#xff0c;通过删除一些元素或不删除任何元素而从 arr 派生出…...

    2024/4/15 1:36:48
  18. 2021-11-05 PageHelper记录

    PageHelper记录 项目基础是&#xff1a;sqlserver2017springboot 在引入pagehelper包以后&#xff0c;一直无效 使用方式是PageHelper.startPage(1,20) 解决方案是&#xff1a; 将maven本地仓库清空&#xff0c;重新引入 结果报出了offset附近有语法错误&#xff0c; 加上…...

    2024/4/18 15:33:20
  19. lintcode-1483 · 最高平均分

    题目描述 给出一组学生的名字以及他们的成绩&#xff0c;求最高的平均分(一位学生可能有多门课成绩) 样例 例 1: 输入:names ["bob","ted","ted"] grades[88,100,20] 输出:88例 2: 输入: names ["john","xisa","…...

    2024/4/15 1:37:03
  20. SpringBoot 原理

    1. SpringBoot原理深入及源码剖析 传统的Spring框架实现一个Web服务&#xff0c;需要导入各种依赖JAR包&#xff0c;然后编写对应的XML配置文件等&#xff0c;相较而言&#xff0c;Spring Boot显得更加方便、快捷和高效。那么&#xff0c;Spring Boot究竟如何做到这些的呢&…...

    2024/4/15 1:37:18

最新文章

  1. 【Java EE】多线程(二)Thread 类与常用方法

    &#x1f4da;博客主页&#xff1a;爱敲代码的小杨. ✨专栏&#xff1a;《Java SE语法》 | 《数据结构与算法》 | 《C生万物》 |《MySQL探索之旅》 |《Web世界探险家》 ❤️感谢大家点赞&#x1f44d;&#x1f3fb;收藏⭐评论✍&#x1f3fb;&#xff0c;您的三连就是我持续更…...

    2024/5/1 15:34:09
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. uos安装lxml避坑记录

    环境&#xff1a;紫光电脑uos系统 python&#xff1a;系统自带3.7.3 条件&#xff1a;已打开开发者模式&#xff0c;可以自行安装应用商店之外的软件 一、pip3 install lxml4.8.0可以正正常下载&#xff0c;但出现如下错误 另&#xff1a;为什么是4.8.0&#xff1f;因为这个…...

    2024/4/30 3:14:16
  4. 【嵌入式开发 Linux 常用命令系列 4.3 -- git add 不 add untracked file】

    请阅读【嵌入式开发学习必备专栏 】 文章目录 git add 不add untracked file git add 不add untracked file 如果你想要Git在执行git add .时不添加未跟踪的文件&#xff08;untracked files&#xff09;&#xff0c;你可以使用以下命令&#xff1a; git add -u这个命令只会加…...

    2024/4/30 3:18:10
  5. 最新在线工具箱网站系统源码

    内容目录 一、详细介绍二、效果展示1.部分代码2.效果图展示 三、学习资料下载 一、详细介绍 系统内置高达72种站长工具、开发工具、娱乐工具等功能。此系统支持本地调用API&#xff0c;同时还自带免费API接口&#xff0c; 是一个多功能性工具程序&#xff0c;支持后台管理、上…...

    2024/5/1 13:29:34
  6. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/4/29 23:16:47
  7. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/4/30 18:14:14
  8. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/29 2:29:43
  9. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/4/30 18:21:48
  10. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/27 17:58:04
  11. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/27 14:22:49
  12. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/28 1:28:33
  13. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/30 9:43:09
  14. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/27 17:59:30
  15. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/4/25 18:39:16
  16. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/28 1:34:08
  17. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  18. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/29 20:46:55
  19. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/30 22:21:04
  20. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/5/1 4:32:01
  21. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/4/27 23:24:42
  22. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/28 5:48:52
  23. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/30 9:42:22
  24. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/4/30 9:43:22
  25. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/30 9:42:49
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; 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
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在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