一、基本概念

a、操作系统中进程与线程的概念

现在的操作系统是多任务操作系统。多线程是实现多任务的一种方式。 进程是指一个内存中运行的应用程序,每个进程都有自己独立的一块内存空间,

一个进程中可以启动多个线程。比如在Windows系统中,一个运行的exe就是一个进程。

线程是指进程中的一个执行流程,一个进程中可以运行多个线程。比如java.exe进程中可以运行很多线程。线程总是属于某个进程,进程中的多个线程共享进程的内存空间。

“同时”执行是人的感觉,在线程之间实际上轮换执行。

b、Java中的线程 在Java中,“线程”指两件不同的事情:

a、java.lang.Thread类的一个实例。

b、线程的执行。

使用java.lang.Thread类或者java.lang.Runnable接口编写代码来定义、实例化和启动新线程。

一个Thread类实例只是一个对象,像Java中的任何其他对象一样,具有变量和方法,在堆上完成对象的创建和销毁。

Java中,每个线程都有一个调用栈,即使不在程序中创建任何新的线程,线程也在后台运行着。

一个Java应用总是从main()方法开始运行,mian()方法运行在一个线程内,它被称为主线程。

一旦创建一个新的线程,就产生一个新的调用栈。线程总体分两类:用户线程守护线程

当所有用户线程执行完毕的时候,JVM自动关闭。但是守护线程却独立于JVM,守护线程一般是由操作系统或者用户自己创建的。

二、线程的创建与启动

a、定义线程

1、继承java.lang.Thread类。

此类中有个run()方法,应该注意其用法: public void run() 如果该线程是使用独立的 Runnable 运行对象构造的,则调用该 Runnable 对象的 run 方法;否则,该方法不执行任何操作并返回。  Thread 的子类应该重写该方法。

2、实现java.lang.Runnable接口。

void run() 使用实现接口 Runnable 的对象创建一个线程时,启动该线程将导致在独立执行的线程中调用对象的 run 方法。

方法 run 的常规协定是,它可能执行任何所需的操作。

b、实例化线程

1、如果是继承java.lang.Thread类的线程,则直接new即可。

即使用的时候Thread a=new tThread();

2、如果是实现了java.lang.Runnable接口的类,则用Thread的构造方法:

Thread(Runnable target)
Thread(Runnable target, String name)
Thread(ThreadGroup group, Runnable target)
Thread(ThreadGroup group, Runnable target, String name)
Thread(ThreadGroup group, Runnable target, String name, long stackSize) 

rThread a=new rThread();//此处可以使用各个构造函数
Thread b=new Thread(a);

c、启动线程

在线程的Thread对象上调用start()方法,而不是run()或者别的方法。 在调用start()方法之前:线程处于新状态中,新状态指有一个Thread对象,但还没有一个真正的线程。 在调用start()方法之后,发生了一系列复杂的事情:启动新的执行线程(具有新的调用栈)该线程从新状态转移到可运行状态当该线程获得机会执行时,其目标run()方法将运行

start()方法后,run()方法并没有执行。

注意:对Java来说,run()方法没有任何特别之处。像main()方法一样,它只是新线程知道调用的方法名称(和签名)。因此,在Runnable上或者Thread上调用run方法是合法的,但并不启动新的线程,所以通常不使用

d、基本例子

1、实现Runnable接口的多线程例子

package com.yunhe.thread;
/*** 实现Runable接口的类* */
public class DoSomething implements Runnable {private String name;public DoSomething(String name) {this.name = name;}public void run() {for (int i = 0; i < 5; i++) {for (long k = 0; k < 100000000; k++);System.out.println(name + ": " + i);}}
}

测试类代码:

package com.yunhe.thread;
/*** 实现Runnable的线程的测试类 */public class TestRunnable {public static void main(String[] args) {DoSomething ds1=new DoSomething("tianti");DoSomething ds2=new DoSomething("yunhe");Thread t1=new Thread(ds1);Thread t2=new Thread(ds2);t1.start();t2.start();}}

运行结果:

tianti: 0
yunhe: 0
yunhe: 1
tianti: 1
yunhe: 2
tianti: 2
yunhe: 3
tianti: 3
yunhe: 4
tianti: 4

2、继承Thread实现线程的例子

package com.yunhe.thread;
/*** 继承Thread的线程类* */
public class DoOtherthing extends Thread {public DoOtherthing(String name) {super(name);}@Overridepublic void run() {// TODO Auto-generated method stubsuper.run();for (int i = 0; i < 5; i++) {for (long k = 0; k < 1000000000; k++);System.out.println(this.getName() + ": " + i);}}}

测试类代码:

package com.yunhe.thread;
/*** 继承Thread类* */
public class DoOtherthing extends Thread {public DoOtherthing(String name) {super(name);}@Overridepublic void run() {// TODO Auto-generated method stubsuper.run();for (int i = 0; i < 5; i++) {for (long k = 0; k < 1000000000; k++);System.out.println(this.getName() + ": " + i);}}}

运行结果:

tianti: 0
yunhe: 0
tianti: 1
yunhe: 1
tianti: 2
yunhe: 2
tianti: 3
yunhe: 3
tianti: 4
yunhe: 4

对于上面的多线程程序代码来说,输出的结果是不确定的。

其中for (long k = 0; k < 100000000; k++);是模拟非常耗时的操作,k值上限较小的时候输出是顺序的,较大的时候是不稳定的交叉输出。

e、一些常见的问题

1、线程的名字,一个运行中的线程总是有名字的,名字有两个来源,一个是JVM虚拟机自己给的名字,一个是你自己的定的名字。在没有指定线程名字的情况下,JVM虚拟机总会为线程指定名字,并且主线程的名字总是main,非主线程的名字不确定。

2、线程都可以设置名字,也可以获取线程的名字,连主线程也不例外。

3、获取当前线程的对象的方法是:Thread.currentThread();

4、在上面的代码中,只能保证:每个线程都将启动,每个线程都将运行直到完成。一系列线程以某种顺序启动并不意味着将按该顺序执行。对于任何一组启动的线程来说,调度程序不能保证其执行次序,持续时间也无法保证

5、当线程目标run()方法结束时该线程完成。

6、一旦线程启动,它就永远不能再重新启动。只有当线程是新的线程的时候才可以被启动,并且只能一次。一个可运行的线程(就绪状态)或死线程可以被重新启动。

7、线程的调度是JVM的一部分,在一个CPU的机器上上,实际上一次只能运行一个线程。一次只有一个线程栈执行。JVM线程调度程序决定实际运行哪个处于可运行状态的线程(就绪状态)。

众多可运行线程中的某一个会被选中做为当前线程。可运行线程被选择运行的顺序是没有保障的。

8、尽管通常采用队列形式,但这是没有保障的。队列形式是指当一个线程完成“一轮”时,它移到可运行队列的尾部等待,直到它最终排队到该队列的前端为止,它才能被再次选中。事实上,我们把它称为可运行池而不是一个可运行队列,目的是帮助认识线程运行并不都是以某种有保障的顺序排列来调度线程。

9、尽管我们不能控制线程调度的顺序,但可以通过别的方式来影响线程调度的方式。

转载于:https://www.cnblogs.com/shudonghe/p/3276387.html

java多线程编程--基础篇相关推荐

  1. java并发编程入门_探讨一下!Java并发编程基础篇一

    Java并发编程想必大家都不陌生,它是实现高并发/高流量的基础,今天我们就来一起学习这方面的内容. 什么是线程?什么是进程?他们之间有什么联系? 简单来说,进程就是程序的一次执行过程,它是系统进行资源 ...

  2. 高并发下Java多线程编程基础

    摘要: Java线程同步与异步 线程池 无锁化的实现方案 分布锁的实现方案 分享的目的: 进一步掌握多线程编程和应用的技巧,希望对大家在平时的开发中应对高并发编程有所帮助 Java线程同步与异步 1. ...

  3. java多线程编程基础

    thread和runnable已经out了.取而代之的是callable<V>,它的结果存在future<V>中.后者有get对象可以阻塞并最终获得异步结果.FutureTas ...

  4. java 多线程系列基础篇(二)

    概要 本章,我们学习"常用的实现多线程的2种方式":Thread 和 Runnable. 之所以说是常用的,是因为通过还可以通过java.util.concurrent包中的线程池 ...

  5. Java多线程系列--“基础篇”10之 线程优先级和守护线程

    概要 本章,会对守护线程和线程优先级进行介绍.涉及到的内容包括: 1. 线程优先级的介绍 2. 线程优先级的示例 3. 守护线程的示例 转载请注明出处:http://www.cnblogs.com/s ...

  6. Java多线程系列--“基础篇”09之 interrupt()和线程终止方式

    概要 本章,会对线程的interrupt()中断和终止方式进行介绍.涉及到的内容包括: 1. interrupt()说明 2. 终止线程的方式   2.1 终止处于"阻塞状态"的线 ...

  7. Java多线程编程实战指南+设计模式篇pdf

    下载地址:网盘下载 随着CPU 多核时代的到来,多线程编程在充分利用计算资源.提高软件服务质量方面扮演了越来越重要的角色.而 解决多线程编程中频繁出现的普遍问题可以借鉴设计模式所提供的现成解决方案.然 ...

  8. java多线程编程_阿里P8熬到秃头肝出来的:Java多线程+并发编程核心笔记

    自学Java的时候,多线程和并发这一块可以说是最难掌握的部分了,很多小伙伴表示需要一些易于学习和上手的资料. 所以今天这本「Java并发学习手册.pdf」就是一份集中学习多线程和并发的手册,PDF版, ...

  9. java多线程编程_Java多线程编程实战指南+设计模式篇.pdf

    Java多线程编程实战指南+设计模式篇.pdf 对Java架构技术感兴趣的工程师朋友们可以关注我,转发此文后私信我"Java"获取更多Java编程PDF资料(附送视频精讲) 关注我 ...

最新文章

  1. XenStore: 使用,结构和原理
  2. Primality Test 素数,打表
  3. fantouch os Android 7,Funtouch OS 3.1 with Android 7.1升级计划
  4. Windows10系统安装 .NET Framework 3.5
  5. python使用get函数在字典中加入键_Python使用字典键作为函数名
  6. 相机标定(4) 矫正畸变 undistort()和initUndistortRectifyMap()
  7. C#快速找出磁盘内的所有文件
  8. Spark2.0.2+Zeppelin0.6.2 环境搭建 初探
  9. docker多个容器一起打包_如何实现多个docker容器同时执行一条命令?
  10. 力扣买卖股票系列总结
  11. Git之Reset的三种模式
  12. HDU2046 骨牌铺方格【递推】
  13. PPP协议基础与工作流程
  14. 随机生成大小为100的范围是100-1000的不重复的数组
  15. 在Qt下使用映美精黑白相机:Qt 5.12 + ImagingSource(映美精)+ vs2017 Community + OpenCV 3.3
  16. 修改win10服务器登录密码,玩转Win10密码基础篇:设置修改系统登录密码
  17. 这些百度搜索技巧,你知道吗?
  18. 网易云信服务监控平台实践
  19. 有机酸膜分离之柠檬酸生产应用反渗透技术
  20. Object-Oriented Programming Summary Ⅰ

热门文章

  1. python的应用不是以下哪种_python的实际应用有哪些?
  2. Linux 服务器性能参数指标总结
  3. 防火墙简单组网方案之双机热备
  4. php怎么实现即时聊天,php实现socket即时通讯示例
  5. Kubernetes 时代的安全软件供应链
  6. 台式电脑不拉网线上网_在家里想不拉宽带用无线上网,试试这几招?
  7. Charles之过滤信息
  8. linux设置逻辑卷进不了图形界面,LVM逻辑卷管理器图形界面操作
  9. nacos 本地测试_一文详解 Nacos 高可用特性
  10. python 3 5的值_python3 语言特性5