对编程语言的基础知识:分支、选择、循环、面向对象等基本概念理解后,我们需要对java高级编程有一定的学习,这里不可避免的要接触到多线程开发。
由于多线程开发整体的系统比较大,我会写一个系列的文章总结介绍 多线程开发的概念、使用、线程状态、同步、线程池。希望与大家共勉。
在第一部分,也就是本节我们先介绍下 什么是多线程程序、线程和进程又是什么,以及为什么要搞多线程。
(一)什么是多线程程序
多线程听上去是非常专业的概念,其实非常简单,我们在日常生活中,经常的接触到多线程。
比如
(1)在工厂,工人努力工作,分工明确。一些工人准备生产资料(混凝土、钢筋、砖头),另外一些工人挖掘地基,还有些工人负责平常无聊的看管,后勤的保障(有点像守护进程,这个后面会专门讲到)。他们总体来说就是把一件事分成若干的工作,然后派不同的人去做,最后使工作得到完善的解决。(一个工人算一条线程)
(2)一个学生完成晚上写的作业,有语、数、外的作业。这名学生写了一半的语文作业后,有一道题不会做,先去完成数学作业,接着再完成英语作业,最后等到家长回来完成语文作业。(一门作业算一条线程)
主要是有这两种情况的多线程,
一种是上边有多个工人(多处理器),各个工人间的工作影响不大,不会因为其中一个工人的努力工作,而导致另外一个工作停歇。
另外一种就是下边的写作业形式(单处理器,只有一个人在做作业),虽然我们有多个作业需要在今天晚上完成(执行),但是某一个时刻我们只能做一件事,当遇到某种情况(例如不会做、或者心情不好)我们随意的切换到其他的科目,然后开始其他的工作,因为某些原因(如有人可以出现辅导),那么我们又可以切换回来,继续做一开始未完成的事情,直到所有的事情都解决完为止。这里要区分一下:写作业的例子看着有点像单线程模式的例子,实则不然,单线程只能按照某种既定的顺序,顺序完成事情,比如语文->外语->数学。遇到困难时(不会做),并不能因为某种原因,而随意的切换,只能苦苦等待。而多线程则可根据环境动态的转换,如他们之间的顺序如语文->外语->数学->语文->外语->外语->数学 这样。(防盗连接:本文首发自王若伊_恩赐解脱http://www.cnblogs.com/jilodream/ )
这种一次做多件事的情况就是多线程(包含短时间内快速的切换,形成一次做多件事的感觉),下面介绍进程和线程,从计算机的角度来谈谈编程中多线程的概念。
(二)线程和进程又是什么
进程: 对于一个OS,如果有一个程序在内存中开始运行,我们就可以说这个运行的程序就是一个进程。这个进程拥有自己独立的功能,并且是OS调度和分配资源的一个独立单位。
对于进程有三个特点
(1)独立性:进程是系统中独立存在的一个实体,拥有自己的资源的,没有自身的允许的话,其他用户进程是不能访问他内部的。
(2)动态性:进程是有生命周期的,他是在OS中活动的一个指令集合。而程序只是一个静态的指令集合。
(3)并发性:在只有一个处理器时,多个进程间也可以并发执行,互相并不影响。(进程间相互轮换执行,如同同时进行一般)
线程:线程是进程执行单元,也可以说是一个轻量级的进程。就像OS中进程是独立的一样,进程中的各个线程也是独立的。每个线程都有自己独立的堆栈及其他资源。互相并不受影响。而进程(这些线程的拥有者)的所有系统资源,被它包含的所有线程所共有分享。
线程也是独立的,他并不知道当前进程中其他线程的存在,而当前线程是否被执行,则与进程类似,是抢占式的。当前进程抢到了OS的执行权,而进程中的某一条线程又抢到了,当前可执行的权利(其他线程和进程被挂起)。
多线程就是一个进程中,可以有多个并发执行的独立的任务,每一个任务可以说就是一个线程。
他们的关系:
一个OS下边可以有若干的进程(但是至少要有一个进程)。
每一个进程下边又有若干的线程(至少要有一条线程)。
(三)为什么要搞多线程呢?
最最最核心的原因就是:提高工作效率,不要出现闲时等待,各个线程抢占式的工作。试想下,如果我们遇到什么问题,是应该一直苦苦等待(是什么都不做的等待)下去性能高呢,还是快速的切换到其他工作上去,我想在大部分的情况下都是快速抢占吧。(有时可能会出现,你刚刚切换,原来苦苦等待的事情刚刚结束。。。。这种碰巧的情况),举个实际点的例子,当我们查询某一个数据时,这个数据可能非常大,我们需要等待好久才能在页面上加载下来,此时倘若单线程苦苦等待时,我们的程序就是被挂死了(试想下没有响应的场景),直到过去了很久,页面才被激活,变成可用的状态。这期间我们什么事情也干不了(对该程序),这时的场景效率很低下,而且非常不友好。
倘若有很好的多线程支持的话,那么在加载数据、绘制图片时,我们还可以随意的切换程序,并不影响其他的操作,从而提高性能。于此同时,由于多线程共享父进程的其他所有资源,所以线程间可以很好的交流数据(数据共享和通信),并且新开辟的线程(新开辟的任务),OS并不会为该进程分配大量的资源(相对于为新开辟任务而创建新进程而言)。
总结一下有如下几个优点
1、线程间可以很好的共享内存资源,进程间是完全独立内存的,所以不方便。(前文中提到线程间是相互独立的,除非一进程允许,否则其他的进程是不允许直接访问它地址的)
2、系统创建新线程的开销,新创建进程的开销要小的多,因此可大大降低多并发的代价。
3、在编码时,我们可以通过类库和代码很好的管理各个线程,而不是直接通过操作系统来指挥当前执行的进程。从而大大的方便了我们可以处理并发任务的执行。
Java多线程开发系列之一:走进多线程的更多相关文章
-
Java多线程开发系列之番外篇:事件派发线程---EventDispatchThread
事件派发线程是java Swing开发中重要的知识点,在安卓app开发中,也是非常重要的一点.今天我们在多线程开发中,穿插进来这个线程.分别从线程的来由.原理和使用方法三个方面来学习事件派发线程. 一 ...
-
Java多线程开发系列之四:玩转多线程(线程的控制2)
在上节的线程控制(详情点击这里)中,我们讲解了线程的等待join().守护线程.本节我们将会把剩下的线程控制内容一并讲完,主要内容有线程的睡眠.让步.优先级.挂起和恢复.停止等. 废话不多说,我们直接 ...
-
Java多线程开发系列之三:线程这一辈子(线程的生命周期)
前文中已经提到了,关于多线程的基础知识和多线程的创建.但是如果想要很好的管理多线程,一定要对线程的生命周期有一个整体概念.本节即对线程的一生进行介绍,让大家对线程的各个时段的状态有一定了解. 线程的一 ...
-
高级java必会系列二:多线程经常使用的3个关键字:synchronized、ReentrantLock、volatile
系列一讲解了多线程,本章讲解多线程开发中经常使用到的3个关键字synchronized.ReentrantLock.volatile. 一.synchronized 互斥锁,即操作互斥,并发线程过来, ...
-
Java SE开发系列-JDK下载安装
JDK下载安装 JDK是Java的开发环境,目前JDK内部也包含了JRE,JRE主要是JAVA程序的运行环境. 点击官方下载地址,按着下图操作即可下载对应系统的不同版本JDK. 进入页面滑到页面底部点 ...
-
Java多线程开发系列之二:如何创建多线程
前文已介绍过多线程的基本知识了,比如什么是多线程,什么又是进程,为什么要使用多线程等等. 在了解了软件开发中使用多线程的基本常识后,我们今天来聊聊如何简单的使用多线程. 在Java中创建多线程的方式有 ...
-
Java多线程开发系列之四:玩转多线程(线程的控制1)
在前文中我们已经学习了:线程的基本情况.如何创建多线程.线程的生命周期.利用已有知识我们已经可以写出如何利用多线程处理大量任务这样简单的程序.但是当应用场景复杂时,我们还需要从管理控制入手,更好的操纵 ...
-
高级java必会系列一:多线程的简单使用
众所周知,开启线程2种方法:第一是实现Runable接口,第二继承Thread类.(当然内部类也算...)常用的,这里就不再赘述.本章主要分析总结线程池和常用调度类. 一.线程池 1.newCache ...
-
java并发编程系列一、多线程
一.什么是线程 一个应用就是一个进程.一个进程由多个线程组成.一个生产车间比作是一个进程.工人比作是线程.当任务比较多的时候,增加工人可以提高效率,同时成本就是支付费用(机器资源,内存)也会增加. p ...
随机推荐
-
Complete The Pattern #1
Complete The Pattern #1 Task: You have to write a function pattern which creates the following patte ...
-
axios POST提交数据的三种请求方式写法
1.Content-Type: application/json import axios from 'axios' let data = {"code":"1234&q ...
-
C# 时间控件 竖直进度条 饼图显示 仪表盘 按钮基础控件库
Prepare 本文将使用一个NuGet公开的组件来实现一些特殊的控件显示,方便大家进行快速的开发系统. 在Visual Studio 中的NuGet管理器中可以下载安装,也可以直接在NuGet控制台 ...
-
DNS协议工作过程;DNS的安全隐患
DNS协议工作过程 下面以域名为m.xyz.com的主机欲通过另一个主机的域名y.abc.com的IP地址为例,简述DNS协议过程. 主机m.xyz.com先向其本地服务器dns.xyz.com进 ...
-
Ubuntu 12.04 下安装 JDK 7
原文链接:http://hi.baidu.com/sanwer/item/370a23330a6a7b23b3c0c533 方法一1.下载 JDK 7从http://www.oracle.com/te ...
-
使用perf + FlameGraph生成进程火焰图
FlameGraph代码:https://github.com/cobblau/FlameGraph 使用方法 1,perf record --call-graph dwarf -p 12345 2, ...
-
iOS-实现对象拷贝【对象拷贝】
对象引用 NSCopying 代理 .h @interface xk : NSObject <NSCopying> @property (nonatomic, copy) NSString ...
-
centos 7 初始化脚本
#!/bin/bash # 时间: 2018-11-21 # 作者: HuYuan # 描述: CentOS 7 初始化脚本 # 加载配置文件 if [ -n "${1}" ];t ...
-
asp.net web api 跨域,带cookie
官网上有一个介绍 http://www.asp.net/web-api/overview/security/enabling-cross-origin-requests-in-web-api 但是只支 ...
-
PCB中的SOLD MASK和阻抗开窗
应用场合:1 PCB中的贴片的焊盘是不过油的,需要暴露出来用于焊接:对于电机驱动需要大电流的走线需要将走线保留暴露出来不过油,然后在上面走一层锡,增大锡箔,铜箔厚度,增大过流和防过热能力. 方法:先在 ...