1 /**
2 * 守护线程daemon['diːmən]
3 * @author Administrator
4 *
5 */
6 public class DaemonDemo {
7 public static void main(String[] args) {
8 MyDaemon dt = new MyDaemon();
9
10 if (dt.thrd.isDaemon()) {
11 System.out.println("dt is a daemon thread.");
12 }
13 System.out.println("Sleeping in main thread.");
14 try{
15 Thread.sleep(10000);
16 }
17 catch(InterruptedException exc){
18 System.out.println("Main thread interrupted.");
19 }
20
21 System.out.println("\nMain thread ending.");
22 }
23 }
24
25 class MyDaemon implements Runnable{
26 Thread thrd;
27
28 public MyDaemon() {
29 thrd = new Thread(this);
30 thrd.setDaemon(true);//守护线程:当用户线程结束时,守护线程也结束。
31 thrd.start();
32 }
33
34 @Override
35 public void run() {
36
37 try {
38 for(;;) {
39 System.out.print(".");
40 Thread.sleep(1000);
41 }
42 } catch (InterruptedException e) {
43 System.out.println("MyDaemon interrupted.");
44 }
45 }
46 }

一个简单的Reminder

 1 import java.util.Calendar;
2 import java.util.GregorianCalendar;
3
4
5 public class ReminderDemo {
6 public static void main(String[] args) {
7 Reminder mt = new Reminder("Call Harry", 2);
8
9 Reminder mt2 = new Reminder("Meet with Bill", new GregorianCalendar(2014,4,14,21,14));
10
11 for(int i = 0; i < 20; i++){
12 try {
13 Thread.sleep(1000);
14 } catch (InterruptedException e) {
15 System.out.println("Main thread interrupted.");
16 }
17 System.out.print(".");
18 }
19 System.out.println("\nMain thread ending.");
20 }
21 }
22 class Reminder implements Runnable {
23
24 Calendar reminderTime;
25
26 String message;
27
28 public Reminder(String msg, int delay) {
29 message = msg;
30 reminderTime = Calendar.getInstance();
31 reminderTime.add(Calendar.SECOND, delay);
32 System.out.printf("Reminder set for %tD %1$tr\n", reminderTime);
33 Thread dThrd = new Thread(this);
34 dThrd.setDaemon(true);
35 dThrd.start();
36 }
37
38 public Reminder(String msg, Calendar cal) {
39 message = msg;
40
41 reminderTime = cal;
42 System.out.printf("Reminder set for %tD %1$tr\n", reminderTime);//变元索引
43 Thread dThrd = new Thread(this);
44 dThrd.setDaemon(true);
45 dThrd.start();
46 }
47 @Override
48 public void run() {
49 try {
50 for(;;){
51 Calendar curTime = Calendar.getInstance();
52 if(curTime.compareTo(reminderTime) >= 0) {
53 System.out.println("\n" + message + "\n");
54 break;
55 }
56 Thread.sleep(1000);
57 }
58 } catch (InterruptedException e) {
59 System.out.println("Reminder interrupted.");
60 }
61 }
62
63 }

多线程编程<四>的更多相关文章

  1. [置顶] 曙光到来,我的新书《Android进阶之光》已出版

    独立博客版本请点击这里 由来 2016年我开始建立了自己的知识体系,所有的文章都是围绕着这个体系来写,随着这个体系的慢慢成长,开始有很多出版社联系我写书,因为比较看好电子工业出版社,就顺理成章的开始了 ...

  2. 《Android进阶之光》--注解与依赖注入框架

    No1: 标准注解: 1)@Override:覆写 2)@Deprecated:过时 3)@SuppressWarnings:取消警告 4)@SafeVarargs:申明使用了可变长度参数的方法 No ...

  3. 《Android进阶之光》--Material Design

    接上篇<Android进阶之光>--Android新特性 No1: 组件: 1)底部工作条-Bottom Sheets 2)卡片-Cards 3)提示框-Dialogs 4)菜单-Menu ...

  4. Android中的多线程编程(一)附源代码

    Android中多线程编程:Handler类.Runnable类.Thread类之概念分析 1.Handler类: Handler是谷歌封装的一种机制:能够用来更新UI以及消息的发送和处理.Handl ...

  5. 《Android进阶之光》--多线程编程

    No1: 实现多线程的3中方法 1)继承Thread,重写run()方法 2)实现Runnable接口,并实现该接口的run()方法 3)实现Callable接口,重写call()方法 public ...

  6. 《Android进阶之光》--网络编程与网络框架

    No1: Volley源码分析: Volley.newRequestQueue-> RequestQueue.start()-> CacheDispatcher.start()->C ...

  7. Android进阶(九)APP编程感想

    从初识Android到现在,在不断做APP(二维码.条形码扫描,彩票购买,火车票余票查询)的过程中,自己学会了很多东西.找时间整理了一下,总结如下: 其中,对于前两个APP,自己都是在他人已完成的基础 ...

  8. Android中的多线程编程

    问题 Android的UI也是线程不安全的,如果要更新应用程序里的UI元素,必须在主线程中进行,否则就会抛异常.比如用一个Button的onClick函数去更新界面上的元素,就会得到一个CalledF ...

  9. 《Android进阶之光》--Android新特性

    Android 5.0新特性 1)全新的Material Design设计风格 2)支持多种设备 3)全新的通知中心设计--按照优先级显示 4)支持64位ART虚拟机 5)多任务视窗Overview ...

  10. Android进阶之光-第1章-Android新特性-读书笔记

    第 1 章 Android 新特性 1.1 Android 5.0 新特性 1.1.1 Android 5.0 主要新特性 1. 全新的 Material Design 新风格 Material De ...

随机推荐

  1. Hive——简介

    Hive--简介 Hive 是基于 Hadoop 构建的一套数据仓库分析系统,它提供了丰富的 SQL 查询方式来分析存储在 Hadoop 分布式文件系统中的数据, 可以将结构化的数据文件映射为一张数据 ...

  2. MapReduce学习总结之java版wordcount实现

    一.代码实现: package rdb.com.hadoop01.mapreduce; import java.io.IOException; import org.apache.hadoop.con ...

  3. ssh保持长连接的方式

    方法有以下三种:1.修改server端的etc/ssh/sshd_configClientAliveInterval 60 #server每隔60秒发送一次请求给client,然后client响应,从 ...

  4. shell脚本(5)-shell变量

    一.变量介绍 将一些数据需要临时存放在内存中,以待后续使用时快速读出. 二.变量分类 1.本地变量: 用户私有变量,只有本用户可以使用,保存在家目录下的.bash_profile..bashrc文件中 ...

  5. powerdesigner连接postgresql数据库生成pdm及word文档

    1.准备软件: powerdesigner165与postgresql的驱动:psqlodbc_11_01_0000 2.安装并破解完成powerdesigner165 参看链接:https://ww ...

  6. 远程访问Jupyter Notebook的两种方式:命令行和配置文件

    远程访问Jupyter Notebook的两种方式:命令行和配置文件 相关配置:Ubuntu 16.04服务器,本地Win10,使用了Xshell,Xftp工具. 相关配置主要分为三步: 服务器上的J ...

  7. 在vue中使用微信jssdk的getLocalImgData怎么让多张图片显示

    在循环里添加了一个异步请求类型的,所以我让他每次执行完毕后再执行下一次操作,其中用到了async 和 await,将异步变为同步去执行. 1 // 图片上传 2 handleImage(typeVal ...

  8. Mybatis-初见

    目录 介绍 示例 搭建环境 创建一个模块 CURD 万能Map 配置解析 环境配置 environments 属性 properties 类型别名 typeAliases 其他配置 映射器 mappe ...

  9. 使用ffmpeg给视频添加跑马灯效果(滚动字幕)

    直接上命令 从左往右滚 ffmpeg -i input.mp4 -vf "drawtext=text=string1 string2 string3 string4 string5 stri ...

  10. MapReduce框架原理-Writable序列化

    序列化和反序列化 序列化就是把内存中的对象,转换成字节序列(或其他数据传输协议)以便于存储(持久化)和网络传输. 反序列化就是将收到字节序列(或其他数据传输协议)或者是硬盘的持久化数据,转换成内存中的 ...