图解java多线程设计模式-序章1 Java线程

以下内容是我在阅读《图解Java多线程设计模式》一书中的总结和思考

何谓线程

文中给出的解释是:正在执行程序的主体

线程的启动

新线程的启动一定是调用start()方法,该方法主要是执行两步操作

  1. 启动新线程
  2. 调用新线程的run()方法

这里需要注意:

public class Test()
{
	public static void main(String[] args)
	{
		Thread t = new Thread();
		t.start();
	}

}

public class Test()
{
	public static void main(String[] args)
	{
		Thread t = new Thread();
		t.run();
	}

}

的作用是不一样的。调用start会开启新线程,然后在新线程中调用run()方法;如果像第二段代码中那样直接调用run(),那只会在本线程中启动run,不会有新线程产生。

概念

顺序:用于表示多个操作依次执行。

并行:用于表示多个操作“同时进行”,并行的情况出现在多核cpu上,是说每个处理单元都在同时工作。

并发:这是某个处理单元在一个时间段上的概念。同一时间段内处理多个线程。并行可以在同一个脉冲中处理多个线程,但并发不行,并发强调的是通过线程切换,在一秒内可以同时处理多个线程。

创建线程

  1. 继承Thread类
  2. 实现Runnable接口

线程的暂停

  1. Thread类的静态方法sleep()
  2. Object类的wait()

对于Thread类的静态方法sleep(),需要注意的是:

public class Test()
{
	public static void main(String[] args)
	{
		Thread t = new Thread();
		t.start();
		try
		{
			t.sleep(1000);
		}
		catch (InterruptedExpection e)
		{
			...
		}
	}

}

如果出现以上代码,那进入休眠的是主线程还是新线程?其实要知道sleep()是静态方法,所以t.sleep()和Thread.sleep()的作用是一样的,因此,进入休眠的是主线程。如果想要新线程进入休眠,就需要在新线程的run()方法上调用sleep()了。

一般静态方法都需要通过实例对象来调用,而会直接通过类来调用,这样会清晰,减少误会。

静态方法与实例方法的synchronized

synchronized静态方法是使用该类的类对象锁来执行线程的互斥处理的。

synchronized实例方法是使用this(实例对象)来执行线程的互斥处理的。

例如现在有个类Something,有两个实例对象a, b,那a调用实例同步方法的时候b也可以调用b的同步方法。但是如果a调用同步静态方法,那b就不能调用静态同步方法了。原因在于Something的类对象只有一个!

读后疑问:

  1. 克隆出来的实例对象是否为同一个对象?可以当做同一把锁?(我觉得只要内存地址不一样,就不是同一个锁)
  2. notify只能唤醒一个线程,那到底唤醒哪个呢?(我觉得会唤醒等待队列中最先进入的那个,可能是先进先出原则。)
  3. 如何理解“所有实例都拥有一个等待队列”这句话?这个实例是指当前线程还是指锁对象?

猜你喜欢

转载自blog.csdn.net/Luke_R/article/details/83244612