Java 多线程 Java 线程模型?理解线程概念?进程的概念?线程的概念?线程与进程的区别和联系?一个进程在其执行过程中,可以产生多个线程。?在进程概念中,每一个进程的内部数据和状态都是完全独立的。但与进程不同的是,同类的多个线程是共享一块内存空间和一组系统资源,而线程本身的数据通常只有微处理器的寄存器数据,以及一个供程序执行时使用的堆栈。?线程是比进程更小的执行单位,是进程内部独立的,有序的指令流。由此,一个进程能包含多个并发执行的线程。线程是一种能够独立运行的子任务。?多线程是一种允许在程序中并发执行彼此间互相独立的多个线程机制。?多个线程的执行是并发的。?多个线程之间的代码是乱序执行的,由此线程调度,同步等问题需要进行特殊处理。 1. 线程的生命周期线程的 5种状态及转换方法新生态 Now Bron 运行态 Running 可运行态 Runnable 阻塞态 Blocked 死亡态 Dead suspend() sleep() wait() resume() notify() start() yield() stop() stop() stop() 1. 新生状态?当利用 new 运算符创建线程对象实例后,它仅仅作为一个对象实例存在, JVM 没有为其分配 CPU 时间片等线程运行资源,该线程处于新生状态。 2. 可运行状态?在处于新生状态的线程中调用 start() 方法将线程的状态转换为可运行状态。这时,线程已经得到除 CPU 时间之外的其它系统资源,只等 JVM 的线程调度管理器按照线程的优先级对该线程进行调度,从而使该线程拥有能够获得 CPU 时间片的机会。 3. 运行状态? JVM 的线程调度管理器选中一个可运行状态线程,使其占有 CPU 并转换为运行状态。运行状态的线程执行自己的 run() 方法中的代码,直到调用其他方法而终止、或等待某资源而阻塞或完成任务而死亡。 4. 睡眠状态?处于运行状态的线程在某些情况下,如执行了 sleep() 方法,或等待 I/O 设备等资源,将让出 CPU 并暂时终止自己的运行,进入阻塞状态, 也称为不可运行状态。?处于阻塞状态的线程是不可执行的,即使 CPU 空闲,也不能执行。只有当引起阻塞的原因被消除时,线程转入可运行状态,重新进入线程队列中排队等待运行,再次运行时从原来终止处继续运行。 5. 死亡状态?死亡状态是线程生命周期中的最后一个阶段。导致线程死亡的有 2种情况:一是正常运行的线程完成了它的全部工作,这个任务完成的动作是由 run() 方法实现的;另一个是线程被强制性地终止,如通过执行 stop() 方法来终止一个线程。?可以用 isAlive() 方法测试线程是否已启动。如果 isAlive() 方法返回 false , 表示该线程是新创建或已被终止;如果返回 true ,表示该线程已启动且未被终止,是可运行状态、运行状态或阻塞状态之一,但不能作进一步的分辨。 2. 线程控制(1) start() 方法? start() 方法对应于启动操作(2) stop() 方法? stop() 方法终止在任何状态的线程,使之转入到死亡状态(3) sleep() 方法? sleep() 方法使线程暂停运行一段固定的时间。在休眠时间内,由于线程不能得到 CPU 时间而不运行,指定的时间一过,线程重新进入可运行状态。? public static void sleep(long millis) throws InterruptedException ? public static void sleep(long millis, int nanos) throws InterruptedException (4) yield() 方法? yield() 方法使得线程放弃当前分得的 CPU 时间,但是不使线程阻塞, 即线程仍处于可运行状态,随时可能再次分得 CPU 时间(5) wait() 方法? wait() 方法使得当前线程进入阻塞状态,直到被唤醒或等够了 timeout 指定的时间。注意: wait() 等价于 wait(0) ,它使得线程永远等待直到被唤醒为止。? public final void wait(long timeout) throws InterruptedException ? public final void wait(long timeout, int nanos) throws InterruptedException ? public final void wait() throws InterruptedException (6) notify() 方法和 notifyAll() 方法? notify() 方法和 notifyA
第8章 java高级编程-2 来自淘豆网m.daumloan.com转载请标明出处.