解决多线程中线程安全的方式二
/** * 解决多线程中线程安全的方式二:同步方法,操作共享数据的是一个方法 * 1.同步方法仍然涉及到同步监视器,只是不需要显示的声明 * 2.非静态的同步方法,同步监视器是this * 静态的同步方法,同步监视器是类本身(类.class) * * * */ public class ThreadMethodDemo { public static void main(String[] args) { RunnableImp1 runnableImp1 = new RunnableImp1(); Thread thread1 = new Thread(runnableImp1); Thread thread2 = new Thread(runnableImp1); Thread thread3 = new Thread(runnableImp1); thread1.setName("Runnable窗口1"); thread2.setName("Runnable窗口2"); thread3.setName("Runnable窗口3"); thread1.start(); thread2.start(); thread3.start(); try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } ThreadExtends threadExtends1 = new ThreadExtends(); ThreadExtends threadExtends2 = new ThreadExtends(); ThreadExtends threadExtends3 = new ThreadExtends(); threadExtends1.setName("Thread窗口1"); threadExtends2.setName("Thread窗口2"); threadExtends3.setName("Thread窗口3"); threadExtends1.start(); threadExtends2.start(); threadExtends3.start(); } } /*实现Runnable方式*/ class RunnableImp1 implements Runnable{ private int ticket = 100; @Override public void run() { while(true){ if(ticket > 0){ show(); }else{ break; } } } public synchronized void show(){//此处的synchronized相当于this if(ticket > 0){ System.out.println(Thread.currentThread().getName() + "卖票,票号为:" + ticket); ticket--; } } } class ThreadExtends1 extends Thread{ private static int ticket = 100; @Override public void run() { while(true){ if(ticket > 0){ show(); }else{ break; } } } public static synchronized void show(){//此处的synchronized相当于当前类对象(ThreadExtends1.class) if(ticket > 0){ System.out.println(Thread.currentThread().getName() + "卖票,票号为:" + ticket); ticket--; } } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)