java并发基础(一)——线程简介

本文介绍了Java线程的基础概念,包括线程定义、使用多线程的原因及线程优先级的作用。并通过实例展示了如何获取线程信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.1、什么是线程?

操作系统调度的最小单元是线程,也叫轻量级进程,在一个进程里面可以创建多个线程,这些线程都拥有各自的计数器、堆栈、局部变量等属性,能够访问共享变量

一个java程序从main()方法开始执行,执行的只一个main线程

 

package cn.sunline.demo.dem2;

import java.lang.management.ManagementFactory;
import java.lang.management.ThreadInfo;
import java.lang.management.ThreadMXBean;

public class ThreadDemo {
	public static void main(String[] args) {
         //获取java线程管理MXBean
		ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean();
		//不需要获取同步的monitor和synchronizer信息,仅获取线程和线程的堆栈信息
		ThreadInfo[]  threadInfos = threadMXBean.dumpAllThreads(false, false);
		for (ThreadInfo threadInfo : threadInfos) {
			System.out.println("["+threadInfo.getThreadId()+"]"+threadInfo.getThreadName());
		}
	}
}

输出结果

[5]Attach Listener  //jvm 监听通讯
[4]Signal Dispatcher  //分发处理发送给JVM信号的线程
[3]Finalizer   //调用对象finalize方法线程
[2]Reference Handler  //清除Reference 线程
[1]main  //main线程,用户程序入口

1.2、为什么要使用多线程?

1、更多的处理器核心

一个线程一个时刻只能运行在一个处理核心上面,多线程将逻辑分配到多个处理器核心上面,减少程序的处理时间,效率更高

2、更快的响应时间

将数据一致性不强的操作派发给其它线程处理,更快的响应用户请求

3、更好的编程模块

多线程编程提供良好、考究并且一致的编程模型,是开发人员更加专注的解决问题

1.3、线程优先级

操作系统基于采用时分的形式调度运行线程,操作系统会分出一个个时间片,线程会分发到若干时间片,当线程的时间片用完了就会发生线程调度,并等待着下次分配,线程优先级决定线程需要或者分配一些处理器资源的线程属性

在java中通过成员变量priority来控制优先级,范围1-10,在线程构建的时候可以通过setPriority(int)来修改优先级,默认为5,优先级搞的线程分配的时间片数量多于优先级低的线程

优先级1和10的job计数器的结果非常相似,没有明显的差距,程序正确性不能依赖线程的优先级高低

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值