多线程的学习笔记

线程的简单学习笔记:

1、进程与线程的概念

进程:从用户角度看进程是应用程序的一个执行过程。

从操作系统核心角度看进程代表的是操作系统分配的内存和CPU时间片等资源的基本单位,是为正在运行的程序提供的运行环境。

线程:是程序执行流的最小单位(处理器调度的最小单位)

线程是一个程序中一个单一的顺序控制流程。

线程是程序执行的一条路径, 一个进程中可以包含多条线程。

2、创建线程

在线程类使用new 关键字实例化之后且在调用start()方法之前,线程处于创建状态,处于创建状态的线程仅仅分配了内存空间,属于生命周期的初始状态。

启动线程:类Thread定义了start()方法用来完成线程的启动。

创建线程有两种方法:

继承java.lang.Thread类或者实现Runnable接口

第一种方法:继承继承java.lang.Thread类

可以通过继承Thread类,覆盖其Run()方法创建自己的线程类。语法格式如下;

Class MyThread(线程名)  extends Thread{

//覆盖Thread类的run()方法

Public void run(){

//执行语句;

}

}

在main方法中:

MyThread  mt=new MyThread();

Mt.start();

第二种创建线程的方法是实现Runnable接口

如果定义的线程类还要继承其他类,这时就不能继承Thread类了,这种情况可以采用实现Runnable接口的方式创建,语法格式如下:

Class    MyThread(线程名)  implements  Runnable{

Public void run(){

//执行语句;

}

}

在main方法中:

MyThread  mt=new MyThread();

Thread t=new Thread(mt);

t.start();

3、线程的生命周期

1)、创建线程

在线程类使用new 关键字实例化之后且在调用start()方法之前,线程处于创建状态,处于创建状态的线程仅仅分配了内存空间,属于生命周期的初始状态。类Thread定义了start()方法用来完成线程的启动。

2)、就绪

在线程调用了start()方法后即处于就绪状态。处于就绪状态的线程就具备了除CPU之外运行所需的所有资源,就绪状态线程排队等待CPU,有系统调度为其分配。

3)、运行

处于就绪状态的线程获得CPU之后即处于运行状态。处于运行状态的线程才开始真正执行线程run()方法的内容。

4)、阻塞

处于运行状态的线程如果因为某种原因不能执行,则进入阻塞状态。阻塞状态与就绪状态的不同是:就绪状态只是因为确实CPU不能执行,而阻塞状态由于各种原因引起线程不能执行,不仅仅是缺少CPU。引起阻塞的原因解除后,线程再次转为就绪状态,等待分配CPU运行。

5)、死亡

当线程执行完run()方法的内容或被强制终止时,线程处于死亡状态,线程的整个生命周期结束。

线程再整个生命周期中始终处于某种状态,从一种状态到另一种状态的转换由线程调度方法实现。

4、线程的调度

处于生命周期中的线程,通过调度实现各种状态间的转换,线程的调度是使用各种线程调度方法;如;setPriority(),sleep(),

yield(),join()等。对线程进行不同的操作。

setPriority():线程的优先级

sleep():线程休眠

yield():线程让步

join():线程等待

setPriority():线程的优先级 线程的优先级是指线程调度执行时的优先执行级别。在多线程程序中,往往是多个线程同时等待被调度执行。然而,每个线程的重要层度不一样,在同等条件下,有些重要的线程需要优先执行。在java语言中,通过调用setPriority()方法为线程设置优先级,优先级用1--10 的数字表示,数字越大,优先级越高。

sleep()方法: 在指定的毫秒数内让当前正在执行的线程休眠(暂停执行),此操作受到系统计时器和调度程序精度和准确性的影响。

可以引起当前线程挂起执行一个指定的时期,这意味着处理时间可用于程序其他线程,或者执行在计算机系统内的其他应用程序。sleep()方法还被用于控制步调等待另外的线程完成有时间要求的任务。

yield()方法:暂停当前正在执行的线程对象,并执行其他线程。

对于正在执行的线程,可以调用yield()方法使其重新排队,将CPU让给排在后面的线程,此线程转为就绪状态。另外,yield()方法只让步给高优先级或者同等优先级的线程,如果后面是低优先级线程,则继续执行此线程。

join()方法:对于正在运行的线程,可以调用jion方法等待其结束,然后执行其他程序。jion()方法有几种重载形式,其中,不带任何参数的join()方法,等待线程执行结束为止,带有一个参数的join(long millis):表示等待该线程终止的时间最长为millis毫秒,超时为 0 意味着要一直等下去。0代表超时时间无限长。

简单理解为;可以等待指定的毫秒之后继续

5、线程之间的同步

当多个线程操作多个共享资源时,比如读写同一个变量,才在着资源竞争的问题。为了解决此类问题,需要使用同步机制。在java语言中,利用synchronized关键字实现线程的同步。

语法格式如下:

访问修饰符 同步关键字(synchronized) 返回值类型 方法名(参数)

多线程的学习笔记

时间: 2024-10-12 17:47:45

多线程的学习笔记的相关文章

Java多线程技术学习笔记(二)

目录: 线程间的通信示例 等待唤醒机制 等待唤醒机制的优化 线程间通信经典问题:多生产者多消费者问题 多生产多消费问题的解决 JDK1.5之后的新加锁方式 多生产多消费问题的新解决办法 sleep和wait的区别 停止线程的方式 守护线程 线程的其他知识点 一.线程间的通信示例 返目录回 多个线程在处理同一资源,任务却不同. 假设有一堆货物,有一辆车把这批货物往仓库里面运,另外一辆车把前一辆车运进仓库的货物往外面运.这里货物就是同一资源,但是两辆车的任务却不同,一个是往里运,一个是往外运. 下面

多线程编程学习笔记——线程池(一)

接上文 多线程编程学习笔记——线程同步(一) 接上文 多线程编程学习笔记——线程同步(二) 接上文 多线程编程学习笔记——线程同步(三) 创建多线程操作是非常昂贵的,所以每个运行时间非常短的操作,创建多线程进行操作,可能并不能提高效率,反而降低了效率. 如果你有非常多的执行时间非常短的操作,那么适合作用线程池来提高效率,而不是自行创建多线程. 线程池,就是我们先分配一些资源到池子里,当我们需要使用时,则从池子中获取,用完了,再放回池子里. .NET中的线程池是受CLR管理的,TheadTool类

多线程编程学习笔记——线程同步(三)

接上文 多线程编程学习笔记——线程同步(一) 接上文 多线程编程学习笔记——线程同步(二) 七.使用Barrier类 Barrier类用于组织多个线程及时在某个时刻会面,其提供一个回调函数,每次线程调用了SignalAndWait方法后该回调函数就会被执行. 1.代码如下: using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading; //

多线程编程学习笔记——async和await(二)

接上文 多线程编程学习笔记——async和await(一) 三.   对连续的异步任务使用await操作符 本示例学习如何阅读有多个await方法方法时,程序的实际流程是怎么样的,理解await的异步调用 . 1.示例代码如下. using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Thread

多线程编程学习笔记——async和await(三)

接上文 多线程编程学习笔记——async和await(一) 接上文 多线程编程学习笔记——async和await(二) 五.   处理异步操作中的异常 本示例学习如何在异步函数中处理异常,学习如何对多个并行的异步操作使用await时聚合异常. 1.程序示例代码如下. using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks;

多线程编程学习笔记——使用并发集合(三)

接上文 多线程编程学习笔记——使用并发集合(一) 接上文 多线程编程学习笔记——使用并发集合(二) 四.   使用ConcurrentBag创建一个可扩展的爬虫 本示例在多个独立的即可生产任务又可消费任务的工作者间如何扩展工作量. 1.程序代码如下. using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using Sy

多线程编程学习笔记——编写一个异步的HTTP服务器和客户端

接上文 多线程编程学习笔记——使用异步IO 二.   编写一个异步的HTTP服务器和客户端 本节展示了如何编写一个简单的异步HTTP服务器. 1.程序代码如下. using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Net; using System.Net.Http; using System.Text; using System.Threading.Ta

Java多线程技术学习笔记(一)

目录: 概述 多线程的好处与弊端 JVM中的多线程解析 多线程的创建方式之一:继承Thread类 线程的状态 多线程创建的方式之二:实现Runnable接口 使用方式二创建多线程的好处 多线程示例 线程安全问题现象 线程安全问题产生的原因 同步代码块 同步的好处与弊端 同步的前提 同步函数 验证同步函数的锁 单例模式的线程安全问题的解决方案 死锁示例 一.概述 目录 首先得了解进程,打开我们电脑的windows资源管理器,可以直观看到进程的样子: 进程直观上理解就是正在进行的程序.而每个进程包含

Java多线程编程(学习笔记)

一.说明 周末抽空重新学习了下多线程,为了方便以后查阅,写下学习笔记. 有效利用多线程的关键是理解程序是并发执行而不是串行执行的.例如:程序中有两个子系统需要并发执行,这时候需要利用多线程编程. 通过多线程的使用,可以编写出非常高效的程序.但如果创建了太多的线程,程序执行的效率反而会降低. 同时上下文的切换开销也很重要,如果创建太多的线程,CPU花费在上下文的切换时间将对于执行程序的时间. 二.Java多线程编程 概念 在学习多线程时,我们应该首先明白另外一个概念. 进程:是计算机中的程序关于某