二、 多锁多线程

本文介绍了多锁多线程的概念,通过示例展示了不同线程获取不同对象锁时,可以并行执行synchronized方法体内容。线程间互不影响,而在静态方法上使用synchronized则锁定类级别,实现线程同步。

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

一、多锁多线程

  1. 概念:
    多个线程,每个线程都可以拿到自己指定的锁,分别获得锁之后,执行synchronized方法体的内容。

  2. 例子:
    synchronized取得的锁都是对象锁,而不是把一段代码(方法)当做锁,所以哪个线程先执行synchronized关键字的方法,哪个线程就持有该方法所属对象的锁(Lock)。当是两个对象时,线程获得的就是两个不同的锁,它们之间是互不影响的。

package com.Thread.Sychronized;

public class many_Thread {
	
	private  int state=0;
	
	public  synchronized void name(String str) {
		try {
		if(str.equals("A"))
		{
			state=100;
			System.out.println("A");
			Thread.sleep(400);
		}
		else
		{
			state=200;
			System.out.println("B");
			Thread.sleep(200);
		}
		
		System.out.println("str: "+str+"   state:"+state);
		
	      }catch (InterruptedException e) {
			e.printStackTrace();
		}
	}
	

	public static void main(String[] args)  {
		// TODO Auto-generated method stub

		final many_Thread m1=new many_Thread();
		final many_Thread m2=new many_Thread();
		
		Thread t1=new Thread()
				{
			      public void run() {m1.name("A");}
			      
				};
		
		Thread t2=new Thread()
		{
			 public void run() {m2.name("B");}
			};
				;
		t1.start();
		t2.start();
		
	}

}

运行结果:

A
B
str: B   state:200
str: A   state:100

总结:两个线程都是同时进行的


相同锁的情况,即在静态方法上加synchronized关键字,表示锁定.class类,类级别的锁(独占.class类)

package com.Thread.Sychronized;

public class many_Thread {
	
	private static int state=0;
	
	public static synchronized void name(String str) {
		try {
		if(str.equals("A"))
		{
			state=100;
			System.out.println("A");
			Thread.sleep(400);
		}
		else
		{
			state=200;
			System.out.println("B");
			Thread.sleep(200);
		}
		
		System.out.println("str: "+str+"   state:"+state);
		
	      }catch (InterruptedException e) {
			e.printStackTrace();
		}
	}
	

	public static void main(String[] args)  {
		// TODO Auto-generated method stub

		final many_Thread m1=new many_Thread();
		final many_Thread m2=new many_Thread();
		
		Thread t1=new Thread()
				{
			      public void run() {m1.name("A");}
			      
				};
		
		Thread t2=new Thread()
		{
			 public void run() {m2.name("B");}
			};
				;
		t1.start();
		t2.start();
		
	}

}

运行结果:

A
str: A   state:100
B
str: B   state:200

总结:先执行完线程一再执行线程二

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值