zoukankan      html  css  js  c++  java
  • 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

    脚本截图

  • 相关阅读:
    【转】HTML CANVAS
    【转】JY 博客
    【转发】如何使用NPM?CNPM又是什么?
    【转廖大神】package.json 包安装
    【转】Socket接收字节缓冲区
    C# 串口操作系列(5)--通讯库雏形
    C# 串口操作系列(3) -- 协议篇,二进制协议数据解析
    C# 串口操作系列(4) -- 协议篇,文本协议数据解析
    .netCore微服务使用Nginx集中式管理实现
    nginx代理访问及上传文件异常413 Request Entity Too Large
  • 原文地址:https://www.cnblogs.com/1252854089qq/p/8909716.html
Copyright © 2011-2022 走看看