黑马程序员-多线程:停止,守护线程,join方法

------<a href="http://www.itheima.com" target="blank">Java培训、Android培训、iOS培训、.Net培训</a>、期待与您交流! -------

守护线程(后台线程)

Thread中的方法,setDaemon()

当正在执行的线程都是守护线程时,JVM退出。

将线程设定为守护线程,就可以控制该线程依赖于某线程,当某线程结束后,所有守护线程都将结束。

条件:

该方法必须在启动线程前调用。

threadInstance.setDaemon(true);


停止线程

JDK1.5以后,stop()方法已经失效。原因在于该方法会强制停止线程,并且该线程将释放其锁定的所有监视器。如果以前受这些监视器保护的任何对象都处于一种不一致的状态,则损坏的对象将对其他线程可见,这有可能导致任意的行为。

现在的方法为让run方法停止,利用循环体来控制,当循环结束了,该线程也就停止了。

代码如下:

argin-bottom:0pt; text-align:justify; " >该方法必须在启动线程前调用。

threadInstance.setDaemon(true);

class ThreadInterrupt {

	public static void main(String[] args) {
		int n = 0;
		ThreadInterruptDemo demo = new ThreadInterruptDemo();
		Thread t1 = new Thread(demo);
		Thread t2 = new Thread(demo);
		
		t1.start();
		t2.start();
		
		while(true) {
			System.out.println(Thread.currentThread().getName() + "---" + n);
			if(n++ > 20) {
				demo.changeFlag();
				break; //使用break来停止while循环
			}
		}
		
	}
}

class ThreadInterruptDemo implements Runnable {
	private boolean flag = true;
	public void changeFlag() {
		flag = false;
	}
	public void run() {
		while(flag){
			System.out.println(Thread.currentThread().getName());
		}
	}
}

特殊情况:

这种情况下,可以使用interrupt()方法,该方法可以清除当前线程调用Objectwait方法所造成的中断状态。当中断被清除后,就可以做一些中断线程的操作了。

class ThreadInterrupt {
	public static void main(String[] args) {
		int n = 0;
		ThreadInterruptDemo demo = new ThreadInterruptDemo();
		Thread t1 = new Thread(demo);
		Thread t2 = new Thread(demo);
		
		t1.start();
		t2.start();
		
		while(true) {
			System.out.println(Thread.currentThread().getName() + "---" + n);
			if(n++ > 20) {
				t1.interrupt();
				t2.interrupt();
				demo.changeFlag();
				break; //使用break来停止while循环
			}
		}
		
	}
}

class ThreadInterruptDemo implements Runnable {
	private boolean flag = true;
	public void changeFlag() {
		flag = false;
	}
	public synchronized void run() {
		while(flag){
			try {
				wait();
			} catch (InterruptedException e) {
				// 在捕获到中断异常的时候,处理时将其关闭。
				flag = false;
				e.printStackTrace();
			}
			System.out.println(Thread.currentThread().getName());
		}
	}
}

join方法

A线程执行到了B线程的join()方法时,则放弃执行资格,直等到B线程运行结束,A线程才能继续执行。

public class JoinDemo {
	public static void main(String[] args) {
		Join join = new Join();
		Thread t1 = new Thread(join);
		Thread t2 = new Thread(join);
		t1.start();
		try {
			t1.join();
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		t2.start();
		
		for(int i = 0;i < 1000 ;i++) {
			System.out.println(Thread.currentThread().getName() + ".." + i);
		}
	}
}

class Join implements Runnable {
	public void run() {
		for(int i = 0;i < 1000 ;i++) {
			System.out.println(Thread.currentThread().getName() + "======" + i);
		}
	}
}

设定线程执行的优先级

优先级分为1-10,共10个等级。让CPU更多的去执行该线程,但并非是绝对的。

setPriority()

MAX_PRIORITY 10

MIN_PRIORITY 1

NORM_PRIORITY 5


暂停

yield()

暂停当前执行的线程,并执行其他线程。

MAX_PRIORITY 10

MIN_PRIORITY 1

NORM_PRIORITY 5


编程中何时使用多线程

当程序中有多个代码块,或功能需要同时被执行时,就需要执行多线程了。

public class NoNameClass {
	public static void main(String[] args) {
		new Thread(){
			public void run() {
				for(int i = 0;i < 100;i++) {
					System.out.println(Thread.currentThread().getName() + i);
				}
			}
		}.start();
		
		for(int i = 0;i < 100;i++) {
			System.out.println(Thread.currentThread().getName() + i);
		}
		
		Runnable r = new Runnable() {
			public void run() {
				for(int i = 0;i < 100;i++) {
					System.out.println(Thread.currentThread().getName() + i);
				}
			}
		};
		
		Thread t = new Thread(r);
		t.start();
		
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
黑马程序员多线程练习题主要包括两个问题。第一个问题是如何控制四个线程在打印log之前能够同时开始等待1秒钟。一种解决思路是在线程的run方法中调用parseLog方法,并使用Thread.sleep方法让线程等待1秒钟。另一种解决思路是使用线程池,将线程数量固定为4个,并将每个调用parseLog方法的语句封装为一个Runnable对象,然后提交到线程池中。这样可以实现一秒钟打印4行日志,4秒钟打印16条日志的需求。 第二个问题是如何修改代码,使得几个线程调用TestDo.doSome(key, value)方法时,如果传递进去的key相等(equals比较为true),则这几个线程应互斥排队输出结果。一种解决方法是使用synchronized关键字来实现线程的互斥排队输出。通过给TestDo.doSome方法添加synchronized关键字,可以确保同一时间只有一个线程能够执行该方法,从而实现线程的互斥输出。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [黑马程序员——多线程10:多线程相关练习](https://blog.csdn.net/axr1985lazy/article/details/48186039)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值