优先级的规律性——T1142

2023-10-28 07:59
文章标签 优先级 规律性 t1142

本文主要是介绍优先级的规律性——T1142,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

package 多线程技能1;import com.sun.scenario.effect.impl.sw.sse.SSEBlend_SRC_OUTPeer;
import com.sun.xml.internal.ws.api.model.wsdl.WSDLOutput;
import org.w3c.dom.ls.LSOutput;import java.util.Random;/*** 优先级的规律性*  虽然使用setPriority()方法可以设置线程的优先级,但还没有看到设置优先级所带来的效果**  从运行结果来看,线程优先级高的总是大部分先执行完,但不代表高优先级的线程全部执行完。*  另外,并不是MyThread1线程被main线程调用就先执行完,出现这种结果的是因为MyThread1*  优先级是最高级别10.当线程优先级的等级差距很大时,谁先执行完和代码的调用顺序无关。**  从Run2的结果来看,大部分MyThread2先执行完,这就验证了线程的优先级与代码的调用顺序*  无关,出现这种结果的原因是因为MyThread2的优先级最高,说明线程的优先级具有一定的规律*  性,即CPU尽量将执行资源让给优先级较高的线程。**/
class MyThreadT1142 extends Thread{@Overridepublic void run() {long begTime=System.currentTimeMillis();long addResult=0;for (int j=0;j<10;j++){for (int i=0;i<50000;i++){Random random=new Random();random.nextInt();addResult=addResult+1;}}long endTime=System.currentTimeMillis();System.out.println("*****thread 1 use time="+(endTime-begTime));}
}
class MyThread2T1142 extends Thread{@Overridepublic void run() {long beginTime =System.currentTimeMillis();long addResult =0;for (int j=0;j<10;++j){for (int i=0;i<50000;++i){Random random=new Random();random.nextInt();addResult=addResult+i;}}long endTime =System.currentTimeMillis();System.out.println("-----Thread 2 use time="+(endTime-beginTime));}
}/*** 运行*/
class RunT1142{public RunT1142(){int h=5;for (int i=0;i<h;++i){MyThreadT1142 threadT1142=new MyThreadT1142();threadT1142.setPriority(10);threadT1142.start();MyThread2T1142 myThread2T1142=new MyThread2T1142();myThread2T1142.setPriority(1);myThread2T1142.start();}}
}
class Run2T1142{public Run2T1142(){int N=5;for (int i=0;i<N;++i){MyThreadT1142 myThreadT1142=new MyThreadT1142();myThreadT1142.setPriority(1);myThreadT1142.start();MyThread2T1142 myThread2T1142=new MyThread2T1142();myThread2T1142.setPriority(10);myThread2T1142.start();}}
}
public class T1142 {public static void main(String[] args) {// RunT1142 runT1142=new RunT1142();System.out.println("---------------------");Run2T1142 run2T1142=new Run2T1142();}
}

在这里插入图片描述

这篇关于优先级的规律性——T1142的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/291829

相关文章

web群集--nginx配置文件location匹配符的优先级顺序详解及验证

文章目录 前言优先级顺序优先级顺序(详解)1. 精确匹配(Exact Match)2. 正则表达式匹配(Regex Match)3. 前缀匹配(Prefix Match) 匹配规则的综合应用验证优先级 前言 location的作用 在 NGINX 中,location 指令用于定义如何处理特定的请求 URI。由于网站往往需要不同的处理方式来适应各种请求,NGINX 提供了多种匹

【Linux】探索进程优先级的奥秘,解锁进程的调度与切换

目录 进程优先级: 是什么? 为什么存在进程优先级的概念呢? Linux为什么调整优先级是要受限制的? PRI vs NICE Linux的调度与切换 概念准备: 那我们到底怎样完成进程的调度和切换呢? 区分:寄存器VS寄存器的内容 Linux实现进程调度的算法,需要考虑优先级,考虑进程饥饿问题,考虑效率问题。 解决优先级问题: 解决进程饥饿问题: 解决效率的问题:

【MATLAB】运算符及其优先级

在MATLAB语言中,运算符可以灵活组合以构建更复杂的运算表达式。需要注意的是,与其他高级编程语言类似,MATLAB中的运算符也有优先级。掌握运算优先级有助于我们正确地执行复杂的计算。以下是按照从高到低顺序排列的MATLAB运算符及其优先级列表。 括号 ()。数组的转秩 ( .’ ),数组幂 ( .^ ) ,复转秩 ( ’ ),矩阵幂 ( ^ )。代数正 ( + ),代数负 ( - ),逻辑非

【Java编程的逻辑】堆与优先级队列PriorityQueue

完全二叉树 & 满二叉树 & 堆 基本概念 满二叉树是指除了最后一层外,每个节点都有两个孩子,而最后一层都是叶子节点,都没有孩子。 满二叉树一定是完全二叉树,但完全二叉树不要求最后一层是满的,但如果不满,则要求所有节点必须集中在最左边,从左到右是连续的,中间不能有空的。 特点 在完全二叉树中,可以给每个节点一个编号,编号从1开始连续递增,从上到下,从左到右 完全二叉树有一

C++---由优先级队列认识仿函数

文章目录 一、优先级队列是什么? 二、如何使用优先级队列 1、优先级队列容器用法 2、为什么容器本身无序? 三、什么是仿函数? 1. 什么是仿函数? 2. 仿函数的优势 四、仿函数如何使用? 1、重载operator()函数 2、运用第三个参数模板 3、大小堆切换  大堆测试代码: 小堆测试代码: 4、头文件总代码  五、什么是容器适配器? 前言   本文主要介绍了优先级队列是什

「OC」剪不断,理还乱——UIResponder、UIGestureRecognizer、UIControl的响应优先级探究

「OC」剪不断,理还乱——UIResponder、UIGestureRecognizer、UIControl的响应优先级探究 文章目录 「OC」剪不断,理还乱——UIResponder、UIGestureRecognizer、UIControl的响应优先级探究前言介绍UIResponderUIGestureRecognizerUIControl 正文UIGestureRecognizer和

C-运算符优先级一个小例子

代码 比如有下面一段代码: #include <stdio.h>int main() {int a = 0x02;int b = 0x20;int ret = 0;const int MASK = 0x02;ret = a & MASK != MASK;printf("ret = %d\n", ret);ret = b & MASK != MASK;printf("ret = %d\n",

Python全网最全基础课程笔记(三)——所有运算符+运算符优先级

本专栏系列为Pythong基础系列,每天都会更新新的内容,搜罗全网资源以及自己在学习和工作过程中的一些总结,可以说是非常详细和全面。 以至于为什么要写的这么详细:自己也是学过Python的,很多新手只是简单的过一篇语法,其实对于一个知识点的底层逻辑和其他使用方法以及参数详情根本不是很了解,这就导致学完很容易忘记,而且在实战过程中也是半知半解,所以自己就尽量写的详细些,让需要的人能更了解P

09 C语言实现优先级队列

//优先级队列是在链式存储的队列中修改了入队操作的代码#include "stdio.h"#include "stdlib.h"typedef int ElemType;typedef struct node {ElemType data;struct node *next;} linknode_t;typedef struct {linknode_t *front;linknode_t

操作符的优先级和结合性

优先级 优先级指的是,如果一个表达式包含多个运算符,那个运算符应该优先运行。各种运算符的优先级是各不相同的。 1 1+2*3; 上面示例中,表达式1+2*3里面既有加法运算符(+),又有乘法运算符(*)。由于乘法运算符的优先级高于加法运算符,所以会先计算2*3,而不是1+2。 结合性 如果两个运算符优先级相同,就要看结合性了,根据运算符是左结合,还是右结合决定执行顺序。大部分运算符