Java多线程编程总结

1:我们先认识下什么是多任务、多进程、单线程、多线程。
  要认识多线程就要从操作系统的原理说起。
 
  以前古老的DOS操作系统是单任务,还没有现成的概念,也就是系统只能做一件事情。比如你在COPY东西的时候,不能RENAME文件的名字。为了提高系统的利用效率,通常采用批处理来批量执行任务。

  现在的操作系统都是多任务的操作系统,每个运行的任务就是操作系统所作的一件事情。比如:你在听歌的同时可以聊QQ。听歌跟聊天就是2个任务,这2个任务"同时"进行,一个任务在一般的情况下对应一个进程,也可能包含好几个进程。比如运行的MSN就对应一个MSN的进程,如果你用的是windows系统,你就可以在任务管理器中看到操作系统正在运行的进程信息。

一般来说,当运行一个应用程序的时候,就启动了一个进程,当然也会启动多个进程。启动程序的时候,操作系统会为进程开辟资源,其中最主要的资源是内存空间,因为程序是在内存中运行的。在进程中,有些程序的代码块是可以乱序执行的,并且这个代码块可以被多次执行。实际上这个代码块就是线程体。线程是进程中乱序执行的代码流程,当多个线程同时运行的时候,这样的执行模式成为并发执行。

说白了,多线程的目的就是为了更好的节约CPU,最大限度的利用CPU

java编写的程序都运行在JVM中,在JVM内部,程序的运行都是通过线程来完成的。每用JAVA命令启动一个java应用程序,都会启动一个进程,在同一个JVM进程中,有且只有一个进程,就是它自己。在这个JVM环境中,所有程序代码的运行都是以线程来运行。

一般常见的JAVA应用程序都是单线程的。实际上操作系统的多进程实现了多任务的并发执行,程序的多线程实现了进程的并发执行。 多任务、多进程、多线程的前提都是要求操作系统提供多任务、多进程、多线程的支持。

所谓的“并发执行”、“同时”其实都不是真正意义上的“同时”。众所周知,CPU都有个时钟频率,表示每秒中能执行cpu指令的次数。在每个时钟周期内,CPU实际上只能去执行一条(也有可能多条)指令。操作系统将进程线程进行管理,轮流(没有固定的顺序)分配每个进程很短的一段是时间(不一定是均分),然后在每个线程内部,程序代码自己处理该进程内部线程的时间分配,多个线程之间相互的切换去执行,这个切换时间也是非常短的。因此多任务、多进程、多线程都是操作系统给人的一种宏观感受,从微观角度看,程序的运行是异步执行的。

用一句话做总结:虽然操作系统是多线程的,但CPU每一时刻只能做一件事,和人的大脑是一样的,呵呵。


2:java与多线程
Java语言的多线程需要操作系统的支持。

Java 虚拟机允许应用程序并发地运行多个执行线程。Java语言提供了多线程编程的扩展点,并给出了功能强大的线程控制API。

在Java中,多线程的实现有两种方式:
扩展java.lang.Thread类
实现java.lang.Runnable接口

每一线程都有一个优先级,优先级高的线程优先级低的线程。每个线程都可以或不可以标记为一个守护线程,当某个线程中运行的代码创建一个新 Thread 对象时,该新线程的初始优先级被设定为创建线程的优先级,并且当且仅当创建线程是守护线程时,新线程才是守护程序。

当java虚拟机启动时,通常都会有单个非守护线程(它通常会调用某个指定类的 main 方法),Java 虚拟机会继续执行线程,直到下列任一情况出现时为止:
调用了 Runtime 类的 exit 方法,并且安全管理器允许退出操作发生。
非守护线程的所有线程都已停止运行,无论是通过从对 run 方法的调用中返回,还是通过 抛出一个传播到 run 方法之外的异常。




你可能感兴趣的:(java,jvm,多线程,编程,虚拟机)