当前位置:首页 > 学习笔记 > Java教程 > Java教程 多线程

Java教程 多线程

刘广法2022年03月25日 09:13:02Java教程4940
Java教程 多线程-第1张图片-刘广法IT博客

一、Java教程 多线程

1.1 关于Java多线程的描述

进程和线程的区别:

1、一个应用程序至少一个进程,进程是指的完整的应用程序,每个进程拥有自己的内存管理,独立使用自己的数据,可以与其他进程通讯。
2、线程:一个应用程序(一个进程)中,可以有多个线程。公用内存管理,可以共享数据,轻量级,线程和线程之间可以直接进行通讯。

进程和线程用处?

并发程序中。并发,指同时会有很多的指令的请求。

单核cpu不存在真正的并发执行程序。只是切换调度而已。由于切换的较快,用户感觉不到

多核cpu存在真正的并发执行程序。


1.2 关于Java中创建多线程的方式:

1、创建子类:创建Thread的子类,重写run(); 方法,自定义执行逻辑

2、创建实现类:创建 Runnable 接口的实现,给Thread 类构造函数的参数进行实现呢。

一、通过创建 Thread 的子类,实现多线程的实例:

首先创建一个Test2 类继承(extends)Thread 类,并重写父类(Thread类)的run(); 方法,来进行多线程

Test2 类 

/**
 * 多线程 继承Thread类
 * @author Liu_Xiansheng
 */
public class Test2 extends Thread {
	private String name;
	public Test2(String name) {
		this.name = name;
	}
	@Override
	public void run() {
		for (int i = 0; i < 10; i++) {
			System.out.println("我是线程:"+this.name+",我在输出:" + i);
		}
	}
	public static void main(String[] args) {

	Test2 t1 = new Test2("A");
	Test2 t2 = new Test2("B");

	t1.start();
	t2.start();
	}
}

Java控制台的输出结果:

我是线程:B,我在输出:0
我是线程:A,我在输出:0
我是线程:B,我在输出:1
我是线程:A,我在输出:1
我是线程:B,我在输出:2
我是线程:A,我在输出:2
我是线程:B,我在输出:3
我是线程:A,我在输出:3
我是线程:A,我在输出:4
我是线程:A,我在输出:5
我是线程:A,我在输出:6
我是线程:A,我在输出:7
我是线程:B,我在输出:4
我是线程:A,我在输出:8
我是线程:B,我在输出:5
我是线程:A,我在输出:9
我是线程:B,我在输出:6
我是线程:B,我在输出:7
我是线程:B,我在输出:8
我是线程:B,我在输出:9

你会发现 线程A 和 线程B 在同时进行运行,如果运行多次就会发现每次运行的结果都是不一样的,也就是说多线程的程序在同时运行;

二、通过创建实现类,也就是继承(implements)Runnable 类,重写Runnable 接口中的run(); 方法,通过构造函数把对象传给Thread 类

Test3 类:

/**
 * 继承接口Runnable接口,实例化对象,把实例化的对象传给Thread类
 * @author Liu_Xiansheng
 */
public class Test3 implements Runnable {
	private String name;

	public Test3(String name) {
		this.name = name;
	}

	@Override
	public void run() {
		for (int i = 0; i < 10; i++) {
			System.out.println("我是线程:" + this.name + ",我在输出:" + i);
		}
	}

	public static void main(String[] args) {
		Test3 t1 = new Test3("A");
		Test3 t2 = new Test3("B");
		Thread t3 = new Thread(t1);
		Thread t4 = new Thread(t2);
		t3.start();
		t4.start();

	}
}

Java控制台的输出:

我是线程:A,我在输出:0
我是线程:B,我在输出:0
我是线程:B,我在输出:1
我是线程:A,我在输出:1
我是线程:B,我在输出:2
我是线程:A,我在输出:2
我是线程:B,我在输出:3
我是线程:A,我在输出:3
我是线程:B,我在输出:4
我是线程:A,我在输出:4
我是线程:B,我在输出:5
我是线程:A,我在输出:5
我是线程:B,我在输出:6
我是线程:A,我在输出:6
我是线程:B,我在输出:7
我是线程:A,我在输出:7
我是线程:B,我在输出:8
我是线程:B,我在输出:9
我是线程:A,我在输出:8
我是线程:A,我在输出:9

1.3 Thread 和 Runnable 的区别:

实现Runnable接口比继承Thread类所具有的优势:

1、:适合多个相同的程序代码的线程去处理同一个资源

2、:可以避免Java中的单继承的限制

3、:增加程序的健壮性,代码可以被多个线程共享,代码和数据独立

4、:线程池只能放入实现Runable或callable类线程,不能直接放入继承Thread的类

二、在多线程中常用方法/常用的关键字:

2.1 在多线程中常用的方法:

1、sleep(); 

休眠毫秒数,告诉运行到此处的线程,你停留的时间。

2、yield();

告诉系统,建议切换线程,但是切换后,系统有可能会重新切换回来。也就是说线程切换,系统并不是一定会听从建议。

3、join();

指等待线程终止。实现方法:启动线程后直接i但用。

join是Thread类的一个方法,启动线程后直接调用,即join()的作用是:“等待该线程终止”,这里需要理解的就是该线程是指的主线程等待子线程的终止。也就是在子线程调用了join()方法后面的代码,只有等到子线程结束了才能执行。

Thread t = new AThread(); 
t.start(); 
t.join();


2.2在多线程中常用的关键字:

1、volatile 关键字:

可视化,如果在多线程中,其中数值发生改变了,并不是所有的线程都能看到,但是运用关键字volatile 后,数值发生改变的时候同时告诉别的线程,值改变后的结果

2、AtomicLong 关键字:

原子性。保证数值的原子性

三、关于Java中多线程资源共享的问题:

线程可以共享数据,但是会存在数据竞争,数据竞争可能会带来数据的错误(脏数据)。


锁与线程同步:保证线程安全

关于锁与线程同步的相关描述:

线程安全:多个线程在访问共享数据的时候,数据是安全的,如果导致共享的数据出现错误(或异常),那就是不安全的,如果多个线程没有共享数据则不存在线程安全问题。

如果说线程是安全的,则表示多个线程在同时操作本类的对象时,不会出现异常或数据错误。


synchronized 关键字

synchronized是同步锁,重量级锁,是互斥锁,可以保证绝对安全,但代价就是性能损失很大。

synchronized 可以修饰代码块,也可以修饰一个方法,当修饰一个方法的时候,是以this.作为锁。


常用的线程安全的方法:

Collections.synchronizedList:返回一个线程安全的list

Collections.synchronizedSet:返回一个线程安全的Set

Collections.synchronizedMap:返回一个线程安全的Map


如果代码不是原子操作,则都可能会出现数据竞争和脏数据。

四、线程池

创建线程,是比较耗费性能的。创建和销毁的过程是比较耗时的。


小编是:刘广法,转载请注明出处,网站地址:https://liuguangfa.com/

扫描二维码推送至手机访问。

版权声明:本文由刘广法博客发布,如需转载请注明出处。

本文链接:https://liuguangfa.com/java/155.html

分享给朋友:

“Java教程 多线程” 的相关文章

JDK的安装卸载以及环境配置

JDK的安装卸载以及环境配置

一、安装JDK首先应该先下载JDK,下面两个网站都是可以下载:下载地址:https://www.oracle.com/java/technologies/javase-downloads.htmlopenJDK 下载:http://jdk.java.net/下载的的就是下面这样的图标,版本号可能不一...

使用eclipse进行文件的导入和导出

使用eclipse进行文件的导入和导出

该说不说,学会这个项目可以省很多的事情,刘广法可以用这个方法借鉴同学的项目,可以进行参考、借鉴、以及抄作业。一、使用eclipse进行项目的导出:1、使用eclipse进行项目的导出第一步:找到所在的项目工作空间,如果你知道的话,可以直接打开文件进行打包发送给你的好友,如果想要知道项目工作空间如何修...

java教程 第三节:基本数据类型和运算符

一、算术运算符+:加-:减*:乘/:除%:取余例如:a+b、a-b、a*b、a/b、a%b当两个操作数都为整数时,结果必定为整数。当其中一个操作数为小数时,则为小数除。去余数,通常是一对正正整取余数,事实上,对小数和负数一样取余数。小数(浮点数)在计算机中不是精确存在的,并不是精确存在的。二、比较运...

Java教程 第四节:流程控制语句总结

流程控制语句:一、顺序结构顺序结构:按照写代码的顺序 一次执行二、分支结构1、if语句if(条件){     语句块 }2、if...else...语句if(条件){     语句块 }else{  ...

java学习:Java流程控制语句的相关测试题

第一题:将所有包含3的三位数整数相加求和。103 131 133 301类似。public static void main(String[] args) { int n = 100;// 从n开始三位数...

eclipse 修改默认的工作空间以及修改个人工作空间的编码

eclipse 修改默认的工作空间以及修改个人工作空间的编码

一、修改工作空间workspaceFile-->Awitch Workspace-->Other,就打开下面的图,然后选择我标起来的就可以新建工作空间了。二、设置工作空间workspace的编码为UTF-8设置完你所用的工作空间也就是上一步后,需要修改工作空间的编码为UTF-8步骤如下:...

eclipse 如何更换JDK版本 替换自带的JDK版本

eclipse 如何更换JDK版本 替换自带的JDK版本

设置jdk,用安装的JDK替换eclipse自带的JDK(详细步骤)1、Window-->Presferences2、进入后,搜索“java”,找到“Installed JRES”3、删除自带的JDK:选中自带的jdk,然后选择remove。4、添加自己安装的JDK:选中右边的Add,选择St...

Java练习:找出三位数中所有的水仙花的值

找到三位数中所有为水仙花的值1、水仙花:百位数的立方+十位数的地方+个位数的立方等于这个数本身。2、三位数中。具体的步骤:public static void main(String[] args) { int i =&nbs...

用Java实现打印各种图形总结篇(矩形、平行四边形、三角形、菱形)

1、用Java实现打印矩形(长方形、正方形): public static void main(String[] args) { for (int y = 0; y < ...

Java练习:百钱百鸡利用Java进行实现

今有100块钱,需要购买100只鸡,已知鸡的价格是:公鸡5元,母鸡3元,小鸡三只元,问:需要购买多少只公鸡、母鸡、小鸡?Java实现百鸡百钱的方法一: public static void main(String[] args) { for&n...

Java练习:打印出所有3位数的素数

课堂练习:打印出所有3位数的素数。素数:只能被1和其本身整除的数 public static void main(String[] args) { // 打印三位数的素数,素数只能被1和本身整数的数。 for (int...

Java学习 第五节:break和continue关键字

break和continue关键字break:表示中断,退出。退出当前一层循环。一旦break,后面的语句将不会得到执行。continue:中断本次循环,直接进行下一次的循环。continue后面的语句将不会得到执行。...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。