多线程(1)

299 阅读3分钟

并发和并行

并行:指两个或多个时间在同一时刻发生(同时发生);

并发:指两个或者两个以上的事情在同一时间段内同时发生;

在操作系统中,安装了多个程序,并发指的是在一段时间内宏观上有多个程序同时运行,这在单 CPU 系统中,每一时刻只能有一道程序执行,即微观上这些程序是分时的交替运行,只不过是给人的感觉是同时运行,那是因为分时交替运行的时间是非常短的。

  而在多个 CPU 系统中,则这些可以并发执行的程序便可以分配到多个处理器上(CPU),实现多任务并行执行,即利用每个处理器来处理一个可以并发执行的程序,这样多个程序便可以同时执行。

  目前电脑市场上说的多核 CPU,便是多核处理器,核 越多,并行处理的程序越多,能大大的提高电脑运行的效率。

注意:单核处理器的计算机肯定不能并行的处理多个任务,只能是多个任务交替的在单个 CPU 上运行。

进程和线程

进程:是指一个内存中运行的应用程序,每个进程都有一个独立的内存空间,一个应用程序可以同时运行多个进程;进程也是程序的一次执行过程,是系统运行程序的基本单位;系统运行一个程序即是一个进程从创建、运行到消亡的过程。

线程:进程内部的一个独立执行单元;一个进程可以同时并发的运行多个线程,可以理解为一个进程便相当于一个单cpu操作系统,而线程便是这个系统中运行的多个任务。

注意: 因为一个进程中的多个线程是并发运行的,那么从微观角度看也是有先后顺序的,哪个线程先执行完全取决于CPU 的调度,程序员是干涉不了,这就造成了多线程的随机性。

2、Java 程序的进程里面至少包含两个线程,主进程也就是main() 方法线程,另外一个是垃圾回收机制线程。每当使用Java命令执行一个类时,实际上都会启动一个JVM,每一个JVM 实际上就是在操作系统中启动了一个线程,Java 本身具备了垃圾的收集机制,所有在Java 运行时至少会启动两个线程。

3、由于创建一个线程的开销比一个进程的开销小的多,那么我们在开发多任务运行的时候,通常考虑创建多线程,而不是创建多进程。

4、多线程是为了同步完成多个任务,不是为了提高程序运行效率。而是提高资源使用效率来提高系统的效率,比如做一个添加功能,需要向很多用户发送短信和邮件,如果需要一分钟,不能能让用户等一分钟才响应,可以使用多线程做后台发送,如果是单核,则多个任务交替的在单个CPU上运行,理论上比不使用多线程耗时多,因为CPU切换任务需要耗费时间,如果是多核,则可以提高资源的使用效率,多核可以充分利用上。

Java创建多线程

第一种方法:继承Thread类

步骤:

1、定义一个线程类A继承于Java.lang.Thread类。

2、在A类中覆盖Thread 类的run() 方法。

3、在run()方法中编写需要执行的操作。

4、在min()方法(线程)中,创建线程对象,并启动线程

     创建线程类:A类 a=new A() 类;

     调用start() 方法启动线程:a.start();