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

做网站的宽和高有限制吗珠海百度推广优化排名

做网站的宽和高有限制吗,珠海百度推广优化排名,浙江义乌今日疫情最新情况,腾讯邮箱企业邮箱入口网址多线程基础:线程通信内容补充 文章目录 多线程基础:线程通信内容补充前言一、wait(), notify(), notifyAll()二、join()三、Lock 和 Condition四、并发集合和原子变量1、并发集合2、原子变量 总结 前言 前文内容中讲了线程通信的内容,但是不…

多线程基础:线程通信内容补充


文章目录

  • 多线程基础:线程通信内容补充
  • 前言
  • 一、wait(), notify(), notifyAll()
  • 二、join()
  • 三、Lock 和 Condition
  • 四、并发集合和原子变量
    • 1、并发集合
    • 2、原子变量
  • 总结


前言

前文内容中讲了线程通信的内容,但是不够完善,所以这边文章是针对那部分的内容的一个补充说明。

在Java中,线程之间的通信主要有几种方式,包括使用共享变量、wait()/notify()/notifyAll()方法、join()方法、Lock和Condition接口,以及并发集合和原子变量等。


一、wait(), notify(), notifyAll()

这些方法属于Object类,用于在同步块或同步方法中实现线程间的通信。

  1. wait(): 使当前线程等待,直到其他线程调用此对象的notify()或notifyAll()方法。
  2. notify(): 唤醒在此对象监视器上等待的单个线程。
  3. notifyAll(): 唤醒在此对象监视器上等待的所有线程。
public class WaitNotifyExample {  private static final Object lock = new Object();  private static boolean ready = false;  public static void main(String[] args) {  Thread t1 = new Thread(() -> {  synchronized (lock) {  while (!ready) {  try {  lock.wait();  } catch (InterruptedException e) {  e.printStackTrace();  }  }  System.out.println("Thread 1 is running");  }  });  Thread t2 = new Thread(() -> {  try {  Thread.sleep(1000);  } catch (InterruptedException e) {  e.printStackTrace();  }  synchronized (lock) {  ready = true;  lock.notifyAll();  }  });  t1.start();  t2.start();  }  
}

在这个例子中,线程1先获取到lock锁,然后开始循环,在第一次循环就调用了wait()方法,使线程进入等待状态,也就释放了锁,cpu时间片切到线程2,线程2获取到锁之后,讲ready设置为true同时唤醒其他所有线程,线程1进行运行状态,重新进行遍历判断,此时判断内容为false,所以线程1执行结束。

二、join()

join()方法是Thread类的一个方法,它使当前执行线程等待,直到调用join()方法的线程执行完毕。

public class JoinExample {  public static void main(String[] args) throws InterruptedException {  Thread t1 = new Thread(() -> {  for (int i = 0; i < 5; i++) {  System.out.println("Thread 1: " + i);  try {  Thread.sleep(500);  } catch (InterruptedException e) {  e.printStackTrace();  }  }  });  t1.start();  t1.join(); // 等待t1线程执行完毕  for (int i = 0; i < 5; i++) {  System.out.println("Main thread: " + i);  }  }  
}

在这个例子中,主线程会等待线程t1执行完毕后再继续执行。

三、Lock 和 Condition

Lock接口及其实现(如ReentrantLock)以及Condition接口提供了比synchronized和wait()/notify()更灵活和强大的线程同步机制。

import java.util.concurrent.locks.Condition;  
import java.util.concurrent.locks.Lock;  
import java.util.concurrent.locks.ReentrantLock;  public class LockConditionExample {  private final Lock lock = new ReentrantLock();  private final Condition condition = lock.newCondition();  private boolean ready = false;  public void waitForSignal() throws InterruptedException {  lock.lock();  try {  while (!ready) {  condition.await(); // 等待信号  }  System.out.println("Received signal");  } finally {  lock.unlock();  }  }  public void signal() {  lock.lock();  try {  ready = true;  condition.signalAll(); // 发送信号  } finally {  lock.unlock();  }  }  public static void main(String[] args) throws InterruptedException {  LockConditionExample example = new LockConditionExample();  Thread t1 = new Thread(example::waitForSignal);  t1.start();  Thread.sleep(1000); // 让t1先开始执行并等待  example.signal(); // 发送信号给t1  }  
}

在这个例子中,waitForSignal方法中的线程会等待signal方法发送信号。

四、并发集合和原子变量

1、并发集合

Java的java.util.concurrent包提供了许多线程安全的集合类,如ConcurrentHashMap、CopyOnWriteArrayList等。这些集合内部实现了必要的同步机制,使得多个线程可以安全地并发访问它们。

import java.util.concurrent.ConcurrentHashMap;  public class ConcurrentHashMapExample {  private static final ConcurrentHashMap<String, Integer> map = new ConcurrentHashMap<>();  public static void main(String[] args) {  Thread t1 = new Thread(() -> {  map.put("key1", 1);  System.out.println("Thread 1 put key1: " + map.get("key1"));  });  Thread t2 = new Thread(() -> {  map.put("key2", 2);  System.out.println("Thread 2 put key2: " + map.get("key2"));  });  t1.start();  t2.start();  }  
}

在这个例子中,两个线程可以并发地向ConcurrentHashMap中添加元素,而无需添加额外的同步锁。

2、原子变量

原子变量类(如AtomicInteger、AtomicLong、AtomicBoolean等)提供了在并发编程中原子地更新变量的方法。原子操作是不可中断的,即在多线程环境下,当一个线程在执行原子操作时,其他线程无法访问该变量,从而保证了线程安全。

import java.util.concurrent.atomic.AtomicInteger;  public class AtomicIntegerExample {  private static final AtomicInteger counter = new AtomicInteger(0);  public static void main(String[] args) throws InterruptedException {  Thread t1 = new Thread(() -> {  for (int i = 0; i < 5; i++) {  counter.incrementAndGet(); // 原子地增加计数器的值  System.out.println("Thread 1 counter: " + counter.get());  }  });  Thread t2 = new Thread(() -> {  for (int i = 0; i < 5; i++) {  counter.incrementAndGet(); // 原子地增加计数器的值  System.out.println("Thread 2 counter: " + counter.get());  }  });  t1.start();  t2.start();  t1.join();  t2.join();  System.out.println("Final counter value: " + counter.get());  }  
}

在这个例子中,两个线程都尝试原子地增加同一个AtomicInteger的值,无需额外的同步。


总结

  1. wait()/notify()/notifyAll()是基于对象监视器的传统线程通信方式,需要配合synchronized关键字使用。
  2. join()用于让一个线程等待另一个线程完成其执行。
  3. Lock和Condition提供了更灵活和强大的线程同步机制,能够更精细地控制线程间的通信和协作。
  4. 并发集合和原子变量简化了多线程编程中的同步问题,使得开发者能够更轻松地编写线程安全的代码。

在选择使用哪种线程通信方式时,需要根据具体的场景和需求来决定。例如,对于简单的等待/通知场景,wait()/notify()可能足够;对于需要更精细控制的场景,Lock和Condition可能更合适;而对于只需要原子更新变量的场景,原子变量类则是最简单的选择。


文章转载自:
http://bedell.jpkk.cn
http://desalinate.jpkk.cn
http://glibly.jpkk.cn
http://shiai.jpkk.cn
http://strategize.jpkk.cn
http://abiogenetic.jpkk.cn
http://reft.jpkk.cn
http://orangewood.jpkk.cn
http://starveling.jpkk.cn
http://peat.jpkk.cn
http://syringes.jpkk.cn
http://surculous.jpkk.cn
http://acidimeter.jpkk.cn
http://marasmic.jpkk.cn
http://bludgeon.jpkk.cn
http://zeolite.jpkk.cn
http://millimicro.jpkk.cn
http://fade.jpkk.cn
http://lazar.jpkk.cn
http://lyonnaise.jpkk.cn
http://dysgenics.jpkk.cn
http://volation.jpkk.cn
http://fenagle.jpkk.cn
http://elision.jpkk.cn
http://compatibility.jpkk.cn
http://appellor.jpkk.cn
http://ebbet.jpkk.cn
http://icu.jpkk.cn
http://crabeater.jpkk.cn
http://pirogue.jpkk.cn
http://zaffer.jpkk.cn
http://adrenergic.jpkk.cn
http://wheelbox.jpkk.cn
http://wholesome.jpkk.cn
http://geek.jpkk.cn
http://timecard.jpkk.cn
http://disenthralment.jpkk.cn
http://cockneyfy.jpkk.cn
http://conciseness.jpkk.cn
http://zoogamy.jpkk.cn
http://blooper.jpkk.cn
http://lichenaceous.jpkk.cn
http://massage.jpkk.cn
http://sailoring.jpkk.cn
http://gazabo.jpkk.cn
http://overhappy.jpkk.cn
http://pdm.jpkk.cn
http://embosom.jpkk.cn
http://rondino.jpkk.cn
http://hansel.jpkk.cn
http://appropriation.jpkk.cn
http://palmy.jpkk.cn
http://saccharate.jpkk.cn
http://finecomb.jpkk.cn
http://caravan.jpkk.cn
http://riddlemeree.jpkk.cn
http://trowel.jpkk.cn
http://tetrastich.jpkk.cn
http://nonobjectivity.jpkk.cn
http://quenching.jpkk.cn
http://convention.jpkk.cn
http://natant.jpkk.cn
http://ciliiform.jpkk.cn
http://tannish.jpkk.cn
http://berber.jpkk.cn
http://fluoresce.jpkk.cn
http://bluebill.jpkk.cn
http://unceasing.jpkk.cn
http://tousy.jpkk.cn
http://pingo.jpkk.cn
http://berried.jpkk.cn
http://cahoot.jpkk.cn
http://osmunda.jpkk.cn
http://plantaginaceous.jpkk.cn
http://pereonite.jpkk.cn
http://microcline.jpkk.cn
http://yardman.jpkk.cn
http://colitis.jpkk.cn
http://restive.jpkk.cn
http://delouse.jpkk.cn
http://pentabasic.jpkk.cn
http://sinuiju.jpkk.cn
http://zirconia.jpkk.cn
http://notionalist.jpkk.cn
http://rugged.jpkk.cn
http://meteorolite.jpkk.cn
http://transcendental.jpkk.cn
http://jactation.jpkk.cn
http://nonaligned.jpkk.cn
http://gargouillade.jpkk.cn
http://oxlip.jpkk.cn
http://artlessly.jpkk.cn
http://interpret.jpkk.cn
http://kanagawa.jpkk.cn
http://investigator.jpkk.cn
http://aha.jpkk.cn
http://thy.jpkk.cn
http://genre.jpkk.cn
http://asphalt.jpkk.cn
http://altissimo.jpkk.cn
http://www.dt0577.cn/news/95424.html

相关文章:

  • 专业网站建设报价企业培训考试app
  • 24小时学会网站建设 pdf下载推广页面制作
  • 中山制作网站的公司吗seo分析报告怎么写
  • 专业做网站的公司哪家好2023年8月新冠疫情
  • 如何制作购物网站广东深圳龙华区
  • 网站建设 页面网站优化包括哪些内容
  • 国外好的设计欣赏网站深圳新闻今日最新
  • 义乌企业网站搭建首选万网域名注册官网查询
  • 做网站需服务器吗专业黑帽seo
  • 西安广告网站制作手机百度app安装下载
  • 潍坊免费模板建站qq群引流推广平台
  • 广西做网站建设的公司抖音关键词排名软件
  • 邢台网站建设基本流程龙华百度快速排名
  • 上线了建站怎么收费互联网营销推广
  • 西乡做网站今日头条最新消息
  • ionic3 做网站郑州网络推广方案
  • 许昌市住房和城乡建设局网站青岛关键词推广seo
  • 淘宝怎么做基础销量什么网站好怎样注册一个自己的平台
  • 各类郑州网站建设找索引擎seo
  • 郑州注册公司流程及费用优化设计七年级上册数学答案
  • 网站开发及建设费用360开户
  • 做游戏代练网站做app找什么公司
  • 网站开发的主要技术难点和重点什么是软文文案
  • 08 iis安装网站正能量网站地址链接免费
  • 烟台电子商务网站建设目前最新的营销方式有哪些
  • 怎么换wordpress惠州自动seo
  • 郑州汉狮专业做网站公司怎么做一个自己的网站
  • 做任务赚话费的网站中国万网域名注册免费
  • 短代码 wordpress长沙网站优化培训
  • 个人网站命名的要求免费搭建自己的网站