`
dwj147258
  • 浏览: 195730 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

多线程的并发与协作

阅读更多

  多线程可以提高一个项目的运行效率, 多线程之间的协作也不可避免,先举一个简单的例子:先介绍第一个类

package HelloWorld;

public class ThradStudy {
	private String response  ; 
	
	private Object synObj = new Object();
	
	public void start(){
		System.out.println("AAAAAAAAA");
		try{
			synchronized (synObj) {
				synObj.wait(10000);
			}
		}
		catch(Exception e ){
		}
		System.out.println(response);
	}
	
	public void notify(String a ){
		response = a ;
		synchronized(synObj){
			synObj.notifyAll();
		}
	}
}

 这个类有两个私有字段,一个是字符串str , 一个是锁synObj对象,在另一个类中,我们先声明一个ThradStudy对象,在main方法中,启动两个线程,一个线程负责执行start,一个线程负责3秒后唤醒另一个线程代码如下

package HelloWorld;

public class notyFyClass {
	public static ThradStudy test = new ThradStudy() ;
	public static void main(String[] args) {
		new Thread(new Runnable(){

			@Override
			public void run() {
				test.start();
			}
			
		}).start();
		
		new Thread(new Runnable(){
			@Override
			public void run() {
				try {
					Thread.sleep(3000) ;
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
				String str = "唤醒" ;
				test.notify(str);
			}
			
		}).start();
	}
}

 执行结果可以看到,先输出AAAAAAA,而后输出“唤醒”;

这个例子可能不太容易理解,下面分别通过synchronized和Lock来实现生产者和消费者

一、Lock

package HelloWorld;

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class ProduceCustomer {

	public static void main(String[] args) {
		Resouse sss = new Resouse();
		Thread pro = new Thread(new Producer(sss));
		Thread cus = new Thread(new Customer(sss));
		pro.start();
		cus.start();
	}
}
	class Resouse{
		private Lock lock = new ReentrantLock();
		private Condition conditionPro = lock.newCondition() ;
		private Condition conditionCus = lock.newCondition() ;
		private String name ; 
		private int count  = 0 ;
		private boolean flag = false ;  //false 表示没有商品需要生产
		public void set(String name) throws Exception{
			lock.lock();
			try{
			if(flag){
					conditionPro.await();
			}
			count++ ;
			this.name = name+count ;
			conditionCus.signal();
			flag = true ;
			System.out.println("生产   "+this.name);
			}
			finally{
				lock.unlock();
			}
			
			
			
		}
		public void pro() throws Exception{
			lock.lock() ;
			try{
			if(!flag){
				conditionCus.await() ;
			}
			flag = false ;
			System.out.println("消费"+this.name);
			conditionPro.signal();
			}
			finally{
				lock.unlock();
			}
			
		}
		
		
	}
	class Producer extends Resouse implements Runnable{
		private Resouse r ; 
		public Producer(Resouse re){
			super();
			r = re ;
		}
		@Override
		public void run() {
			// TODO Auto-generated method stub
			while(true){
				try {
					r.set("篮球") ;
				} catch (Exception e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
				
			}
		}
		
	}
	class Customer extends Resouse implements Runnable{
		private Resouse r ;
		public Customer(Resouse re ){
			super();
			r = re ;
		}
		@Override
		public void run() {
			// TODO Auto-generated method stub
			while(true){
				try {
					r.pro() ;
				} catch (Exception e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			}
		}
		
	}

 

里面有一个resource类,他里面有一个set和pro方法,set方法负责生产部件,pro方法负责消费部件,如果没有部件就不能消费只能生产,在这里set方法中,如果有部件需要生产则生产一个部件并唤醒消费,如果不需要生产则睡眠,等待消费线程消费完部件后唤醒,Producer类和Customer则是实现线程不断的执行生产和消费

二、synchronized

package HelloWorld;

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class ProduceCustomer {

	public static void main(String[] args) {
		Resouse sss = new Resouse();
		Thread pro = new Thread(new Producer(sss));
		Thread cus = new Thread(new Customer(sss));
		pro.start();
		cus.start();
	}
}
	class Resouse{
		private Object synObj = new Object();
		private String name ; 
		private int count  = 0 ;
		private boolean flag = false ;  //false 表示没有商品需要生产
		public  void set(String name) throws Exception{
			synchronized(synObj){
				if(flag){
					synObj.wait();
			}
			count++ ;
			this.name = name+count ;
			synObj.notify();
			flag = true ;
			System.out.println("生产   "+this.name);
			}
			
			
			
		}
		public void pro() throws Exception{
			synchronized(synObj){
				if(!flag){
					synObj.wait() ;
				}
				flag = false ;
				System.out.println("消费"+this.name);
				synObj.notify();
			}
			
		}
		
		
	}
	class Producer extends Resouse implements Runnable{
		private Resouse r ; 
		public Producer(Resouse re){
			super();
			r = re ;
		}
		@Override
		public void run() {
			// TODO Auto-generated method stub
			while(true){
				try {
					r.set("篮球") ;
				} catch (Exception e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
				
			}
		}
		
	}
	class Customer extends Resouse implements Runnable{
		private Resouse r ;
		public Customer(Resouse re ){
			super();
			r = re ;
		}
		@Override
		public void run() {
			// TODO Auto-generated method stub
			while(true){
				try {
					r.pro() ;
				} catch (Exception e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			}
		}
		
	}

 实现原理和Lock一样

分享到:
评论

相关推荐

    Java 模拟线程并发

    最后,Java并发库还包含了很多其他有用的工具,如Semaphore(信号量)用于控制同时访问特定资源的线程数量,CyclicBarrier(循环屏障)和CountDownLatch(计数器门锁)用于多线程间的协作,以及Lock接口及其实现如...

    并发服务器-多线程服务器详解

    一种典型的多线程并发服务器架构如下: - **主监听线程**:负责接收客户端连接请求。 - **工作线程池**:由多个工作线程组成,负责处理具体的客户端请求。 **3. 示例代码片段** 下面是一个简单的多线程服务器示例...

    java socket 多线程并发控制 hibernate mysql

    本项目聚焦于使用Java的Socket进行多线程并发控制,并结合Hibernate ORM框架与MySQL数据库进行数据存储。下面将详细阐述这些技术及其应用。 首先,Java Socket是Java提供的用于实现网络上不同计算机间进程通信的...

    JDK5中的多线程并发库.doc

    在JDK5中,Java引入了一套强大的多线程并发库,极大地提升了多线程编程的效率和安全性。这个库提供了丰富的类和接口,使得开发者能够更好地控制线程的执行、同步和通信。 1. **线程** - **线程与进程的关系**:...

    多线程并发的demo

    在IT领域,多线程并发是提升程序性能和效率的重要技术。在现代计算机系统中,尤其是在服务器端的应用,如Web项目,多线程并发能够充分利用多核处理器的资源,实现任务并行处理,提高响应速度和服务质量。"多线程并发...

    java多线程和并发.pdf

    Java多线程与并发编程是Java语言中用于处理多任务执行的关键技术,它能够帮助开发者设计出能够有效应对高并发请求的应用程序。在现代的线上(Online)和离线(Offline)应用中,合理利用多线程技术可以大幅提高系统...

    操作系统课设 多线程并发执行 C# WPF

    并发执行涉及线程间的协作与同步。在C#中,`Mutex`, `Semaphore`, `Monitor`以及`lock`语句等工具可以帮助我们控制对共享资源的访问,防止数据竞争和死锁的发生。例如,`lock`关键字提供了一个简单的互斥锁定机制,...

    C#多线程开发之并发编程经典实例.zip

    4. **线程间通信**:`WaitHandle`类(如`AutoResetEvent`, `ManualResetEvent`, `Mutex`, `Semaphore`)用于线程间的通信和同步,`Barrier`则用于多线程分阶段协作。 5. **线程优先级**:`Thread.Priority`属性可以...

    JDK5中的多线程并发库

    在JDK5中,多线程并发库引入了一系列新的特性,极大地增强了Java处理并发问题的能力。以下是关于这个主题的详细解释: 1. **线程**: - **线程与进程的关系**:进程是一个正在执行的程序实体,而线程是进程内部的...

    java 多线程高并发相关资料收集

    在Java编程领域,多线程和高并发是两个至关重要的概念,它们对于构建高效、可扩展的系统至关重要。本文将围绕“Java多线程高并发相关资料收集”这一主题,详细探讨这两个领域的核心知识点。 首先,多线程是指在单个...

    第20章 Part3 多线程互斥与协作.pdf

    ### 第20章 Part3:多线程互斥与协作 #### 一、互斥(Mutual Exclusion) 互斥是指在线程编程中确保多个线程不会同时访问同一资源的技术。这种技术非常重要,因为如果不加以控制,多个线程对共享资源的并发访问...

    张孝祥Java多线程与并发库高级应用笔记

    ### 张孝祥Java多线程与并发库高级应用笔记概览 #### 一、Java多线程技术的重要性与挑战 Java线程技术是软件工程领域不可或缺的一部分,尤其在底层编程、Android应用开发以及游戏开发中,其重要性不言而喻。然而,...

    多线程并发编程-同步与互斥-原⼦变量-并发和⽆锁 数据结构

    多线程并发编程-同步与互斥-原子变量-并发和无锁数据结构 多线程并发编程是提高认程序性能的核心技术,但它也增加了编程的复杂性。因此,系统理解和掌握多线程并发编程的技巧变得尤为重要。本章将从多线程编程的...

    02-4(马士兵)-多线程并发

    在IT领域,多线程并发是程序设计中的一个重要概念,特别是在服务器端开发、高并发应用以及实时系统中。"02-4(马士兵)-多线程并发"可能是一个教学资源,由马士兵老师讲解,涵盖了多线程并发的相关知识。在Java中,...

    深入Java多线程和并发编程

    ### 深入Java多线程与并发编程 在当今高度发展的信息技术领域中,随着硬件技术的进步和软件架构设计的复杂化,多线程与并发编程成为提高程序执行效率、增强系统性能的关键技术之一。本篇文章将围绕Java多线程与并发...

    电信设备-基于线程信息的多线程并发执行跟踪方法及系统.zip

    《基于线程信息的多线程并发执行跟踪方法及系统》是针对电信设备中的多线程并发执行问题提出的一种高效跟踪技术。在现代电信设备中,多线程并发执行是提高系统性能和处理能力的关键,但同时也带来了复杂性和调试难度...

    Java 多线程与并发编程总结

    多线程意味着在一个进程中可以有多个线程并发执行,从而实现任务的并行化。 Java中的多线程是通过JVM来实现的。每个Java应用启动时都会创建一个JVM进程,而程序代码的执行是以线程的形式进行。最常见的例子是主线程...

    操作系统实验:多线程并发程序设计模拟生产者消费问题

    操作系统实验中的多线程并发程序设计是解决经典并发问题——生产者消费者问题的一种方式。生产者消费者问题是进程间通信和同步的经典案例,涉及到共享资源的访问控制和线程的协作。在这个实验中,我们将创建两个线程...

    java多线程处理数据库数据

    通过以上方法,我们可以在Java中有效地利用多线程处理数据库数据,提高程序的并发能力和效率。记得在设计时充分考虑线程间的协作与同步,以及数据库连接的管理和优化,以确保程序的稳定性和性能。

    基于JAVA IO, NIO, Netty, 多线程并发实战源码.zip

    Java IO、NIO和Netty是Java平台中用于处理输入/输出操作的重要组件,而多线程并发则是提升程序性能和响应能力的关键技术。在这个压缩包"基于JAVA IO, NIO, Netty, 多线程并发实战源码.zip"中,我们可以期待找到一些...

Global site tag (gtag.js) - Google Analytics