[ 高并发]Java高并发编程系列第二篇--线程同步

  • 一 线程同步基本概述

同步: 什么是线程同步,可以简单认为,当有两个以上的线程,需要访问共同的一个资源的时候,我们需要确保每一个线程都能使用到资源.那么问题来了,怎么实现,这就可以使用到我们的这个概念–同步.
同步,其实关键的一点,也就是监视器,它的作用就是监视每一个线程发生的每次动作行为.下面我们看看同步到底怎么去在代码中实现.

  • 二 同步实现方式

实现方式

其实,在JAVA语言中同步是简单的一件事,为什么呢?应为我们可以使用关键字synchronized 这个关键字去实现(实现同步的一种).用它来修饰某个方法.
我们可以使用一个小的Demo来验证一下:

场景描述:
一个发送者类
一个消息类
一个主方法调用类

清单1_消息类

/**
 * 测试消息类
 */
public class Message {
    // 发送消息 1.加入synchronized表示同步,不加入表示不同步,可以自己切换体验
    // public void sendMeg(String[] meg) {
    public synchronized void sendMeg(String meg[]) {
        System.out.print("接受消息:" + meg[0]+meg[1]+"---");

        try {
            Thread.sleep(1000);

        } catch (InterruptedException e) {
            System.out.println("异常");
        }
        System.out.println(meg[1]+"-----发送成功");
    }
}

清单2_发送者类

/**
 * 发送者类
 */
public class From implements Runnable {

    //全局变量
    String[] meg;
    Message message;
    Thread thread;

    //构造函数
    public From(Message message, String[] meg) {
        this.message = message;
        this.meg = meg;
        thread = new Thread(this);
        thread.start();
    }

    //重写父类函数
    public void run() {
        message.sendMeg(meg);
    }
}

清单3_主类:

/**
 * 同步测试类
 */
public class Synch {
    public static void main(String[] args) {
        Message message = new Message();
        From from = new From(message, new String[]{"我的消息:----","1"});
        From from2 = new From(message, new String[]{"我的消息:----","2"});
        From from3 = new From(message, new String[]{"我的消息:----","3"});

        try {
            from.thread.join();
            from2.thread.join();
            from3.thread.join();
        } catch (InterruptedException i) {
            System.out.println("异常");
        }
    }
}

到此为止,三个类就写完了,那么我们来运行一下.是什么结果.
运行j结果:

接受消息:我的消息:----2-----发送成功
接受消息:我的消息:----3-----发送成功
接受消息:我的消息:----1-----发送成功

这里如果,你再取消清单一中的同步关键字再试一试,结果显示,消息出现错乱,不会同步.

  • 三 同步进阶

线程同步的方式和机制理论
临界区(Critical Section)、互斥量(Mutex)、信号量(Semaphore)、事件(Event)的区别
1、临界区:通过对多线程的串行化来访问公共资源或一段代码,速度快,适合控制数据访问。在任意时刻只允许一个线程对共享资源进行访问,如果有多个线程试图访问公共资源,那么在有一个线程进入后,其他试图访问公共资源的线程将被挂起,并一直等到进入临界区的线程离开,临界区在被释放后,其他线程才可以抢占。
2、互斥量:采用互斥对象机制。 只有拥有互斥对象的线程才有访问公共资源的权限,因为互斥对象只有一个,所以能保证公共资源不会同时被多个线程访问。互斥不仅能实现同一应用程序的公共资源安全共享,还能实现不同应用程序的公共资源安全共享
3、信号量:它允许多个线程在同一时刻访问同一资源,但是需要限制在同一时刻访问此资源的最大线程数目
4、事 件: 通过通知操作的方式来保持线程的同步,还可以方便实现对多个线程的优先级比较的操作

  • 四 线程同步的方式

第一种:使用synchronized关键字修饰的方法。
第二种:同步代码块 ,即有synchronized关键字修饰的语句块。
第三种:使用特殊域变量(volatile)实现线程同步
第四种:使用重入锁实现线程同步, ReentrantLock类是可重入、互斥、实现了Lock接口的锁
第五种:使用局部变量实现线程同步

可以根据不同的功能做不同的实现.

出处:
http://www.cnblogs.com/hyhnet/p/6257698.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值