线程同步与死锁

原创 2016年07月26日 09:48:59

线程同步与死锁
课程大纲
一、 多线程共享数据
1、在多线程的操作中,多个线程有可能同时处理同一个资源,这就是多线程中的共享数据。
二、 线程同步
1、 解决数据共享问题,必须使用同步,所谓同步就是指多个线程在同一个时刻只能有一个线程执行指定代码,其他线程要等到该线程执行结束之后才能继续执行。
2、 线程同步有两种方法
(1)、同步代码块synchronized(要同步的对象)
{
要同步的操作
}
(2)、同步方法
Public synchronize void method()
{
要同步的操作
}
三、 同步准则
1、 当编写synchronize块时,有几个简单的准则可以遵循,这些准则在避免死锁和性能危险的风险方面大有帮助:
2、 (1)、使代码块简短,把不随线程变化的预处理和后处理移出synchronize块。
3、 (2)、不要阻塞,如:InputStream.Read()
4、 (3)、在持有锁的时候,不要对其他对象调用方法。
四、 线程死锁
1、过多的同步有可能出现死锁,死锁的操作一般是在程序运行的时候才有可能出现。

代码如下:

package us.google;

/**
* 多线程共享数据的安全问题。使用同步解决
* 1、同步代码块
* 2、同步方法
* 同步代码会代来性能降低的问题,提高数据的安全性。
* @author chongrubujing
*
*/
public class ThreadDemo {

public static void main(String[] args) {
    Mythread my = new Mythread();
    Thread t1 = new Thread(my,"小白");
    Thread t2 = new Thread(my,"小黑");
    t1.start();//启动的时候就会调用run方法
    t2.start();

}

}
class Mythread implements Runnable
{

@Override
public void run() {
    /*//方法一:同步代码块
    synchronized (this) {//括号总可以写任意对象
        System.out.println(Thread.currentThread().getName()+"正在吃饭");
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println(Thread.currentThread().getName()+"吃饭了");*/
    //调用method方法
    method();
    }

//方法二:同步方法,同步的是当前对象(this)
    public synchronized void method()
    {
        System.out.println(Thread.currentThread().getName()+"正在吃饭");
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println(Thread.currentThread().getName()+"吃饭了");
    }

}

死锁:是有几率的

package us.google;
/**
* 线程死锁
* @author chongrubujing
*
*/
public class DeadThreadDemo {

public static void main(String[] args) {
    new DeadThread();//new的时候先调用构造方法,构造方法中start时候再调用run()方法,run()方法
                     //最后调用
}

}
//顾客
class Customer
{
public synchronized void say(Waiter w)
{
System.out.println(“顾客说先做再给钱!”);
w.doService();
}
public synchronized void doService()
{
System.out.println(“同意了,先给钱再做”);
}
}
//服务员
class Waiter
{
public synchronized void say(Customer c)
{
System.out.println(“服务员说:先给钱再做!”);
c.doService();
}
public synchronized void doService()
{
System.out.println(“同意了,先做再给钱!”);
}
}
//死锁线程
class DeadThread implements Runnable
{

Customer c = new Customer();
Waiter w = new Waiter();
//无参构造方法
 public DeadThread() {
     new Thread(this).start();//this代表的是DeadThread的一个对象
     w.say(c);
}
@Override
public void run() {
    c.say(w); 
}

}

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

JAVA_线程同步与死锁

  • 2012年08月16日 11:45
  • 32KB
  • 下载

Java 线程同步与死锁 学习笔记

Java 线程同步与死锁 学习笔记Java 线程同步与死锁 学习笔记 1 多线程共享数据 2 线程同步 3 同步准则 4 线程死锁 1、 多线程共享数据 在多线程操作中,多个线程可能同时处理同一个资源...

线程同步和线程死锁

1.线程同步,一个关键字:synchronized 为什么有这个东西呢,假如有一个对象,里面有成员变量和方法,如果有很多线程都想访问它们,有可能造成用户想避免的结果。 我也举那个经典的例子...

线程同步、死锁、线程池

文章来自:http://www.cnblogs.com/xiaoxuetu/

Java多线程之线程同步和死锁

Java多线程之线程同步和死锁 

Java线程同步与死锁、生产者消费者模式以及任务调度等

Thread类基本信息方法 线程同步 由于同一进程的多个线程共享同一片存储空间,在带来方便的同时,也带来了访问冲突这个严重的问题。Java语言提供了专门机制以解决这种冲突,有效避免了同一个...

Java多线程 线程同步与死锁

1.线程同步多线程引发的安全问题一个非常经典的案例,银行取钱的问题。假如你有一张银行卡,里面有5000块钱,然后你去银行取款2000块钱。正在你取钱的时候,取款机正要从你的5000余额中减去2000的...

C语言多线程编程-死锁和线程同步方式介绍(一)

线程同步,互斥锁,条件变量,读写锁

Java第七课 Java的多线程程序进程和线程的概念,实现多线程的两种方式,线程同步的原理,线程的死锁,运用wait和notify来实现producer - consumer关系,线程终止的两种情况。

程序、进程和线程 1.程序是计算机指令的集合,它以文件的形式存储在磁盘上。 2.进程:是一个程序在其自身的地址空间中的一次执行活动。 3.进程是资源申请、调度和独立运行的单位,因此,它使...

线程同步/线程死锁

1.线程同步,一个关键字:synchronized 为什么有这个东西呢,假如有一个对象,里面有成员变量和方法,如果有很多线程都想访问它们,有可能造成用户想避免的结果。 我也举那个经典的例子...
  • hilo77
  • hilo77
  • 2014年09月19日 09:54
  • 203
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:线程同步与死锁
举报原因:
原因补充:

(最多只允许输入30个字)