线程同步(多人过山洞)

2024-03-02 21:18
文章标签 线程 同步 山洞 多人过

本文主要是介绍线程同步(多人过山洞),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概念:当两个或两个以上的线程需要共享资源,它们需要某种方法来确定资源在某一刻仅被一个线程占用。达到此目的的过程叫做同步(synchronization)。

同步的关键是管程(也叫信号量semaphore)的概念。管程是一个互斥独占锁定的对象,或称互斥体(mutex)。在给定的时间,仅有一个线程可以获得管程。当一个线程需要锁定,它必须进入管程。所有其他的试图进入已经锁定的管程的线程必须挂起直到第一个线程退出管程。这些其他的线程被称为等待管程。一个拥有管程的线程如果愿意的话可以再次进入相同的管程。

任何时候在多线程情况下,你有一个方法或多个方法操纵对象的内部状态,都必须用synchronized 关键字来防止状态出现竞争。一旦线程进入实例的同步方法,没有其他线程可以进入相同实例的同步方法。该实例的其他不同步方法却仍然可以被调用。

多人过山洞的实现:

package cn.thread.cave.day23;public class Cave {/*** 人过山洞:*/public synchronized void passCave(Person person){System.out.println(person.getName()+"进入山洞!");try{Thread.sleep(2000);}catch(InterruptedException e){e.printStackTrace();}System.out.println(person.getName()+"已成功通过山洞");}
}

package cn.thread.cave.day23;public class Person {private String name;/*** 构造方法*/public Person(String name){this.name=name;}/*** 设置名字    获取名字*/public String getName(){return name;}public void setName(String name){this.name=name;}
}


package cn.thread.cave.day23;public class PersonPassCave implements Runnable{Cave cave;Person person;public PersonPassCave(Cave cave,Person person){this.cave=cave;this.person=person;new Thread(this).start();//this:实现Runnable的实例}@Overridepublic void run() {cave.passCave(person);}
}

package cn.thread.cave.day23;
/** * java实现线程同步 关键字 synchronized*    同步资源是方法  *       在方法头部返回值前加上synchronized*       synchronized void callMe(){*          //*       }*       *    同步资源是语句*       synchronized(object){*          //同步语句块*       }*  编程题1.编写多线程应用程序,模拟多个人通过一个山洞。这个山洞每次只能通过一个人,每个人通过山洞的时间为5秒,随机生成10个人,同时准备过此山洞,显示每次通过山洞人的姓名。*/
public class PersonPassCaveTest {public static void main(String[] args) {Person p1 = new Person("张一");Person p2 = new Person("张二");Person p3 = new Person("张三");Person p4 = new Person("张四");Person p5 = new Person("张五");Cave cave = new Cave();PersonPassCave ppc = new PersonPassCave(cave,p1);new PersonPassCave(cave,p2);new PersonPassCave(cave,p3);new PersonPassCave(cave,p4);new PersonPassCave(cave,p5);/*** 构造方法中不用this实现Runnable的实例,写法应如下:*/
//		PersonPassCave ppc = new PersonPassCave(cave,p1);
//		Thread t1 = new Thread(ppc);
//		t1.start();//		Thread t2 = new Thread(new PersonPassCave(cave,p2));
//		t2.start();}
}



这篇关于线程同步(多人过山洞)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/767450

相关文章

线程池ThreadPoolExecutor应用过程

《线程池ThreadPoolExecutor应用过程》:本文主要介绍如何使用ThreadPoolExecutor创建线程池,包括其构造方法、常用方法、参数校验以及如何选择合适的拒绝策略,文章还讨论... 目录ThreadPoolExecutor构造说明及常用方法为什么强制要求使用ThreadPoolExec

Java线程池核心参数原理及使用指南

《Java线程池核心参数原理及使用指南》本文详细介绍了Java线程池的基本概念、核心类、核心参数、工作原理、常见类型以及最佳实践,通过理解每个参数的含义和工作原理,可以更好地配置线程池,提高系统性能,... 目录一、线程池概述1.1 什么是线程池1.2 线程池的优势二、线程池核心类三、ThreadPoolE

JAVA线程的周期及调度机制详解

《JAVA线程的周期及调度机制详解》Java线程的生命周期包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED,线程调度依赖操作系统,采用抢占... 目录Java线程的生命周期线程状态转换示例代码JAVA线程调度机制优先级设置示例注意事项JAVA线程

深入理解Redis线程模型的原理及使用

《深入理解Redis线程模型的原理及使用》Redis的线程模型整体还是多线程的,只是后台执行指令的核心线程是单线程的,整个线程模型可以理解为还是以单线程为主,基于这种单线程为主的线程模型,不同客户端的... 目录1 Redis是单线程www.chinasem.cn还是多线程2 Redis如何保证指令原子性2.

C++实现一个简易线程池的使用小结

《C++实现一个简易线程池的使用小结》在现代软件开发中,多线程编程已经成为提升程序性能的常见手段,本文主要介绍了C++实现一个简易线程池的使用小结,感兴趣的可以了解一下... 在现代软件开发中,多线程编程已经成为提升程序性能的常见手段。无论是处理大量 I/O 请求的服务器,还是进行 CPU 密集型计算的应用

JDK21对虚拟线程的几种用法实践指南

《JDK21对虚拟线程的几种用法实践指南》虚拟线程是Java中的一种轻量级线程,由JVM管理,特别适合于I/O密集型任务,:本文主要介绍JDK21对虚拟线程的几种用法,文中通过代码介绍的非常详细,... 目录一、参考官方文档二、什么是虚拟线程三、几种用法1、Thread.ofVirtual().start(

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

Java JUC并发集合详解之线程安全容器完全攻略

《JavaJUC并发集合详解之线程安全容器完全攻略》Java通过java.util.concurrent(JUC)包提供了一整套线程安全的并发容器,它们不仅是简单的同步包装,更是基于精妙并发算法构建... 目录一、为什么需要JUC并发集合?二、核心并发集合分类与详解三、选型指南:如何选择合适的并发容器?在多

Java中如何正确的停掉线程

《Java中如何正确的停掉线程》Java通过interrupt()通知线程停止而非强制,确保线程自主处理中断,避免数据损坏,线程池的shutdown()等待任务完成,shutdownNow()强制中断... 目录为什么不强制停止为什么 Java 不提供强制停止线程的能力呢?如何用interrupt停止线程s