20175330 2018-2019-2 《Java程序设计》第十周学习总结

教材学习内容总结

教材学习内容总结

12.1进程与线程

  • 进程:程序的一次动态执行过程中,从代码加载、执行至执行完毕的一个完整过程。
  • 线程:一个进程在执行中,可以产生多个执行线索,每条线索也有产生、存在和消亡的过程。
    • 进程与线程。线程比进程还小,一个进程的进行期间可以产生多个线程。
    • Java的多线程机制。Java内置对多线程的支持。我们的计算机在任何给定说的时刻只能执行线程中的一个,Java虚拟机只是从一个线程迅速地切换到另一个线程。
      当main方法中有其他线程时,JVM一直要等到Java应用程序中的所有线程都结束后才会结束Java应用程序。
      Java语言使用Thread类及其子类的对象来表示线程,新建的线程一般要经历4个状态:

12.3 Thread类与线程的创建

  • 使用Thread的子类, 需要重写父类的run()方法。
  • 用Thread类直接创建线程对象。Thread(Runnable target)(该构造方法中的参数是一个Runnable类型的接口。)
  • 目标对象与线程的关系
    • 目标对象和线程完全解耦。目标对象没有组合线程对象.目标对象经常需要通过获得线程的名字(因为无法获得线程对象的引用)以便确定是哪个线程正在占用CPU资源,即被JVM正在执行的线程。
    • 目标对象组合线程(弱耦合)。目标对象可以组合线程.目标对象类组合线程对象时, 目标对象可以通过获得线程对象的引用。


① 创建Thread对象;
② 在第一步创建对象后,该对象仅仅拥有内存次元,需要再调用start()方法才能使得其成为新线程。如果这个线程是Thread的对象,类中的run()方法就立刻执行,且程序必须在子类中重写run()方法。注意,线程没有结束run()方法之前,不要让线程再调用start()方法,否则抛出IllegalThreadStateException异常。
③ 线程中断:切换给其他线程;执行了sleep(int time)方法,经过time毫秒后,该线程就重新排队,以便从中断处继续运行;执行了wait()方法,线程进入等待状态,此时,其他线程调用notify()方法来使得在等待状态的线程重新排队以便从中断处继续运行;执行某个操作进入阻塞状态时不能进入排队队列。
④ 线程有两种原因会“死亡”,一是正常运行完了该线程的全部工作;二是run()方法被强制结束。当一个线程“死亡”之后,未死亡的线程会继续轮流占用CPU。
线程是可以设置优先级的(使用setPriority()方法),当优先级高的线程执行完毕时,才会执行低优先级的线程。可以使用getPriority()方法来获得线程的优先级,优先级只能在1~10之间。

12.4线程的常用方法

①start()方法:线程调用该方法将启动线程,使之从新建状态进入就绪队列排队,只有新创建的线程才可以调用该方法。
②run()方法:该方法是否运行结束是判断线程是否结束的一个重要标准。只有当该方法运行结束后,线程才能再次调用start()方法。
③sleep(int millsecond)方法:线程可以调用该方法来使程序进入睡眠,知道过了参数指定的秒数过后才“醒来”。该方法必须在try-catch语句中调用,因为线程如果在休眠中被打断,会抛出InterruptedException异常。
④isAlive()方法:该方法用来判断线程是否正在运行,若是,返回true,若不是,返回false。
⑤currentThread()方法是Thread类中的类方法,可以用类名调用,返回当前使用CPU的线程。
⑥interrupt()方法用来“唤醒”调用sleep方法而处于睡眠状态的线程。一个占有CPU资源的线程可以让休眠的线程调用interrupt()方法“吵醒”自己,即导致休眠的线程发生InterruptedException异常,从而结束休眠,重新排队等待CPU资源。

12.5 线程同步

  • 当两个或多个线程同时访问同一个变量,并且一个线程需要修改这个变量。
  • 在处理线程同步时,要修改数据的方法用关键字synchronized来修饰。
  • 如果有若干个线程需要同时使用一个方法,为了不出现混乱,可以使用synchronized进行修饰。这样一来,该方法只能轮流被调用,直到正在调用该方法的线程使用完该方法后,其他线程才可以调用该方法。

12.6 协调同步的线程

  • wait()方法可以中断方法的执行,使本线程等待,暂时让出CPU的使用权,并允许其它线程使用这个同步方法。
  • notifyAll()方法通知所有的由于使用这个同步方法而处于等待的线程结束等待。曾中断的线程就会从刚才的中断处继续执行这个同步方法,并遵循“先中断先继续”的原则。
  • notify()方法只是通知处于等待中的线程的某一个结束等待。
  • 协调同步的线程:当一个线程使用的同步方法中用到了某个变量,而此变量又需要其他线程修改后才能符合本线程的要求,则可以使用wait()方法来中断线程的执行,并允许其他线程使用这个同步方法(sleep方法是做不到这个功能的)。若有线程在运行同步方法时不需要等待,那么需要在用完方法的同时应用notifyAll()方法来通知其他所有处于等待的线程结束等待。只有在同步线程中才可以使用wait(),notify(),notifyAll()方法。

12.7 线程联合

线程联合:线程A在其运行期间,如果其他线程B调用了join()方法和线程A联合,那么A线程会立马中断,直到B线程运行结束A线程才会重新排队。若B线程已经结束,调用join()方法则不会有任何效果。

  • GUI线程:Java包含GUI(图形用户界面)时,会启动多个线程。
  • 计时器线程:Java中的javax.swing包中的Timer类可以用来创建计时器:Timer(int a,Object b);,a为毫秒,b为监视器(监视器必须是组件类),每隔a毫秒会执行b一次。注意java.util包中也有一个名字是Timer的类,使用类名时需要注意避免混淆。
  • 守护线程:线程默认是非守护线程,线程在运行之前必须设置自己是否为守护线程。可以调用voidsetDaemon(boolean on)来将自己设置成一个守护线程。当所有非守护线程运行结束时,守护线程一定会跟着结束

碰到的问题和解决过程

参考百度经验:https://jingyan.baidu.com/article/ad310e80fbf7fc1848f49e4d.html

扫描二维码关注公众号,回复: 6126200 查看本文章

代码托管

https://gitee.com/shadowsombra/java-basti-is-tip

上周考试错题总结

JDBC驱动类型一、JDBC-ODBC桥

JDBC-ODBC 桥 是sun公司提供的,是jdk提供的的标准API. 这种类型的驱动实际是把所有 JDBC的调用传递给ODBC ,再由ODBC调用本地数据库驱动代码.( 本地数据库驱动代码是指 由数据库厂商提供的数据库操作二进制代码库,例如在oracle for windows中就是oci dll 文 件)

只要本地机装有相关的ODBC驱动那么采用JDBC-ODBC桥几乎可以访问所有的数据库,JDBC- ODBC方法对于客户端已经具备ODBC driver的应用还是可行的.

但是,由于JDBC-ODBC先调用 ODBC再由ODBC去调用本地数据库接口访问数据库.所以,执行效率比较低,对于那些大数据量 存取的应用是不适合的.而且,这种方法要求客户端必须安装ODBC 驱动,所以对于基于 internet ,intranet的应用也是不合适的.因为,你不可能要求所有客户都能找到ODBC driver.

JDBC驱动类型二、本地API驱动

本地API驱动直接把JDBC调用转变为数据库的标准调用再去访问数据库.

这种方法需要本地 数据库驱动代码. 本地API驱动 | 厂商DB代码---------------数据库Server (图二) 这种驱动比起JDBC-ODBC桥执行效率大大提高了.但是,它仍然需要在客户端加载数据库厂商 提供的代码库.这样就不适合基于internet的应用.并且,他的执行效率比起3,4型的JDBC驱动 还是不够高.

JDBC驱动类型三、网络协议驱动

这种驱动实际上是根据我们熟悉的三层结构建立的. JDBC先把对数局库的访问请求传递给网 络上的中间件服务器. 中间件服务器再把请求翻译为符合数据库规范的调用,再把这种调用 传给数据库服务器.如果中间件服务器也是用java开法的,那么在在中间层也可以使用1,2型 JDBC驱动程序作为访问数据库的方法. 网络协议驱动---------中间件服务器------------数据库Server

由于这种驱动是基于server的.所以,它不需要在客户端加载数据库厂商提供的代码库.而且 他在执行效率和可升级性方面是比较好的.因为大部分功能实现都在server端,所以这种驱动 可以设计的很小,可以非常快速的加载到内存中. 但是,这种驱动在中间件层仍然需要有配置 其它数据库驱动程序,并且由于多了一个中间层传递数据,它的执行效率还不是最好.

JDBC驱动类型四、本地协议驱动

这种驱动直接把JDBC调用转换为符合相关数据库系统规范的请求.由于4型驱动写的应用可 以直接和数据库服务器通讯.这种类型的驱动完全由java实现,因此实现了平台独立性. 本地协议驱动---------数据库Server

参考博客:https://blog.csdn.net/weixin_41715077/article/details/84841726

猜你喜欢

转载自www.cnblogs.com/waaaaa/p/10813891.html