进程、线程、线程的创建及多线程

原创 2013年12月04日 01:02:15


1.进程(Process)

所有运行中的任务都对应一条进程。当一个程序进入内存运行,就变成了一个进程。进程是处于运行过程中的程序,并且具有一定独立功能。进程是系统进行资源分配和调度的一个独立单位。

进程有三个特征:

1)独立性:进程是系统中独立存在的实体,它可以拥有自己独立的资源,每一个进程都拥有自己私有的地址空间。在没有经过进程本身允许的情况下,一个用户进程不可以直接访问其他进程的地址空间。

2)动态性:进程是一个正在系统中活动的指令集合。

3)并发性:多个进程可以在单个处理器上并发执行,多个进程之间不会互相影响。

注:并行性和并发性

并行:在同一时刻,有多条指令在多个处理器上同时执行。

并发:同一时刻只能有一条指令执行,但多个进程指令被快速轮换执行,使得在宏观上具有多个进程同时执行的效果。

2.线程(Thread)

线程是进程的组成部分,一个进程可以拥有多个线程,一个线程必须有一个父进程,线程是进程的执行单元。线程不再拥有系统资源,它与父进程的其他线程共享该进程所拥有的全部资源。一个线程可以创建和撤销另一个线程,同一个进程中的多个线程之间可以并发执行。

多线程存在于一个应用程序中,让一个应用程序中可以有多个执行部分同时执行,但操作系统无须将多个线程看作多个独立的应用,对多线程实现调度和管理以及资源分配。线程的调度和管理由进程本身负责完成。

一个程序运行至少有一个进程,一个进程里可以包含多个线程,但至少要包含一个线程。

3.多线程的优势

*进程间不能共享内存,而线程之间共享内存非常容易。因为多个线程共享同一个进程虚拟空间,利用这些共享数据,线程间互相通信很容易。

*系统创建进程需要为该进程重新分配系统资源,而创建线程代价小得多,因此使用多线程来实现多任务并发比多进程的效率高。

4.线程的状态


5.线程的创建

1)继承Thread类创建线程类

a.定义Thread类的子类,并重写该类的run()方法。

b.创建Thread子类的对象。

c.用线程对象的start()方法来启动线程。

例1:

package com.itheima;

/**
 * 继承Thread类创建线程类
 * */

public class ThreadDemo_1 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		//创建两个线程
		FirstThread t1 = new FirstThread();
		FirstThread t2 = new FirstThread();
		//开启两个线程
		t1.start();
		t2.start();
		
		//主线程执行的代码
		for(int i = 0; i < 60; i++) {
			//调用Thread的currentThread方法获取当前线程
			System.out.println(Thread.currentThread().getName() + "---" + i);
		}

	}	
}


class FirstThread extends Thread {
	
	//重写run方法,封装线程要执行的代码
	public void run() {
		for(int i = 0; i < 60; i++) {
			//getName()返回当前线程的名字
			System.out.println(getName() + "---" + i);
		}
	}
}
2)实现Runnable接口创建线程类

a.定义Runnable接口实现类,重写run()方法。

b.创建Runnable实现类对象,并将该对象作为参数传入Thread类的构造器来创建Thread对象。

c.调用Thread对象的start()方法。

例2:

package com.itheima;

/**
 * 实现Runnable接口创建线程类
 * */

public class ThreadDemo_2 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		//开启两个线程
		new Thread(new SecondThread()).start();
		new Thread(new SecondThread()).start();
		
		//主线程执行的代码
		for(int i = 0; i < 60; i++) {
			//调用Thread的currentThread方法获取当前线程
			System.out.println(Thread.currentThread().getName() + "---" + i);
		}
	}
}

class SecondThread implements Runnable {
	//重写run方法,封装线程要执行的代码
		public void run() {
			for(int i = 0; i < 60; i++) {
				//当线程类实现Runnable接口时,
				//如果想获取当前线程,只能用Thread.currentThread()方法。
				System.out.println(Thread.currentThread().getName() + "---" + i);
			}
		}
}
6.两种方式比较

1)采用实现Runnable接口方式:

优势:线程类只是实现了Runnable接口,还可以继承其他类;多个线程可以共享线程类的实例属性,因为是多条线程访问同一个Runnable  实现类对象。

劣势:如果要访问当前线程,必须使用Thread.currentThread()方法。

2)采用继承Thread类方式:

优势:编写简单,如果访问当前线程,无需使用Thread.currentThread()方法,直接使用this即可。

劣势:因为线程类已经继承了Thread类,所以不能再继承其他父类;多条线程无法共享线程类的实例变量。


7.注意

1)不要对已经处于启动状态的线程再次调用start方法,否则将引发IllegalThreadStateException异常。

2)不要对处于死亡状态的线程调用start方法,程序只能对新建状态的线程调用start方法。否则将引发IllegalThreadStateException异常。

3)当主线程结束的时候,其他线程不受任何影响,并不会随之结束。一旦子线程启动起来,它就拥有和主线程相同的地位,它不受主线程的影响。



多线程编程-通过fork方式创建任务进程

背景在多进程中需要创建一个任务进程进行待处理任务的分发工作。也就是说,需要在主进程中detach剥离出一个进程,且该子进程独立于主进程,进行独立的任务发送。如果是单纯在主进程中fork一个子进程的话,...
  • ljp1919
  • ljp1919
  • 2017年03月07日 16:02
  • 278

进程与线程学习(三)之线程之使用场合

在对进程、线程的学习稍加了解后,不仅会自问在什么情况下要使用多线程?毕竟,对知识的学习而不在于知识本身,而是怎么使用所学的知识,有什么局限性。 但从耗时来讲,我对多线程做了一些测试:程序如下: 只...
  • sgs1018
  • sgs1018
  • 2013年04月27日 14:51
  • 879

多线程切换以及线程进程之间关系

进程是资源拥有的单位。线程是调度的最小单位。又称为轻进程。他只拥有进程中一些资源,这次资源对于这个线程来说是必不可少的。而所有的线程共享进程的资源。因此不同的线程之间可以共享一些数据变量。而进程则不可...
  • sunxiaopengsun
  • sunxiaopengsun
  • 2017年02月23日 09:53
  • 826

Java(线程的概念)(线程和进程的比较)(多线程的优点)

一般地,每个程序都会有一个入口,一个出口以及一个顺序执行的序列,执行中的程序称为进程,在进程执行过程中的任何指定时刻,都只有一个单独的执行点。在多线程的情况下,在单个进程内部可以在同一时刻进行多种运算...
  • JACK_JYH
  • JACK_JYH
  • 2016年09月01日 20:12
  • 386

进程、线程与多线程概念详解

一、概述 在windows中,每一个打开运行的应用程序或后台程序,比如运行中的QQ、谷歌浏览器、网易云音乐、资源管理器等都是一个进程。我们感觉这些程序是“同时”运行的,但实际上,一个处理器同一时刻只...
  • zhangliangzi
  • zhangliangzi
  • 2016年04月24日 21:33
  • 2344

什么是线程?它与进程有什么区别?为什么要使用多线程?

线程是指程序在执行过程中,能够执行程序代码的一个执行单元。在Java语言中,线程有四种状态:运行、就绪、挂起、结束。 进程是指一段正在执行的程序。而线程有时候也被称为轻量级进程,是程序执行的最小单元,...
  • xdhehao
  • xdhehao
  • 2014年09月11日 22:47
  • 2958

编程思想之多线程与多进程(1)——以操作系统的角度述说线程与进程

线程是什么?要理解这个概念,须要先了解一下操作系统的一些相关概念。大部分操作系统(如Windows、Linux)的任务调度是采用时间片轮转的抢占式调度方式,也就是说一个任务执行一小段时间后强制暂停去执...
  • luoweifu
  • luoweifu
  • 2015年06月22日 20:05
  • 53494

关于使用sigsuspend(sigset_t* mask)阻塞进程

sigsuspend的定义:http://man7.org/linux/man-pages/man2/sigsuspend.2.html 参考博文:http://www.tuic...
  • u010346319
  • u010346319
  • 2013年12月16日 06:46
  • 780

理解process(进程)、thread(线程)

理解process(进程)、thread(线程)
  • chenjiaxiang520
  • chenjiaxiang520
  • 2016年12月17日 13:33
  • 309

一个进程可以创建多少个线程

最近在做端口扫描的实验,需要用到多线程,在批量扫描的时候,对每个ip地址来说,为其所有要扫描的每个端口创建一个线程,主机最多有65535个端口,然后我就创建了这么多(65535)的线程。结果就是中断了...
  • qq_31917799
  • qq_31917799
  • 2016年12月21日 20:00
  • 1492
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:进程、线程、线程的创建及多线程
举报原因:
原因补充:

(最多只允许输入30个字)