多线程

2020-12-09 23:33

阅读:438

标签:rmi   线程安全   mina   退出   效果   概述   span   操作   计时   

一,多线程
  1,并发与并行
    并行:两个或两个以上的事件,同一时刻发生(同时进行)
    并发:两个或两个以上的事件,同一时间段内发生(交替进行)
  2,进程与线程
    进程:进入到内存中的应用程序、软件,这个过程叫做进程。
    线程:进程中的一个执行单元,负责当前进程中程序的执行,一个进程中至少有一个线程,一个程序是可以有多个线程的,这个程序就可以称作多线程。
  3,主线程
    主线程:执行main方法的线程。
    单线程:程序执行从main方法开始,从上到下执行。
    原理:java程序进入内存,jvm先执行main方法,jvm会找操作系统开辟main方法---》通向CPU的路径,CPU就会通过这个路径main执行代码
  4,创建线程类
    概述:
      java.lang.Thread 类代表线程,所有的线程对象都必须是Thread的类或是其子类。
    创建步骤:
      1,继承Thread类
      2,重写run(); 方法
      3,创建Thread子类的实例,即使创建了线程对象
      4,调用 对象.start();方法
    获取线程名:
      1,Thread类中,有getName(); 返回该线程名称 String name
      2,获取当前正在执行的线程名称 currentThread();返回当前正在执行的线程对象,再通过 对象.getName(); 获取名称
    设置线程名:
      1,通过父类构造器,把名字String name传参到其中,super(name);
      2,通过 对象.set(name);方法
    休眠:
      sleep(long seconds); 执行的是线程休眠
  5,实现类接口方式创建线程
    概述:
      java.lang.Runnable 接口可通过被实现类实现方式,创建线程
    步骤:
      1,创建实现类实现Runnable接口
      2,重写run();方法----》方法中是新线程执行的代码
      3,创建Runnable实现类的对象
      4,创建Thread类对象,构造器中传参(Runnable实现类 对象)
      5,调用Thread类对象.start();方法,开启新的线程,执行run();
    作用:
      1,一个类如果继承Thread类,就不能继承其他类了
      2,一个类实现Runnable接口还可以继续继承其他类,提高可重用性
 
二,线程安全
  概述:
    如果有多个线程同时运行,而这些线程同时运行这段这段代码,如果程序运行的结果和单线程结果一样,而且运行的结果和预期效果也是一样的,我们成线程安全。否则,线程存在安全问题。
    当我们使用多个线程访问同一个源,并且多个线程中对资源有写的操作,就容易出现线程安全问题。
  解决:
    java中提供了同步来解决线程安全问题。 synchronized
  使用:
    1,同步代码块
      synchronized(锁对象){
        出现安全问题代码块
      }
      步骤:
        1》在成员位置创建 锁对象
        2》把锁对象添加到()中
        3》问题代码块添加到{ }中
      注意:
        1,创建的锁对象可以是任意对象,Object obj =new Object();
        2,必须保证多个线程使用的是同一个锁对象
        3,把{ }只让一个线程进
 
    2,同步方法
      步骤:
        1》创建一个方法,修饰符添加 synchronized
        2》把访问了共享数据的代码块放入该方法中
        3》调用方法
    3,Lock锁
      概述:
        Lock接口中,有lock();上锁 unlock();解锁的方法
      步骤:
        1》在成员位置创建Lock的实现类, ReentrantLock
        2》在可能会出现问题的代码前面, 调用 lock();方法加锁
        3》在可能会出现问题的代码后面,调用 unlock();方法解锁,释放锁
 
三,线程状态
  API中,java.lang.Thread.State 帮助手册
  概述:
    当线程被new 创建后,不是立即执行的,线程存在多种状态
    New         线程新建状态,但未被启动
    Runnable       可运行,在JVM里的状态
    Blocked       阻塞
    Waiting       无限等待,一个线程在等待另一个线程唤醒
    Timed_Waiting   计时等待
    Terminated     被终止,因run();结束,正常退出而死亡

多线程

标签:rmi   线程安全   mina   退出   效果   概述   span   操作   计时   

原文地址:https://www.cnblogs.com/kide1412/p/10992966.html


评论


亲,登录后才可以留言!