- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[经济学]第8讲 Java多线程技术
Wen Jiabao, College of Information Science and Engineering in Hunan University. OUTLINE 问题导入 程序、进程和线程 创建线程的方式 3.1 继承Thread类的方式 3.2 实现Runnable的方式 3.3 两种创建线程方法的比较 3.4 Thread类 3.5 线程的状态控制 线程的同步与互斥 线程通信 多线程工具库Concurrency Utilities (JSR-166) 1 问题导入 在开始讲述Java多线程技术之前,我们先来思考几个问题: 什么是线程? 为什么要引入线程? 线程有哪些应用? 怎么编写Java多线程程序? 1 问题导入 计算需求现状:随着互联网应用日益普及,数字资源飞速增长,企业和消费者对计算能力和网络流量需求强劲增长。 计算核心:作为计算核心的CPU经过30多年的发展,其主频速度已经接近物理极限。目前,单核处理器正在向多核处理器方向实现跨越式发展,这为分布式计算、并行处理、集群计算、P2P、分布式数据库等应用提供了硬件上的支持和准备。 多核处理器确实可以提升计算机的运算速度和性能,但多核处理性能的发挥依赖于软件,依赖于多线程软件的支持。 线程虽然在80年代末才被真正引入,在Unix、Linux、Solaris、Windows等操作系统中得到了广泛的应用。 计算机高级语言一般提供了串行程序设计(即使包含方法调用)的方法。Java是第一个在语言级支持多线程并发编程的语言。 2 程序、进程和线程 程序(Program)是指能完成预定功能的指令序列,它是静态的。 为提高操作系统的并行性和资源利用率,提出了进程(Process)的概念。进程是程序的一次执行,它是动态的。 进程是操作系统资源分配和处理器调度的基本单位,拥有独立的代码、内部数据和状态(进程上下文)。 频繁的进程状态的切换必然消耗大量的系统资源。为此,又提出了线程(Thread)的概念,进一步分离资源分配和处理器调度两个基本功能:进程只是资源分配的单位,线程是处理器调度的基本单位。 线程本身的数据通常只有寄存器数据,以及一个程序执行时使用的堆栈,所以线程的状态切换比进程间状态切换的负担要小。线程又被称为 轻量级进程LWP(Light Weight Process)。这样进一步提高了系统的整体性能和效率。 2 程序、进程和线程 线程:在一个程序内部实现多个任务(顺序执行线索)的并发执行,其中每个任务称为线程,即线程是一个程序内部的顺序控制流。线程并不是程序,它自己本身并不能运行,必须在程序中运行。 多线程技术应用广泛: 腾讯QQ 迅雷等多线程下载软件 浏览器 … … 如果没有多线程技术,只能串行编程的话… 2 程序、进程和线程 计算机高级语言一般提供了串行程序设计(即使包含方法调用)的方法。一个程序启动一个进程。一个进程中只包含一个执行线索,称为主线程。 2 程序、进程和线程 2 程序、进程和线程 进程、线程的区别: 两者粒度不同,是两个不同层次上的概念。进程是由操作系统来管理的,而线程则是在一个程序(进程)内。 每个进程是操作系统分配资源和处理器调度的基本单位,拥有独立的代码、内部数据和状态(进程上下文),而一个进程(程序)内的多线程只是处理器调度的基本单位,共享该进程的资源,所以线程又被称为轻量级进程。线程间有可能互相影响。 线程本身的数据通常只有寄存器数据,以及一个程序执行时使用的堆栈,所以线程的切换比进程切换的负担要小。 有关进程的大部分概念和技术可直接迁移到到线程上。同时并发进程需要解决的问题,线程也必须给出解决的方案: 线程的同步与互斥问题 线程之间的通信问题 3 Java创建线程的方式 计算机的并发能力(进程并发)由操作系统提供。虽然各种操作系统(Unix/Linux、Windows等)都支持多线程,但若要用C、C++或其他语言编写多线程程序是十分困难的,因为它们对数据同步的支持不充分。Java在语言级提供多线程并发的概念。 什么时候选择线程编程?如果一段代码要执行较长的时间(循环执行)且计算量不太密集,如监控程序,可选择多线程编程。 main()方法是Java Application的入口点。执行一个Java应用程序,首先就会启动一个主线程。由主线程来实现对其它线程的启动、终止、暂时挂起等。 3 Java创建线程的方式 OUTLINE 问题导入 程序、进程和线程 创建线程的方式 3.1 继承Thread类的方式 3.2 实现Runnable的方式 3.3 两种创建线程方法的比较 3.4 Thread类 3.5 线程的状态控制 线程的同步与互斥 线程通信 多线程工具库Concurrency Utilities (JSR-166) 3.1
您可能关注的文档
最近下载
- 企业内部控制采购业务.doc VIP
- 2022年深圳市大鹏新区招聘社区专职工作者考试真题.docx VIP
- 数字化转型背景下职业教育信息化建设路径.pptx VIP
- 第8课 用制度体系保证人民当家作主【2023年秋最新版】.pptx VIP
- 比泽尔-半封闭整体型螺杆压缩机-中文操作手册CSH65-CSH75-CSH85-CSH95.pdf VIP
- 《无衣》(教学课件)-2024-2025学年高二语文选择性必修上册同步备课系列(统编版2019).pptx
- 基于特征性肽段检测人血浆中特瑞普利单抗药物浓度的液相色谱串联质谱方法.pdf VIP
- 矿业权评估师经济与法律笔记2023.docx VIP
- 肺部感染合并心衰护理查房.pptx VIP
- 财富管理02基础-家庭财务报表.ppt VIP
文档评论(0)