多线程基础

#.进程和线程的区别

    1.进程是所有线程的集合,每一个线程是进程中的一条执行路径。

#.多线程的应用场景

    1.下载,数据库连接池。

#.创建线程的方式

    1.继承Thread类,重写run方法

package cn.gobon.Thread;

/**
 * 
* @ClassName: ThreadTest01 
* @Description: 
* @author KimHung Yic
* @date 2019年4月20日 上午10:27:47 
*
 */
public class ThreadTest01 {
	
	public static void main(String[] args) {
		System.out.println("-----------线程执行开始-------------");
		CreateThread thread = new CreateThread();
		System.out.println("-----------线程启动------------");
		thread.start();
		System.out.println("-----------线程创建结束------------");
	}
}


class CreateThread extends Thread{
	@Override
	public void run() {
		for (int i = 0; i < 10; i++) {
			System.out.println("i=" + i);
		}
	}
}
/**输出*************
-----------线程执行开始-------------
-----------线程启动------------
-----------线程创建结束------------
i=0
i=1
i=2
i=3
i=4
i=5
i=6
i=7
i=8
i=9
输出***************/

    2.实现Runnable接口,重写run方法

package cn.gobon.Thread;

/**
 * 
* @ClassName: ThreadTest01 
* @Description: 
* @author KimHung Yic
* @date 2019年4月20日 上午10:29:40 
*
 */
public class ThreadTeset02 {

	public static void main(String[] args) {
		System.out.println("-----------线程执行开始-------------");
		CreateRunnable createThread = new CreateRunnable(); 
		Thread thread = new Thread(createThread);
		System.out.println("-----------线程启动------------");
		thread.start();
		System.out.println("-----------线程创建结束------------");
	}

}

class CreateRunnable implements  Runnable {
	
	@Override
	public void run() {
		for (int i = 0; i < 10; i++) {
			System.out.println("i=" + i);
		}
	}
}
/**输出*************
-----------线程执行开始-------------
-----------线程启动------------
-----------线程创建结束------------
i=0
i=1
i=2
i=3
i=4
i=5
i=6
i=7
i=8
i=9
输出***************/

    3.匿名内部类方式

package cn.gobon.Thread;

/**
 * 
* @ClassName: ThreadTest03 
* @Description: 
* @author KimHung Yic
* @date 2019年4月20日 上午10:29:40 
*
 */
public class ThreadTest03 {

	public static void main(String[] args) {
		System.out.println("-----------线程执行开始-------------");
		Thread thread = new Thread(new Runnable() {
			
			@Override
			public void run() {
				
				for (int i = 0; i < 10; i++) {
					System.out.println("i=" + i);
				}
				
			}
		});
		System.out.println("-----------线程启动------------");
		thread.start();
		
		System.out.println("-----------线程创建结束------------");
	}

}

/**输出*************
-----------线程执行开始-------------
-----------线程启动------------
-----------线程创建结束------------
i=0
i=1
i=2
i=3
i=4
i=5
i=6
i=7
i=8
i=9
输出***************/

    提示:启动线程是start方法,并不是run方法。

# 守护线程

    1.java中有两种线程,一种是用户线程,另一种是守护线程。

        1)用户线程:用户创建的线程,主线程停止,用户线程不受影响。

        2)守护线程:当进程不存在或主线程停止,守护线程也会被停止。

package cn.gobon.Thread;

/**
 * 
* @ClassName: DaemonThread 
* @Description: 
* @author KimHung Yic
* @date 2019年4月20日 上午10:27:47 
*
 */
public class DaemonThread {

	public static void main(String[] args) {
		Thread thread = new Thread(new Runnable() {
			
			@Override
			public void run() {
				while (true) {
					try {
						Thread.sleep(100);
					} catch (Exception e) {
					}
					System.out.println("我是子线程...");
				}
			}
		});
		
		thread.setDaemon(true);
		thread.start();
		for (int i = 0; i < 10; i++) {
			try {
				Thread.sleep(100);
			} catch (Exception e) {

			}
			System.out.println("我是主线程");
		}
		System.out.println("主线程执行完毕!");

	}
}
/**输出*************
我是子线程...
我是主线程
我是主线程
我是子线程...
我是主线程
我是子线程...
我是子线程...
我是主线程
我是子线程...
我是主线程
我是主线程
我是子线程...
我是主线程
我是子线程...
我是子线程...
我是主线程
我是主线程
我是子线程...
我是主线程
我是子线程...
主线程执行完毕!
输出***************/

# 线程状态

    5885d65a2a7873ba9b2e1d69e476d9a0611.jpg

    1.线程从创建、运行到结束有五种状态:新建状态、就绪状态、运行状态、阻塞状态和死亡状态。

        1)新建状态

            当new线程时,还没开始运行,线程处于新建状态。

        2)就绪状态

            当线程执行start方法,处于就绪状态。

        3)运行状态

            真正执行run方法,处于运行状态。

        4)阻塞状态

            调用wait方法,sleep方法,或试图获取锁,而锁处于另一条线程中。

        5)死亡状态

            run方法结束后,发生异常,线程自动死亡,通过isAlive方法判断线程是否存活

        1)新建状态

            当new线程时,还没开始运行,线程处于新建状态。

        2)就绪状态

            当线程执行start方法,处于就绪状态。

        3)运行状态

            真正执行run方法,处于运行状态。

        4)阻塞状态

            调用wait方法,sleep方法,或试图获取锁,而锁处于另一条线程中。

        5)死亡状态

            run方法结束后,发生异常,线程自动死亡,通过isAlive方法判断线程是否存活

# join方法作用

    1.当在主线程中执行join方法,就认为主线程把cpu执行权让给执行join方法的线程。

package cn.gobon.Thread;

/**
 * 
* @ClassName: ThreadTest04 
* @Description: join方法
* @author KimHung Yic
* @date 2019年4月20日 下午1:38:20 
*
 */
public class ThreadTest04 {

	public static void main(String[] args) {
		Thread thread = new Thread(new Runnable() {
			
			@Override
			public void run() {
				for (int i = 0; i < 10; i++) {
					try {
						Thread.sleep(10);
					} catch (Exception e) {

					}
					System.out.println(Thread.currentThread().getName() + "i:" + i);
				}

			}
		});
		
		thread.start();
		try {
			thread.join();
		} catch (InterruptedException e1) {
			e1.printStackTrace();
		}
		for (int i = 0; i < 10; i++) {
			try {
				Thread.sleep(10);
			} catch (Exception e) {

			}
			System.out.println("main" + "i:" + i);
		}

	}
}
/**输出*************
Thread-0i:0
Thread-0i:1
Thread-0i:2
Thread-0i:3
Thread-0i:4
Thread-0i:5
Thread-0i:6
Thread-0i:7
Thread-0i:8
Thread-0i:9
maini:0
maini:1
maini:2
maini:3
maini:4
maini:5
maini:6
maini:7
maini:8
maini:9
输出***************/

#线程优先级

    1.通过setPriority设置线程的优先级,最高为10,默认为5。

package cn.gobon.Thread;

/**
 * 
* @ClassName: ThreaTest05 
* @Description: 线程优先级
* @author KimHung Yic
* @date 2019年4月20日 下午1:38:20 
*
 */
public class ThreadTest05 {

	public static void main(String[] args) {
		PrioritytThread prioritytThread = new PrioritytThread();
		Thread t1 = new Thread(prioritytThread);
		Thread t2 = new Thread(prioritytThread);
		//设置优先级,不一定会执行该线程先。
		t1.setPriority(10);
		t1.start();
		
		t2.start();
	}
	
}

class PrioritytThread implements Runnable{

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

	}
	
}

/**输出*************
Thread[Thread-0,10,main]---i:0
Thread[Thread-1,5,main]---i:0
Thread[Thread-1,5,main]---i:1
Thread[Thread-0,10,main]---i:1
Thread[Thread-1,5,main]---i:2
Thread[Thread-0,10,main]---i:2
Thread[Thread-1,5,main]---i:3
Thread[Thread-0,10,main]---i:3
Thread[Thread-0,10,main]---i:4
Thread[Thread-0,10,main]---i:5
Thread[Thread-1,5,main]---i:4
Thread[Thread-1,5,main]---i:5
Thread[Thread-1,5,main]---i:6
Thread[Thread-1,5,main]---i:7
Thread[Thread-1,5,main]---i:8
Thread[Thread-0,10,main]---i:6
Thread[Thread-0,10,main]---i:7
Thread[Thread-0,10,main]---i:8
Thread[Thread-0,10,main]---i:9
Thread[Thread-1,5,main]---i:9
Thread[Thread-1,5,main]---i:10
Thread[Thread-0,10,main]---i:10
Thread[Thread-0,10,main]---i:11
Thread[Thread-1,5,main]---i:11
Thread[Thread-1,5,main]---i:12
Thread[Thread-0,10,main]---i:12
Thread[Thread-0,10,main]---i:13
Thread[Thread-1,5,main]---i:13
Thread[Thread-0,10,main]---i:14
Thread[Thread-0,10,main]---i:15
Thread[Thread-1,5,main]---i:14
Thread[Thread-0,10,main]---i:16
Thread[Thread-0,10,main]---i:17
Thread[Thread-1,5,main]---i:15
Thread[Thread-0,10,main]---i:18
Thread[Thread-0,10,main]---i:19
Thread[Thread-1,5,main]---i:16
Thread[Thread-1,5,main]---i:17
Thread[Thread-0,10,main]---i:20
Thread[Thread-0,10,main]---i:21
Thread[Thread-1,5,main]---i:18
Thread[Thread-0,10,main]---i:22
Thread[Thread-0,10,main]---i:23
Thread[Thread-0,10,main]---i:24
Thread[Thread-0,10,main]---i:25
Thread[Thread-0,10,main]---i:26
Thread[Thread-1,5,main]---i:19
Thread[Thread-0,10,main]---i:27
Thread[Thread-0,10,main]---i:28
Thread[Thread-1,5,main]---i:20
Thread[Thread-0,10,main]---i:29
Thread[Thread-0,10,main]---i:30
Thread[Thread-1,5,main]---i:21
Thread[Thread-1,5,main]---i:22
Thread[Thread-0,10,main]---i:31
Thread[Thread-0,10,main]---i:32
Thread[Thread-1,5,main]---i:23
Thread[Thread-0,10,main]---i:33
Thread[Thread-1,5,main]---i:24
Thread[Thread-0,10,main]---i:34
Thread[Thread-1,5,main]---i:25
Thread[Thread-1,5,main]---i:26
Thread[Thread-0,10,main]---i:35
Thread[Thread-1,5,main]---i:27
Thread[Thread-0,10,main]---i:36
Thread[Thread-1,5,main]---i:28
Thread[Thread-1,5,main]---i:29
Thread[Thread-1,5,main]---i:30
Thread[Thread-1,5,main]---i:31
Thread[Thread-1,5,main]---i:32
Thread[Thread-0,10,main]---i:37
Thread[Thread-0,10,main]---i:38
Thread[Thread-1,5,main]---i:33
Thread[Thread-0,10,main]---i:39
Thread[Thread-0,10,main]---i:40
Thread[Thread-0,10,main]---i:41
Thread[Thread-0,10,main]---i:42
Thread[Thread-0,10,main]---i:43
Thread[Thread-1,5,main]---i:34
Thread[Thread-0,10,main]---i:44
Thread[Thread-0,10,main]---i:45
Thread[Thread-0,10,main]---i:46
Thread[Thread-0,10,main]---i:47
Thread[Thread-0,10,main]---i:48
Thread[Thread-0,10,main]---i:49
Thread[Thread-1,5,main]---i:35
Thread[Thread-0,10,main]---i:50
Thread[Thread-0,10,main]---i:51
Thread[Thread-1,5,main]---i:36
Thread[Thread-0,10,main]---i:52
Thread[Thread-1,5,main]---i:37
Thread[Thread-1,5,main]---i:38
Thread[Thread-1,5,main]---i:39
Thread[Thread-0,10,main]---i:53
Thread[Thread-1,5,main]---i:40
Thread[Thread-0,10,main]---i:54
Thread[Thread-0,10,main]---i:55
Thread[Thread-0,10,main]---i:56
Thread[Thread-0,10,main]---i:57
Thread[Thread-0,10,main]---i:58
Thread[Thread-0,10,main]---i:59
Thread[Thread-0,10,main]---i:60
Thread[Thread-0,10,main]---i:61
Thread[Thread-0,10,main]---i:62
Thread[Thread-0,10,main]---i:63
Thread[Thread-0,10,main]---i:64
Thread[Thread-0,10,main]---i:65
Thread[Thread-0,10,main]---i:66
Thread[Thread-0,10,main]---i:67
Thread[Thread-0,10,main]---i:68
Thread[Thread-0,10,main]---i:69
Thread[Thread-1,5,main]---i:41
Thread[Thread-0,10,main]---i:70
Thread[Thread-1,5,main]---i:42
Thread[Thread-0,10,main]---i:71
Thread[Thread-1,5,main]---i:43
Thread[Thread-0,10,main]---i:72
Thread[Thread-1,5,main]---i:44
Thread[Thread-0,10,main]---i:73
Thread[Thread-0,10,main]---i:74
Thread[Thread-0,10,main]---i:75
Thread[Thread-1,5,main]---i:45
Thread[Thread-0,10,main]---i:76
Thread[Thread-1,5,main]---i:46
Thread[Thread-1,5,main]---i:47
Thread[Thread-0,10,main]---i:77
Thread[Thread-0,10,main]---i:78
Thread[Thread-0,10,main]---i:79
Thread[Thread-0,10,main]---i:80
Thread[Thread-0,10,main]---i:81
Thread[Thread-0,10,main]---i:82
Thread[Thread-0,10,main]---i:83
Thread[Thread-1,5,main]---i:48
Thread[Thread-1,5,main]---i:49
Thread[Thread-0,10,main]---i:84
Thread[Thread-0,10,main]---i:85
Thread[Thread-1,5,main]---i:50
Thread[Thread-0,10,main]---i:86
Thread[Thread-1,5,main]---i:51
Thread[Thread-1,5,main]---i:52
Thread[Thread-1,5,main]---i:53
Thread[Thread-0,10,main]---i:87
Thread[Thread-1,5,main]---i:54
Thread[Thread-0,10,main]---i:88
Thread[Thread-0,10,main]---i:89
Thread[Thread-0,10,main]---i:90
Thread[Thread-1,5,main]---i:55
Thread[Thread-0,10,main]---i:91
Thread[Thread-0,10,main]---i:92
Thread[Thread-0,10,main]---i:93
Thread[Thread-0,10,main]---i:94
Thread[Thread-0,10,main]---i:95
Thread[Thread-0,10,main]---i:96
Thread[Thread-1,5,main]---i:56
Thread[Thread-0,10,main]---i:97
Thread[Thread-0,10,main]---i:98
Thread[Thread-1,5,main]---i:57
Thread[Thread-0,10,main]---i:99
Thread[Thread-1,5,main]---i:58
Thread[Thread-1,5,main]---i:59
Thread[Thread-1,5,main]---i:60
Thread[Thread-1,5,main]---i:61
Thread[Thread-1,5,main]---i:62
Thread[Thread-1,5,main]---i:63
Thread[Thread-1,5,main]---i:64
Thread[Thread-1,5,main]---i:65
Thread[Thread-1,5,main]---i:66
Thread[Thread-1,5,main]---i:67
Thread[Thread-1,5,main]---i:68
Thread[Thread-1,5,main]---i:69
Thread[Thread-1,5,main]---i:70
Thread[Thread-1,5,main]---i:71
Thread[Thread-1,5,main]---i:72
Thread[Thread-1,5,main]---i:73
Thread[Thread-1,5,main]---i:74
Thread[Thread-1,5,main]---i:75
Thread[Thread-1,5,main]---i:76
Thread[Thread-1,5,main]---i:77
Thread[Thread-1,5,main]---i:78
Thread[Thread-1,5,main]---i:79
Thread[Thread-1,5,main]---i:80
Thread[Thread-1,5,main]---i:81
Thread[Thread-1,5,main]---i:82
Thread[Thread-1,5,main]---i:83
Thread[Thread-1,5,main]---i:84
Thread[Thread-1,5,main]---i:85
Thread[Thread-1,5,main]---i:86
Thread[Thread-1,5,main]---i:87
Thread[Thread-1,5,main]---i:88
Thread[Thread-1,5,main]---i:89
Thread[Thread-1,5,main]---i:90
Thread[Thread-1,5,main]---i:91
Thread[Thread-1,5,main]---i:92
Thread[Thread-1,5,main]---i:93
Thread[Thread-1,5,main]---i:94
Thread[Thread-1,5,main]---i:95
Thread[Thread-1,5,main]---i:96
Thread[Thread-1,5,main]---i:97
Thread[Thread-1,5,main]---i:98
Thread[Thread-1,5,main]---i:99
输出***************/

# yield方法

    1.让其他线程优先执行,可能没有效果。

转载于:https://my.oschina.net/u/3794524/blog/3042581

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值