线程同步与死锁

原创 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多线程 线程同步与死锁

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

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

Java 线程同步与死锁 学习笔记Java 线程同步与死锁 学习笔记 1 多线程共享数据 2 线程同步 3 同步准则 4 线程死锁 1、 多线程共享数据 在多线程操作中,多个线程可能同时处理同一个资源...
  • haha_zhan
  • haha_zhan
  • 2016年09月25日 10:02
  • 916

多线程同步与死锁深入分析

多线程同步与死锁深入分析 前言 在多线程开发中,同步与死锁是非常重要的,在本篇文章中,读者将会明白一下几点: 1、哪里需要同步 2、如何实现同步 3、以及实现同步之后会有哪些副作用 例子 ...
  • yangwenxue_admin
  • yangwenxue_admin
  • 2016年04月10日 17:53
  • 1789

1线程同步:互斥量,死锁

1线程为什么要同步 A:共享资源,多个线程都可对共享资源操作。 B:线程操作共享资源的先后顺序不确定。 C:处理器对存储器的操作一般不是原子操作。 2互斥量 mutex操作原语 pthre...
  • toto1297488504
  • toto1297488504
  • 2014年09月25日 16:44
  • 1743

同步锁、互锁(死锁)

经历了精心动魄的活动之后,对,锁、多线程的理解进一步加深了,记得在单例模式的时候接触过一点,但那都是皮毛,简单的理解。接下来和大家共同分享学习 java中cpu分给每个线程的时间片是随机的并且在jav...
  • lishehe
  • lishehe
  • 2014年01月15日 21:32
  • 3456

java 多线程学习笔记2-同步代码块,死锁

1、多线程-同步代码块:synchronized     当多线程并发, 有多段代码同时执行时, 我们希望某一段代码执行的过程中CPU不要切换到其他线程工作. 这时就需要同步。     如...
  • gaopinqiang
  • gaopinqiang
  • 2016年12月18日 15:08
  • 594

VC++6.0调试篇:定位临界区(critical section)导致的死锁

转自:http://blog.csdn.net/ljh081231/article/details/38294681      在多线程程序的开发中,因为效率的关系,通常会选用CriticalSec...
  • rankun1
  • rankun1
  • 2016年08月22日 09:14
  • 867

彻底搞懂OC中GCD导致死锁的原因和解决方案

GCD提供了功能强大的任务和队列控制功能,相比于NSOperationQueue更加底层,因此如果不注意也会导致死锁。所谓死锁,通常指有两个线程A和B都卡住了,并等待对方完成某些操作。A不能完成是因为...
  • abc649395594
  • abc649395594
  • 2015年08月27日 23:56
  • 7681

Java Thread 多线程同步、锁、通信

线程同步、同步锁、死锁 线程通信 线程组和未处理异常 Callable和Future 12、线程同步 当多个线程访问同一个数据时,非常容易出现线程安全问题。这时候就需要用线程...
  • jerrysbest
  • jerrysbest
  • 2016年02月24日 05:55
  • 615

java多线程同步以及线程间通信详解&消费者生产者模式&死锁&Thread.join()(多线程编程之二)

多线程系列教程: java多线程-概念&创建启动&中断&守护线程&优先级&线程状态(一) java多线程同步以及线程间通信详解&消费者生产者模式&死锁&Thread.join()(二) 本篇我...
  • javazejian
  • javazejian
  • 2016年03月13日 16:58
  • 9799
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:线程同步与死锁
举报原因:
原因补充:

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