多线程可以提高一个项目的运行效率, 多线程之间的协作也不可避免,先举一个简单的例子:先介绍第一个类
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并发库还包含了很多其他有用的工具,如Semaphore(信号量)用于控制同时访问特定资源的线程数量,CyclicBarrier(循环屏障)和CountDownLatch(计数器门锁)用于多线程间的协作,以及Lock接口及其实现如...
一种典型的多线程并发服务器架构如下: - **主监听线程**:负责接收客户端连接请求。 - **工作线程池**:由多个工作线程组成,负责处理具体的客户端请求。 **3. 示例代码片段** 下面是一个简单的多线程服务器示例...
本项目聚焦于使用Java的Socket进行多线程并发控制,并结合Hibernate ORM框架与MySQL数据库进行数据存储。下面将详细阐述这些技术及其应用。 首先,Java Socket是Java提供的用于实现网络上不同计算机间进程通信的...
在JDK5中,Java引入了一套强大的多线程并发库,极大地提升了多线程编程的效率和安全性。这个库提供了丰富的类和接口,使得开发者能够更好地控制线程的执行、同步和通信。 1. **线程** - **线程与进程的关系**:...
在IT领域,多线程并发是提升程序性能和效率的重要技术。在现代计算机系统中,尤其是在服务器端的应用,如Web项目,多线程并发能够充分利用多核处理器的资源,实现任务并行处理,提高响应速度和服务质量。"多线程并发...
Java多线程与并发编程是Java语言中用于处理多任务执行的关键技术,它能够帮助开发者设计出能够有效应对高并发请求的应用程序。在现代的线上(Online)和离线(Offline)应用中,合理利用多线程技术可以大幅提高系统...
并发执行涉及线程间的协作与同步。在C#中,`Mutex`, `Semaphore`, `Monitor`以及`lock`语句等工具可以帮助我们控制对共享资源的访问,防止数据竞争和死锁的发生。例如,`lock`关键字提供了一个简单的互斥锁定机制,...
4. **线程间通信**:`WaitHandle`类(如`AutoResetEvent`, `ManualResetEvent`, `Mutex`, `Semaphore`)用于线程间的通信和同步,`Barrier`则用于多线程分阶段协作。 5. **线程优先级**:`Thread.Priority`属性可以...
在JDK5中,多线程并发库引入了一系列新的特性,极大地增强了Java处理并发问题的能力。以下是关于这个主题的详细解释: 1. **线程**: - **线程与进程的关系**:进程是一个正在执行的程序实体,而线程是进程内部的...
在Java编程领域,多线程和高并发是两个至关重要的概念,它们对于构建高效、可扩展的系统至关重要。本文将围绕“Java多线程高并发相关资料收集”这一主题,详细探讨这两个领域的核心知识点。 首先,多线程是指在单个...
### 第20章 Part3:多线程互斥与协作 #### 一、互斥(Mutual Exclusion) 互斥是指在线程编程中确保多个线程不会同时访问同一资源的技术。这种技术非常重要,因为如果不加以控制,多个线程对共享资源的并发访问...
### 张孝祥Java多线程与并发库高级应用笔记概览 #### 一、Java多线程技术的重要性与挑战 Java线程技术是软件工程领域不可或缺的一部分,尤其在底层编程、Android应用开发以及游戏开发中,其重要性不言而喻。然而,...
多线程并发编程-同步与互斥-原子变量-并发和无锁数据结构 多线程并发编程是提高认程序性能的核心技术,但它也增加了编程的复杂性。因此,系统理解和掌握多线程并发编程的技巧变得尤为重要。本章将从多线程编程的...
在IT领域,多线程并发是程序设计中的一个重要概念,特别是在服务器端开发、高并发应用以及实时系统中。"02-4(马士兵)-多线程并发"可能是一个教学资源,由马士兵老师讲解,涵盖了多线程并发的相关知识。在Java中,...
### 深入Java多线程与并发编程 在当今高度发展的信息技术领域中,随着硬件技术的进步和软件架构设计的复杂化,多线程与并发编程成为提高程序执行效率、增强系统性能的关键技术之一。本篇文章将围绕Java多线程与并发...
《基于线程信息的多线程并发执行跟踪方法及系统》是针对电信设备中的多线程并发执行问题提出的一种高效跟踪技术。在现代电信设备中,多线程并发执行是提高系统性能和处理能力的关键,但同时也带来了复杂性和调试难度...
多线程意味着在一个进程中可以有多个线程并发执行,从而实现任务的并行化。 Java中的多线程是通过JVM来实现的。每个Java应用启动时都会创建一个JVM进程,而程序代码的执行是以线程的形式进行。最常见的例子是主线程...
操作系统实验中的多线程并发程序设计是解决经典并发问题——生产者消费者问题的一种方式。生产者消费者问题是进程间通信和同步的经典案例,涉及到共享资源的访问控制和线程的协作。在这个实验中,我们将创建两个线程...
通过以上方法,我们可以在Java中有效地利用多线程处理数据库数据,提高程序的并发能力和效率。记得在设计时充分考虑线程间的协作与同步,以及数据库连接的管理和优化,以确保程序的稳定性和性能。
Java IO、NIO和Netty是Java平台中用于处理输入/输出操作的重要组件,而多线程并发则是提升程序性能和响应能力的关键技术。在这个压缩包"基于JAVA IO, NIO, Netty, 多线程并发实战源码.zip"中,我们可以期待找到一些...