一、程序与进程
1、程序:一段静态的代码。
2、进程:程序的一次动态执行过程,它对应从代码加载、执行到执行完毕的一个完整过程。
3、进程也称任务,支持多个进程同时执行的OS就被称为多进程OS或多任务OS。
二、进程与线程
在一个程序内部也可以实现多个任务并发执行,其中每个任务称为线程。
线程是比进程更小的执行单位,它是在一个进程中独立的控制流,即程序内部的控制流。
特点:线程不能独立运行,必须依赖于进程,在进程中运行。
每个程序至少有一个线程称为主线程。
单线程:只有一条线程的进程称为单线程
多线程:有不止一个线程的进程称为多线程
三、开启多线程的优点和缺点
提高界面程序响应速度。通过使用线程,可以将需要大量时间完成的流程在后台启动单独的线程完成,提高前台界面的相应速度。
充分利用系统资源,提高效率。通过在一个程序内部同时执行多个流程,可以充分利用CPU等系统资源,从而最大限度的发挥硬件的性能。
当程序中的线程数量比较多时,系统将花费大量的时间进行线程的切换,这反而会降低程序的执行效率。但是,相对于优势来说,劣势还是很有限的,所以现在的项目开发中,多线程编程技术得到了广泛的应用。
13.2 多线程实现
一、在实现线程编程时,首先需要让一个类具备多线程的能力,继承Thread类或实现Runnable接口的类具备多线程的能力,然后创建线程对象,调用对应的启动线程方法即可实现线程编程。
在一个程序中可以实现多个线程,多线程编程指在同一个程序中启动了两个或两个以上的线程。
在实际实现线程时,Java语言提供了三种实现方式:
(1)继承Thread类
(2)实现Runnable接口
(3)使用Timer和TimerTask组合
二、继承Thread线程类实现多线程
java.lang包中提供了一个专门的线程类(Thread),在该类中封装了许多对线程进行调度和处理的方法。如果一个类继承了Thread类,则该类就具备了多线程的能力,可以多线程的方式执行。
class MyThread extends Thread{
public void run(){
//线程体
}
}
继承Thread类实现多线程。
MyThread tt1 = new MyThread ();
//启动线程
tt1.start();
try{
for(int i = 0;i < 5;i++){
//延时1秒
Thread.sleep(1000);
System.out.println("Main:" + i);
}
}catch(Exception e){}
注意:
线程的特性:随机性,系统在执行多线程程序时只保证线程是交替执行的,至于哪个线程先执行哪个线程后执行,则无法获得保证,需要书写专门的代码才可以保证执行的顺序。
对于同一个线程类,也可以启动多个线程
同一个线程不能启动两次,
当自定义线程中的run方法执行完成以后,则自定义线程自然死亡。而对于系统线程来说,只有当main方法执行结束,而且启动的其它线程都结束以后,才会结束。当系统线程执行结束以后,程序的执行才真正结束。
三、 实现Runable接口
a) 多线程对象实现java.lang.Runnable接口并且在该类中重写Runnable接口的run方法。
b) 好处:实现Runable接口的方法避免了单继承的局限性。
例1:使用实现Runable接口的方式实现多线程。
class MyThread2 implements Runable{
public void run(){} //重写Runable接口中的run()方法
}
MyThread2 mt1=new MyThread2();
Thread t1=new Thread(mt1);
t1.start();
13.3 线程的生命周期
一、线程的生命周期
线程是一个动态执行的过程,它也有一个从产生到死亡的过程,这就是所谓的生命周期。一个线程在它的生命周期内有5种状态:
1、新建(new Thread)
当创建Thread类的一个实例(对象)时,此线程进入新建状态(未被启动)。
例如:Thread t1=new Thread();
2、就绪(runnable)
线程已经被启动,正在等待被分配给CPU时间片,也就是说此时线程正在就绪队列中排队等候得到CPU资源。例如:t1.start();
3、运行(running)
线程获得CPU资源正在执行任务(run()方法),此时除非此线程自动放弃CPU资源或者有优先级更高的线程进入,线程将一直运行到结束。
4、死亡(dead)
当线程执行完毕或被其它线程杀死,线程就进入死亡状态,这时线程不可能再进入就绪状态等待执行。
自然终止:正常运行run()方法后终止
异常终止:调用stop()方法让一个线程终止运行
5、堵塞(blocked)
由于某种原因导致正在运行的线程让出CPU并暂停自己的执行,即进入堵塞状态。
正在睡眠:用sleep(long t) 方法可使线程进入睡眠方式。一个睡眠着的线程在指定的时间过去可进入就绪状态。
正在等待:调用wait()方法。(调用motify()方法回到就绪状态)
被另一个线程所阻塞:调用suspend()方法。(调用resume()方法恢复)
相关推荐
本资源“C#多线程介绍.rar”包含了对这一主题的深入探讨,旨在帮助开发者理解和掌握C#中的多线程编程。 首先,我们要理解什么是线程。线程是操作系统分配CPU时间的基本单位,每个线程都有自己的程序计数器、系统栈...
【VC++多线程介绍】 在Windows环境下,Visual Studio提供了对多线程的支持,使得开发者可以构建更加高效、响应迅速的应用程序。多线程技术允许应用程序同时执行多个独立的任务,从而提高了程序的并发性和资源利用率...
本资源“很的全多线程介绍知识”显然提供了全面的多线程学习资料,非常适合对这一主题感兴趣或者需要提升这方面的技能的人下载学习。 首先,我们要理解什么是多线程。多线程是指在一个应用程序中同时执行多个独立的...
本资料包"多线程介绍.zip"提供了多线程场景的实例源码和相关的说明文档,旨在帮助开发者深入理解并熟练运用多线程技术。 1. **线程的概念** 线程是操作系统调度的基本单位,它共享进程的内存空间,有自己的程序...
Java多线程是Java编程语言中的一个重要特性,它允许在单个程序中同时执行多个线程,从而提高程序的效率和响应性。本文将深入探讨Java多线程的基础概念、线程的生命周期以及一些关键的线程控制方法,如`suspend()`和`...
43 016_1多线程介绍.mp4
多线程
C#,多线程,介绍,html格式 C#,多线程,介绍,html格式 C#,多线程,介绍,html格式 C#,多线程,介绍,html格式 C#,多线程,介绍,html格式 C#,多线程,介绍,html格式 C#,多线程,介绍,html格式
Java 多线程是编程中一个非常重要的概念,特别是在并发编程和系统设计中。Java 提供了一套完整的机制来管理和控制多线程的执行,以确保程序的正确性和高效性。本文将深入探讨 Java 中的多线程相关知识,包括线程的...
在编程领域,多线程是一种重要的并发执行方式,它允许程序同时执行多个任务,从而提高系统资源利用率和程序响应速度。Qt是一个流行的跨平台应用程序开发框架,提供了丰富的API支持多线程编程。本文将深入探讨Qt中的...
Linux下的多线程技术是操作系统中并发执行的重要概念。线程是进程内的执行单元,相比进程,线程具有更低的开销和更快的上下文切换速度。本文将深入讲解线程的相关知识,包括进程与线程的区别、使用线程的优势、线程...
Linux C 多线程介绍: * C 语言的开始设计,并未设计多线程的机制,由于随着软硬件的发展及需求的发展。后来 C 语言才发开了线程库以支持多线程的操作、应用。 * 主要基于 Linux 介绍 C 多线程。在编译 C 的多线程...
本文将深入探讨多进程和多线程的概念,以及在Python中如何实现这些技术。多进程和多线程允许一个程序同时执行多个不同的任务,从而更好地利用计算机资源。 一、多进程与多线程基础 1. **多进程**:多进程是指一个...
本章主要介绍多线程编程的基础知识,包括并发与多线程的概念、多线程编程的重要性、线程的运行机制、并发编程面临的挑战以及如何使用Java中的线程进行编程。 现代计算机具有多个核心,通常为5-10个,但也有如Intel...
在计算机科学领域,多线程是一种程序设计技术,它允许应用程序同时执行多个任务或子任务。这提高了系统资源的利用率,特别是在多核处理器系统中,每个线程可以在一个单独的处理器核心上运行,从而实现真正的并行处理...
#### Linux C多线程介绍 C语言最初并未内置多线程的支持。随着软件和硬件技术的发展,C语言通过引入线程库来支持多线程操作。在Linux环境中,多线程的支持主要是通过`pthread`库实现的。为了在C程序中使用多线程...