• 多线程基础


    守护线程

     Java有两种线程,一种是用户线程,另一种是守护线程。用户线程是用户自定义创建的线程,主线程停止,用户线程不会停止守护线程进程不存在或主线程停止,守护线程也停止

     setDaemon(true)方法设置为守护线程

     

     1 public class DaemonThread {
     2 
     3     public static void main(String[] args) {
     4         Thread thread = new Thread(new Runnable() {
     5             @Override
     6             public void run() {
     7                 while (true) {
     8                     try {
     9                         Thread.sleep(100);
    10                     } catch (Exception e) {
    11                         // TODO: handle exception
    12                     }
    13                     System.out.println("我是子线程...");
    14                 }
    15             }
    16         });
    17         thread.setDaemon(true);
    18         thread.start();
    19         for (int i = 0; i < 10; i++) {
    20             try {
    21                 Thread.sleep(100);
    22             } catch (Exception e) {
    23 
    24             }
    25             System.out.println("我是主线程");
    26         }
    27         System.out.println("主线程执行完毕!");
    28     }
    29 
    30 }

     

     JOIO()方法的应用

    join作用是让其他线程变为等待,  t1.join();// 让其他线程变为等待,直到当前t1线程执行完毕,才释放。thread.Join把指定的线程加入到当前线程,可以将两个交替执行的线程合并为顺序执行的线程。比如在线程B中调用了线程AJoin()方法,直到线程A执行完毕后,才会继续执

    需求:

    创建一个线程,子线程执行完毕后,主线程才能执行。

    1 class JoinThread implements Runnable {
    2 
    3     public void run() {
    4         for (int i = 0; i < 100; i++) {
    5             System.out.println(Thread.currentThread().getName() + "---i:" + i);
    6         }
    public class JoinThreadDemo {
    
        public static void main(String[] args) {
            JoinThread joinThread = new JoinThread();
            Thread t1 = new Thread(joinThread);
            Thread t2 = new Thread(joinThread);
            t1.start();
            t2.start();
            try {
           //其他线程变为等待状态,等t1线程执行完成之后才能执行join方法。
                t1.join();
            } catch (Exception e) {
    
            }
            for (int i = 0; i < 100; i++) {
                System.out.println("main ---i:" + i);
            }
        }
    
    }

    优先级

    现代操作系统基本采用时分的形式调度运行的线程,线程分配得到的时间片的多少决定了线程使用处理器资源的多少,也对应了线程优先级这个概念。在JAVA线程中,通过一个int priority来控制优先级,范围为1-10,其中10最高,默认值为5。下面是源码(基于1.8)中关于priority的一些量和方法。

    class PrioritytThread implements Runnable {
    
    	public void run() {
    		for (int i = 0; i < 100; i++) {
    			System.out.println(Thread.currentThread().toString() + "---i:" + i);
    		}
    	}
    }
    

      

    public class ThreadDemo4 {
    
    	public static void main(String[] args) {
    		PrioritytThread prioritytThread = new PrioritytThread();
    		Thread t1 = new Thread(prioritytThread);
    		Thread t2 = new Thread(prioritytThread);
    		t1.start();
    		// 注意设置了优先级, 不代表每次都一定会被执行。 只是CPU调度会有限分配
    		t1.setPriority(10);
    		t2.start();
    		
    	}
    
    }
    

      

    Yield方法

    Thread.yield()方法的作用:暂停当前正在执行的线程,并执行其他线程。(可能没有效果)

    yield()让当前正在运行的线程回到可运行状态,以允许具有相同优先级的其他线程获得运行的机会。因此,使用yield()的目的是让具有相同优先级的线程之间能够适当的轮换执行。但是,实际中无法保证yield()达到让步的目的,因为,让步的线程可能被线程调度程序再次选中。

    结论:大多数情况下,yield()将导致线程从运行状态转到可运行状态,但有可能没有效果。

  • 相关阅读:
    nginx通过多级代理获得真实用户IP的方法
    装饰器
    base64文件隐写脚本
    椭圆曲线加密
    mysql创建账号及管理权限
    Linux 中指定启动 tomcat 的 jdk 版本
    Linux 下创建 sftp 用户并限定目录
    linux 服务器脚本采集数据中文无法执行错误
    poi 读取使用 Strict Open XML 保存的 excel 文档
    win7 配置Windows Update 失败,还原更改,无法进入系统
  • 原文地址:https://www.cnblogs.com/wangyangzhao/p/12181021.html
Copyright © 2020-2023  润新知