多线程runnable 和 synchronized

本文探讨了并发编程的基本概念,重点介绍了如何利用线程池优化多线程程序的性能,通过实例展示了如何实现线程同步和资源共享。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

只要是new一个共享资源就行

runnable (new一个ticket,因为多个线程可以使用一个目标对象)

package ticketThread;

class ticketP
{
	int ticket=100;
	void sale()
	{
		this.ticket--;
	}
}

class ticket extends Thread
{
	private  ticketP tk;
	public ticket(ticketP tk)
	{
		this.tk=tk;
	}
	
	public void run()
	{
		synchronized(this.tk)
		{
			while(tk.ticket>0)
			{
				System.out.println("sale : " + Thread.currentThread().getName() + " " + tk.ticket); 
				tk.sale();
			}
			
		}
	}
	
	public static void main(String[] args)
	{

		ticketP tk1=new ticketP();
		ticket t1=new ticket(tk1);
		ticket t2=new ticket(tk1);
		ticket t3=new ticket(tk1);
		ticket t4=new ticket(tk1);
		t1.start();
		t2.start();
		t3.start();
		t4.start();
		
		
	}
}





synchronized (new一个ticketP,用synchronized对它互斥访问)

class ticket implements Runnable
{
}
	private int tk=100;
	public void run()
	{

		while(tk>0)
		{
			System.out.println("sale : " + Thread.currentThread().getName() + " " +tk--); 
		}
			
	}

	
	public static void main(String[] args)
	{

		ticket tk1=new ticket();

		Thread t1=new Thread(tk1);
		Thread t2=new Thread(tk1);
		Thread t3=new Thread(tk1);
		Thread t4=new Thread(tk1);
		t1.start();
		t2.start();
		t3.start();
		t4.start();
		
		
	}
}






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值