欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

java Thread 多线程

程序员文章站 2023-12-03 09:06:40
thread 创建线程的两种方法: 1、定义类继承thread类,覆写类中的run方法,调用类对象的start方法,start方法启动线程,调用run方法。thre...

thread 创建线程的两种方法:

1、定义类继承thread类,覆写类中的run方法,调用类对象的start方法,start方法启动线程,调用run方法。thread类用于描述线程;该类定义一个功能run,用于存储线程要运行的代码。

2、定义类实现runnable接口,覆盖runnable接口中的方法,通过thread类建立线程对象,将runnable接口的子类对象作为实际参数传递给thread类的构造函数,调用thread类的start方法开启线程,线程会调用runnable接口子类中的run方法;

实现接口runnable的方式避免了单继承带来的局限性;

thread t;

t.setmaemon(true);//设置线程为后台线程;当所有前台线程结束后后台线程自动结束;

t.notify();//唤醒本线程;

t.notifyall();//唤醒全部线程;

t.interrupt();//中断线程;

thread.sleep(100);//暂停线程100毫秒

synchronized:默认锁定的是本身,也可以锁定自定义的对象;

必须要有两个及以上的线程执行,多个线程使用同一个锁,必须保证同步过程中只能有一个线程在运行;

判断同步: 明确哪些代码是需要多线程运行的代码,明确共享数据,明确多线程运行代码中哪些语句是操作共享数据;

class tickets implements runnable
{
 private int tick = 100;
 public void run() { // public synchronized void run()
  while (tick > 0) {
   synchronized (this) {
    if (tick > 0) {
     try {
      thread.sleep(100);
     } catch (interruptedexception e) {
      e.printstacktrace();
     }
     system.out.println(this.tostring() + "sale:" + tick--);
    }
   }
  }
 }

如上:tick就是共享数据,操作tick就需要在synchronized中进行操作,synchroized锁定的就是tickets本身;

等待唤醒机制: 在操作同步线程时,都必须要标识它们所操作线程所持有的锁,只有同一个锁上的被等待线程,才可以被同一个锁上的notify唤醒,不可以对不同锁中的线程进行了唤醒;(也即:等待和唤醒必须是同一个锁)