• 多线程synchronized锁


    11、

    Synchronized使用方式
    代码块形式
    1)、使用到Synchronized锁:任务对象锁
    2)、方法(非静态)默认this锁
    3)、方法(静态),当前类Class字节码锁

    i)、this或object

    public class TickerThread implements Runnable {

    private int count=100;

    @Override
    public void run() {
    while (count>0){
    ticket();
    }
    }


    Object object=new Object();
    public void ticket(){

    //synchronized(object){
    synchronized(this){
    if(count>0){
    try {
    Thread.sleep(30);
    }catch (Exception e)
    {

    }
    System.out.println(Thread.currentThread().getName()+",当前系统余票【"+count+"】");
    System.out.println(Thread.currentThread().getName()+",正在出票第【"+(100-count+1)+"】张");
    count--;
    if(count==0)
    {
    System.out.println(Thread.currentThread().getName()+",当前系统的票已售尽,当前系统余票【"+count+"】");
    }
    }
    }

    }

    public static void main(String arg[])
    {
    TickerThread tickerThread=new TickerThread();
    new Thread(tickerThread,"售票机1号").start();
    new Thread(tickerThread,"售票机2号").start();
    new Thread(tickerThread,"售票机3号").start();
    new Thread(tickerThread,"售票机4号").start();
    new Thread(tickerThread,"售票机5号").start();
    }

    }

    ii)、非静
    public class TickerThread implements Runnable {

    private int count=100;

    @Override
    public void run() {
    while (count>0){
    ticket();
    }
    }

    public synchronized void ticket(){
    if(count>0){
    try {
    Thread.sleep(30);
    }catch (Exception e)
    {

    }
    System.out.println(Thread.currentThread().getName()+",当前系统余票【"+count+"】");
    System.out.println(Thread.currentThread().getName()+",正在出票第【"+(100-count+1)+"】张");
    count--;
    if(count==0)
    {
    System.out.println(Thread.currentThread().getName()+",当前系统的票已售尽,当前系统余票【"+count+"】");
    }
    }
    }

    public static void main(String arg[])
    {
    TickerThread tickerThread=new TickerThread();
    new Thread(tickerThread,"售票机1号").start();
    new Thread(tickerThread,"售票机2号").start();
    new Thread(tickerThread,"售票机3号").start();
    new Thread(tickerThread,"售票机4号").start();
    new Thread(tickerThread,"售票机5号").start();
    }

    }


    iii)、静态
    public class TickerThread implements Runnable {

    private static int count=100;

    @Override
    public void run() {
    while (count>0){
    ticket();
    }
    }

    public static void ticket(){
    synchronized(TickerThread.class){
    if(count>0){
    try {
    Thread.sleep(30);
    }catch (Exception e)
    {

    }
    System.out.println(Thread.currentThread().getName()+",当前系统余票【"+count+"】");
    System.out.println(Thread.currentThread().getName()+",正在出票第【"+(100-count+1)+"】张");
    count--;
    if(count==0)
    {
    System.out.println(Thread.currentThread().getName()+",当前系统的票已售尽,当前系统余票【"+count+"】");
    }
    }
    }

    }

    public static void main(String arg[])
    {
    TickerThread tickerThread=new TickerThread();
    new Thread(tickerThread,"售票机1号").start();
    new Thread(tickerThread,"售票机2号").start();
    new Thread(tickerThread,"售票机3号").start();
    new Thread(tickerThread,"售票机4号").start();
    new Thread(tickerThread,"售票机5号").start();
    }

    }

  • 相关阅读:
    数论分块与整除相
    P3254——DP&&入门
    P3384——树链剖分&&模板
    树链剖分模板
    P4145——线段树点修改&&模板题
    P1198最大数——线段树点修改&&模板题
    线段树(四)——两个标记(add和set)
    epoll 知识总结
    C++中的mutable关键字
    [LeetCode] Max Points on a Line
  • 原文地址:https://www.cnblogs.com/smallfa/p/14578424.html
Copyright © 2020-2023  润新知