20165308第八周学习总结

20165308第八周学习总结

课本知识点总结

  • 进程:代码加载、执行、执行完毕(共享操作系统资源)
  • 线程:一个进程由多个线程组成。(共享进程中某些内存单元,例如代码与数据)
  • 关系:线程是运行在进程中的小线程。
  • 多线程:几个执行体共同执行程序的过程。
    • 多线程使用轮流执行机制
    • 1个cpu只能同时执行一个线程。
  • 主线程:JVM加载代码时,发现main方法之后启动的线程
  • 线程的状态:
    • 新建:Thread类或其子类的对象被声明并创建
    • 运行:调用start()方法通知JVM;如果线程是Thread的子类创建的,程序必须在子类中重写run()方法
    • 中断:
    • JVM讲CPU切换给其他线程
    • 执行sleep(int millsecond)方法,等待millsecond指定时间后,重新排队等待
    • 执行wait()必须由线程调用notifyll方法,才能重新排队
    • 进入阻塞状态
    • 死亡:释放分配给线程的内存
    • 正常死亡,运行完run()
    • 被提前强制终止
  • 线程的创建
    • 使用Thread类子类创建:需要重写run()方法。
    • 使用Thread类
    • 构造方法:Thread(Runable target)
    • 需要创建一个Runnable接口类的事例,并在该接口中重写run方法。
  • 目标对象与线程的关系:完全解耦和目标对象组合线程
  • 线程的常用方法:
    • start() : 线程调用该方法将启动线程,使之从新建状态进入就绪队列排队,一旦轮到它来享用CPU资源时,就可以脱离创建它的线程独立开始自己的生命周期了。
    • run(): Thread类的run()方法与Runnable接口中的run()方法的功能和作用相同,都用来定义线程对象被调度之后所执行的操作,都是系统自动调用而用户程序不得引用的方法。
    • sleep(int millsecond): 优先级高的线程可以在它的run()方法中调用sleep方法来使自己放弃CPU资源,休眠一段时间。
    • isAlive(): 线程处于“新建”状态时,线程调用isAlive()方法返回false。在线程的run()方法结束之前,即没有进入死亡状态之前,线程调用isAlive()方法返回true.
    • currentThread():该方法是Thread类中的类方法,可以用类名调用,该方法返回当前正在使用CPU资源的线程。
    • interrupt() :一个占有CPU资源的线程可以让休眠的线程调用interrupt()方法“吵醒”自己,即导致休眠的线程发生InterruptedException异常,从而结束休眠,重新排队等待CPU资源。
  • 线程同步 : 若干个线程都需要使用一个synchronized(同步)修饰的方法
  • 线程同步机制
  • 当一个线程使用synchronized方法时,其他线程若想使用就必须使用wait()方法等待,直到该线程使用完该方法
  • 其他线程在使用同步方法时若不需要等待,则用完方法的同时,执行notifyAll()方法通知所有处于等待状态的线程结束等待
    必须要在同步方法中使用wait()、notify()、notifyAll()方法
  • 线程联合
    join():其他线程调用该方法,可以和正在使用CPU资源的线程联合。
  • GUI线程
  • 计时器线程:使用Time类
  • 守护线程:使用void setDaemon(boolean on)方法

    码云链接

https://gitee.com/BESTI-IS-JAVA-2018/5308/tree/master/src/ch12

脚本截图

猜你喜欢

转载自www.cnblogs.com/1252854089qq/p/8909716.html