线程基础

进程

一个静态概念

线程

在一个时间点内 cpu只能执行一个线程,分成多个时间片去分给线程占用,短时间察觉不到,感觉在运行多个线程
真正的多线程:多cpu 多内核 确确实实是多线程
相对于进程是动态的
一个程序里执行的不同路径,main是主线程

java操作线程

  • java线程是通过java.lang.Thread类来实现的
  • VM启动时,会有由主方法所定义的线程
  • 可以通过创建Thread实例来创建
  • 每个线程都是通过某个Thread对象所对应的方法run()来完成其操作的,run()为线程体
  • 通过Thread类的start()方法来启动一个线程

两种方法实现线程

  • f1
public class RunnableTest {
    public static void main(String[] args) {
        //启动线程
        Runner runner = new Runner();
        Thread thread = new Thread(runner);
        thread.start();
        loop();
    }
    public static void loop() {
        for(int i = 0 ;i<10;i++){
            System.out.println("main "+i);
        }
    }
}

class Runner implements Runnable{

    @Override
    public void run() {
        // TODO Auto-generated method stub
        
        for(int i = 0 ;i<10;i++){
            System.out.println("Runner "+i);
        }
    }
    
}
/*
 * 
main 0
main 1
main 2
Runner 1
Runner 2
Runner 3
Runner 4
main 3
Runner 5
Runner 6
main 4
Runner 7
Runner 8
main 5
Runner 9
main 6
main 7
main 8
main 9*/
  • f2
public class ThreadTest {
    public static void main(String[] args) {
        //启动线程
        Runner1 runner1 = new Runner1();
        runner1.start();
        loop();
    }
    public static void loop() {
        for(int i = 0 ;i<10;i++){
            System.out.println("main "+i);
        }
    }
}

class Runner1 extends Thread{

    @Override
    public void run() {
        // TODO Auto-generated method stub
        for(int i = 0 ;i<10;i++){
            System.out.println("Runner1 "+i);
        }
    }
}

sleep、interrupt实验

import java.util.Date;


public class InterrputTest {
    public static void main(String[] args) {
        Runner3 runner3 = new Runner3();
        runner3.start();
        try {
            Thread.sleep(10000);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        runner3.interrupt();
    }
}

class Runner3 extends Thread{

    @Override
    public void run() {
        // TODO Auto-generated method stub
        while(true){
            System.out.println(new Date());
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                System.out.println("kill");
                e.printStackTrace();
                return;
            }
        }
    }
}
Wed Nov 08 21:54:05 CST 2017
Wed Nov 08 21:54:06 CST 2017
Wed Nov 08 21:54:07 CST 2017
Wed Nov 08 21:54:08 CST 2017
Wed Nov 08 21:54:09 CST 2017
Wed Nov 08 21:54:10 CST 2017
Wed Nov 08 21:54:11 CST 2017
Wed Nov 08 21:54:12 CST 2017
Wed Nov 08 21:54:13 CST 2017
Wed Nov 08 21:54:14 CST 2017
kill
java.lang.InterruptedException: sleep interrupted
    at java.lang.Thread.sleep(Native Method)
    at Runner3.run(InterrputTest.java:26)

join实验(合并线程)

import java.util.Date;


public class JoinTest {
    public static void main(String[] args) {
        Runner4 runner4 = new Runner4();
        runner4.start();
        
        try {
            runner4.join();
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        for(int i = 0 ;i < 10;i++){
            System.out.println("main thread: "+new Date());
        }
    }

}

class Runner4 extends Thread {
    public void run(){
        for(int i = 0 ;i < 10;i++){
            System.out.println("runner4 thread: "+new Date());
            try {
                sleep(1000);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
                return;
            }
        }
    }
}
runner4 thread: Wed Nov 08 22:11:51 CST 2017
runner4 thread: Wed Nov 08 22:11:52 CST 2017
runner4 thread: Wed Nov 08 22:11:53 CST 2017
runner4 thread: Wed Nov 08 22:11:54 CST 2017
runner4 thread: Wed Nov 08 22:11:55 CST 2017
runner4 thread: Wed Nov 08 22:11:56 CST 2017
runner4 thread: Wed Nov 08 22:11:57 CST 2017
runner4 thread: Wed Nov 08 22:11:58 CST 2017
runner4 thread: Wed Nov 08 22:11:59 CST 2017
runner4 thread: Wed Nov 08 22:12:00 CST 2017
main thread: Wed Nov 08 22:12:01 CST 2017
main thread: Wed Nov 08 22:12:01 CST 2017
main thread: Wed Nov 08 22:12:01 CST 2017
main thread: Wed Nov 08 22:12:01 CST 2017
main thread: Wed Nov 08 22:12:01 CST 2017
main thread: Wed Nov 08 22:12:01 CST 2017
main thread: Wed Nov 08 22:12:01 CST 2017
main thread: Wed Nov 08 22:12:01 CST 2017
main thread: Wed Nov 08 22:12:01 CST 2017
main thread: Wed Nov 08 22:12:01 CST 2017

yield

让出CPU,给其他线程执行的机会

import java.util.Date;


public class YeildTest {
    public static void main(String[] args) {
        Runner5 first = new Runner5("First thread!");
        Runner5 second = new Runner5("Second thread!");
        first.start();second.start();
        
    }
}

class Runner5 extends Thread{
    Runner5(String name){
        super(name);
    }
    public void run() {
        for(int i = 0 ; i<= 20; i++){
            System.out.println(getName()+" "+i);
            if(i%10==0){
                yield();  //切换线程
            }
        }
    }
}

priority

线程优先级


public class PriorityTest {
    public static void main(String[] args) {
        Thread aThread = new Thread(new Runner6());
        Thread bThread = new Thread(new Runner7());
        aThread.setPriority(Thread.NORM_PRIORITY+2);
        aThread.start();bThread.start();
    }
}

class Runner6 implements Runnable{
    public void run() {
        for(int i = 0 ; i<= 20; i++){
            System.out.println("A" + i);
        }
    }
}

class Runner7 implements Runnable{
    public void run() {
        for(int i = 0 ; i<= 20; i++){
            System.out.println("B" + i);
        }
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 前言 多线程并发编程是Java编程中重要的一块内容,也是面试重点覆盖区域,所以学好多线程并发编程对我们来说极其重要...
    嘟爷MD阅读 12,055评论 21 272
  • 写在前面的话: 这篇博客是我从这里“转载”的,为什么转载两个字加“”呢?因为这绝不是简单的复制粘贴,我花了五六个小...
    SmartSean阅读 10,273评论 12 45
  • 一、线程概念 1. 操作系统中的线程现在的操作系统是多任务操作系统,多线程是实现多任务的一种方式,在操作系统中,每...
    TyiMan阅读 5,920评论 1 35
  • 1 当公司大楼里一天的忙碌终于结束的时候,别人一身疲惫,我却十分轻松,因为下班于他们而言是一天的结束,对我而言却只...
    鹤飞瓯越阅读 4,748评论 4 10
  • 看到这个题目,很多人都会以为我沦陷在封建迷信里了。在这里我想说,你们认为的没有错。缓和一下题目的沉重感。 ...
    瑾萱儿阅读 3,226评论 0 0

友情链接更多精彩内容