java多线程学习之线程同步

基本上感觉自己学习的东西都是学会了立马就用,很少有机会能专门花时间去学习一些东西,近些时候不忙,准备把公司的面试题全做一遍,难的倒是不多,但是很多人都不会做,问题就是出在实践上。

言归正传。多线程就目前而言,纯是兴趣上的学习,并没有真实的应用场景。以前觉java多线程很乱,很多概念没似懂非懂,但是实战中写几个实例就一目了然了。

昨天练习线程安全时提到了synchronized关键字,其作用原理其实就是把一个或者一部份资源锁住,只允许当前这个进程使用。我理解线程同步就让各个线程之间能够控制资源的分配,比方说锁定资源,释放资源以及等待资源的释放。

下面这个例子之前在网上看到的,自己动手实现了一遍。主要思路就是有一个盘子,有两个人去对盘子操作,其中一个负责放鸡蛋,另一个只负责取走鸡蛋。当盘子里有鸡时,不能再放,当盘子是空的时候无法再取走产鸡蛋。

 代码如下 复制代码

package threads;

public class TestSynchronous
{
  public static int size = 50;

  public static void main(String[] args)
  {
    Plate plate = new Plate();
    new Thread1(plate).start();
    new Thread2(plate).start();
  }

  public static class Thread1 extends Thread //负责放鸡蛋的人
  {
    Plate plate;

    public Thread1(Plate plate)
    {
      this.plate = plate;
    }

    public void run()
    {
      for (int i = 0; i < size; i++) {
        synchronized (plate) {
          if (plate.hasEgg()) {
            try {
              plate.wait();
            } catch (InterruptedException e) {
              e.printStackTrace();
            }
          }
          plate.putEgg("egg");
          System.out.println("put egg.");
          plate.notify();
        }
      }
    }
  }

  public static class Thread2 extends Thread //负责取走产鸡蛋的进度
  {
    Plate plate;

    public Thread2(Plate plate)
    {
      this.plate = plate;
    }

    public void run()
    {
      for (int i = 0; i < size; i++) {
        synchronized (plate) {
          if (!plate.hasEgg()) {
            try {
              plate.wait();
            } catch (InterruptedException e) {
              e.printStackTrace();
            }
          }
          plate.eggAway();
          System.out.println("take away egg.");
          plate.notify();
        }
      }
    }
  }

  public static class Plate //盘子
  {
    Object egg;

    public Plate()
    {
    }

    public void putEgg(Object egg)
    {
      this.egg = egg;
    }

    public void eggAway()
    {
      this.egg = null;
    }

    public boolean hasEgg()
    {
      return egg != null;
    }
  }
}

时间: 2024-08-03 11:02:33

java多线程学习之线程同步的相关文章

多线程问题-新手求助关于Java多线程中启动线程问题

问题描述 新手求助关于Java多线程中启动线程问题 public class Example15_1 { /** * @param args */public static void main(String[] args) { // TODO Auto-generated method stub SpeakHello speakHello; SpeakNinhao speakNinhao; speakHello = new SpeakHello(); speakNinhao= new Speak

java多线程学习笔记之线程安全

假设i为银行的存款数据,i = 100, 现在使用A B两个线程(两个人)同时执行 i = i + 10;(存10块钱)的操作,由于默认情况下异步执行,那么流程可能会是这样: 1. A线程从系统内存中读到 i. 2. B线程从系统内存中读到 i. 3. A线程执行 i+10. 4. B线程执行 i+10. 5. A线程将110写回到系统内存,内存中i的值为 110. 6. B线程将110写回到系统内存,内存中i的值为 110,. 显然这程结果是不正确的,少了一个人存的钱. synchronize

Java多线程学习(吐血超详细总结)

  本文主要讲了java中多线程的使用方法.线程同步.线程数据传递.线程状态及相应的一些线程函数用法.概述等.在这之前,首先让我们来了解下在操作系统中进程和线程的区别: 进程:每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销,一个进程包含1--n个线程.(进程是资源分配的最小单位) 线程:同一类线程共享代码和数据空间,每个线程有独立的运行栈和程序计数器(PC),线程切换开销小.(线程是cpu调度的最小单位) 线程和进程一样分为五个阶段:创建.就绪.运行.阻塞.终止. 多

Java 多线程学习详细总结_java

目录(?)[-] 一扩展javalangThread类 二实现javalangRunnable接口 三Thread和Runnable的区别 四线程状态转换 五线程调度 六常用函数说明 使用方式 为什么要用join方法 七常见线程名词解释 八线程同步 九线程数据传递      本文主要讲了java中多线程的使用方法.线程同步.线程数据传递.线程状态及相应的一些线程函数用法.概述等. 首先讲一下进程和线程的区别: 进程:每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销,一个

多线程:C#线程同步lock,Monitor,Mutex,同步事件和等待句柄(下)

转自 http://www.cnblogs.com/freshman0216/archive/2008/08/07/1256919.html    前两篇简单介绍了线程同步lock,Monitor,同步事件EventWaitHandler,互斥体Mutex的基本用法,在此基础上,我们对它们用法进行比较,并给出什么时候需要锁什么时候不需要的几点建议.最后,介绍几个FCL中线程安全的类,集合类的锁定方式等,做为对线程同步系列的完善和补充.       1.几种同步方法的区别       lock和M

Java多线程编程之CountDownLatch同步工具使用实例_java

好像倒计时计数器,调用CountDownLatch对象的countDown方法就将计数器减1,当到达0时,所有等待者就开始执行. java.util.concurrent.CountDownLatch 一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待.用给定的计数初始化CountDownLatch.由于调用了countDown()方法,所以在当前计数到达零之前,await方法会一直受阻塞.之后,会释放所有等待的线程,await的所有后续调用都将立即返回.这种现

c#.net多线程编程教学——线程同步_C#教程

随着对多线程学习的深入,你可能觉得需要了解一些有关线程共享资源的问题. .NET framework提供了很多的类和数据类型来控制对共享资源的访问. 考虑一种我们经常遇到的情况:有一些全局变量和共享的类变量,我们需要从不同的线程来更新它们,可以通过使用System.Threading.Interlocked类完成这样的任务,它提供了原子的,非模块化的整数更新操作. 还有你可以使用System.Threading.Monitor类锁定对象的方法的一段代码,使其暂时不能被别的线程访问. System

java多线程学习初步

import java.io.*; //多线程编程 public class MultiThread { public static void main(String args[]) { System.out.println("我是主线程!"); //下面创建线程实例thread1 ThreadUseExtends thread1=new ThreadUseExtends(); //创建thread2时以实现了Runnable接口的THhreadUseRunnable类实例为参数 Th

银行取款[多线程]{未进行线程同步}(junit不适合多线程并发单元测试)

        由于计算机多任务.多进程.多线程的支持,使得计算机资源的服务效率提高,服务器对请求的也使用线程来相应,所有,代码中涉及到同时对共享数据的操作,将在 多线程环境中操作数据,导致数据安全问题.      经典例子:老婆(朱丽叶)老公(罗密欧),使用银行卡和存折,或者网银等,同时对同一账户操作的安全问题.      如果要保证多线程下数据安全,就要实现线程同步(例如:一间小厕所,就得有一个锁,保证同一时间为一个人服务).其他文章讲: 此处用多线程实现,同时取款的模拟实现,未进行线程同步