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

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计数器的结果非常相似,没有明显的差距,程序正确性不能依赖线程的优先级高低

发布了75 篇原创文章 · 获赞 85 · 访问量 10万+

猜你喜欢

转载自blog.csdn.net/zhangchangbin123/article/details/81074835