线程的简单学习笔记:
1、进程与线程的概念
进程:从用户角度看进程是应用程序的一个执行过程。
从操作系统核心角度看进程代表的是操作系统分配的内存和CPU时间片等资源的基本单位,是为正在运行的程序提供的运行环境。
线程:是程序执行流的最小单位(处理器调度的最小单位)
线程是一个程序中一个单一的顺序控制流程。
线程是程序执行的一条路径,一个进程中可以包含多条线程。
2、创建线程
在线程类使用new关键字实例化之后且在调用start()方法之前,线程处于创建状态,处于创建状态的线程仅仅分配了内存空间,属于生命周期的初始状态。
启动线程:类Thread定义了start()方法用来完成线程的启动。
创建线程有两种方法:
继承java.lang.Thread类或者实现Runnable接口
第一种方法:继承继承java.lang.Thread类
可以通过继承Thread类,覆盖其Run()方法创建自己的线程类。语法格式如下;
ClassMyThread(线程名)extendsThread{
//覆盖Thread类的run()方法
Publicvoidrun(){
//执行语句;
}
}
在main方法中:
MyThreadmt=newMyThread();
Mt.start();
第二种创建线程的方法是实现Runnable接口
如果定义的线程类还要继承其他类,这时就不能继承Thread类了,这种情况可以采用实现Runnable接口的方式创建,语法格式如下:
ClassMyThread(线程名)implementsRunnable{
Publicvoidrun(){
//执行语句;
}
}
在main方法中:
MyThreadmt=newMyThread();
Threadt=newThread(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(longmillis):表示等待该线程终止的时间最长为millis毫秒,超时为0意味着要一直等下去。0代表超时时间无限长。
简单理解为;可以等待指定的毫秒之后继续
5、线程之间的同步
当多个线程操作多个共享资源时,比如读写同一个变量,才在着资源竞争的问题。为了解决此类问题,需要使用同步机制。在java语言中,利用synchronized关键字实现线程的同步。
语法格式如下:
访问修饰符同步关键字(synchronized)返回值类型方法名(参数)
相关推荐
Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式...
Java多线程读大文件 java多线程写文件:多线程往队列中写入数据
java多线程PPT 多线程基本概念 创建线程的方式 线程的挂起与唤醒 多线程问题
一个java 多线程操作数据库应用程序!!!
java多线程经典案例,线程同步、线程通信、线程阻塞等经典案例
《Java多线程编程核心技术》建议猿友们读两遍,因为其写得没有那么抽象,第一遍有些概念不是很理解,可以先跳过并记录起来,第一遍阅读的目的主要是了解整个架构。第二遍再慢慢品味,并贯穿全部是指点来思考,并将...
Java多线程编程实战指南(核心篇) 高清pdf带目录 随着现代处理器的生产工艺从提升处理器主频频率转向多核化,即在一块芯片上集成多个处理器内核(Core),多核处理器(Multicore Processor)离我们越来越近了――如今...
该文档总结了Java多线程相关的知识点,分享给大家,简单易懂!
详细的讲解了java多线程的原理,并配有代码进行实战,适合java初学者和想对多线程有进一步了解的人。
一张图方便理解和掌握java 多线程之间通信的实质 java 多线程 其实就是每个线程都拥有自己的内存空间,多线程之间的通信,比例A线程修改了主内存(main方法的线程)变量,需要把A线程修改的结果同步到主线程中,...
java多线程处理数据库数据,使用并发包,无框架,可批量处数据库数据,进行增删改。。等等操作。
java多线程,对多线程,线程池进行封装,方便使用
现在的操作系统是多任务操作系统。多线程是实现多任务的一种方式。 线程是指进程中的一个执行流程,一个进程中可以运行多个线程。...本文档提供Java多线程编程经验,方便广大Java爱好者研究学习Java多线程
java多线程处理大数据,可根据配置的线程数,任务去调度处理
java多线程并发的在新窗口
Java多线程机制 9.1 Java中的线程 9.2 Thread的子类创建线程 9.3 使用Runable接口 9.4 线程的常用方法 9.5 GUI线程 9.6 线程同步 9.7 在同步方法中使用wait()、notify 和notifyAll()方法 9.8 挂起、恢复和终止线程 ...
资深Java专家10年经验总结,全程案例式讲解,首本全面介绍Java多线程编程技术的专著 结合大量实例,全面讲解Java多线程编程中的并发访问、线程间通信、锁等最难突破的核心技术与应用实践 Java多线程无处不在,如...
java多线程实现大批量数据切分成指定份数的数据,然后多线程处理入库或者导出,线程的个数和每份数据的数量都可以控制
java多线程并发查询数据库,使用线程池控制分页,并发查询。
java多线程模拟队列实现排队叫号,多线程模拟排队叫号取号 java多线程模拟队列实现排队叫号,多线程模拟排队叫号取号