一个进程可以有多个线程,如视频中同时听声音,看图像等。
Process与Thread
说起进程,就不得不说下程序。程序是指令和数据的有序集合,
其本身没有任何运行的含义,是一个静态的概念。
而进程则是执行程序的一次执行过程,它是一个动态的概念。
是系统资源分配的单位。
通常在一个进程中可以包含若干个线程,当然一个进程中至少有一个线程,不然没有存在的意义。线程是CPU调度和执行的单位。
注意:很多多线程是模拟出来的,真正的多线程是指有多个CPU,即多核,如服务器。如果是模拟出来的多线程,即在一个CPU
的情况下,在同一个时间点,CPU只能执行一个代码,因为切换的很快,所以就有同时执行的错局。
核心概念
线程就是独立的执行路径。
在程序运行时,即使没有自己创建线程,后台也会有多个线程,如主线程,gc线程。
main()称之为主线程,为系统的入口,用于执行整个程序。
在一个进程中,如果开辟了多个线程,线程的运行由调度器安排调度,调度器是与操作系统紧密相关的,先后顺序是不能认为的干预的。对同一份资源操作时,会存在资源抢夺的问题,需要加入并发控制。线程会带来额外的开销,如CPU调度时间,并发控制开销。
每个线程在自己的工作内存交互,内存控制不当会造成数据不一致。
创建线程方式一:继承Thread1 类,重写run()方法,调用start开启线程
总结:注意,线程开始不一定立即执行,由CPU调度执行
public class TestThread1 extends Thread {
public void run (){
//run方法线程体
for (int i = 0 ;i < 20 ; i++){
System .out.println (“我在看代码.......”i++){
}
}
public static void main (String []args ){
//main 线程,主线程
//创建一个线程对象
TestThread1 testThread1 = new TestThread1();
//调用start()方法开启线程
TestThread1.start();
for (int i = 0;i<20;i++){
System.out.println (“我在学习多线程......”+i);
}
}
}
练习Thread , 实现多线程同步下载图片
public class TestThread2 extends Thread{
private String url;
private String name;
}
public TestThread2()String url,String name){
this.url = url;
this.name = name;
}
@override
public void run (){
WebDownload webDownloader = new webDownloader();
web Downloader.downloader(url,name);
System.out.println (“下载了文件名:”+name);
}
public static void main(String[]args){
TestThread2 testThread2 = new TestThread2();
}
下载器
class WeDownloader2 (){
}
}
//下载方法
public void downloader(String url,String name){
try{
FileUtils.copyURLToFile (new URL(url),new File(name));
}catch(IoException e){
e.printStackTrace();
System.out.println(“IO异常,downloader方法出现问题”);
}
}
}
线程实现(重点)
-
继承Thread类
-
实现Runable接口
-
实现Callable接口
线程同步(重点)