Joda-Time 学习笔记
一 Jode-Time 介绍
任何企业应用程序都需要处理时间问题。应用程序需要知道当前的时间点和下一个时间点,有时它们还必须计算这两个
时间点之间的路径。使用 JDK 完成这项任务将非常痛苦和繁琐。
既然无法摆脱时间,为何不设法简化时间处理?现在来看看 Joda Time,一个面向 Java™ 平台的易于
使用的开源时间/日期库。正如您在本文中了解的那样,JodaTime轻松化解了处理日期和时间的痛苦和繁琐。
Joda-Time 令时间和日期值变得易于管理、操作和理解。事实上,易于使用是 Joda 的主要设计目标。其他目标包括可扩展性、完整的特性集以及对多种日历系统的支持。
并且 Joda 与 JDK 是百分之百可互操作的,因此您无需替换所有 Java 代码,只需要替换执行日期/时间计算的那部分代码。
Joda-Time提供了一组Java类包用于处理包括ISO8601标准在内的date和time。可以利用它把JDK Date和Calendar类完全替换掉,而且仍然能够提供很好的集成。
为什么要使用 Joda?
考虑创建一个用时间表示的某个随意的时刻 — 比如,2000 年 1 月 1 日 0 时 0 分。
我如何创建一个用时间表示这个瞬间的 JDK 对象?使用 java.util.Date?
事实上这是行不通的,因为自 JDK 1.1 之后的每个 Java 版本的 Javadoc 都声明应当使用 java.util.Calendar。
Date 中不赞成使用的构造函数的数量严重限制了您创建此类对象的途径。
那么 Calendar 又如何呢?我将使用下面的方式创建必需的实例:
- Calendar calendar = Calendar.getInstance();
- calendar.set(2000, Calendar.JANUARY, 1, 0, 0, 0);
使用 Joda,代码应该类似如下所示:
- DateTime dateTime = new DateTime(2000, 1, 1, 0, 0, 0, 0);
这一行简单代码没有太大的区别。但是现在我将使问题稍微复杂化。
假设我希望在这个日期上加上 90 天并输出结果。使用 JDK,我需要使用清单 1 中的代码:
- // 以 JDK 的方式向某一个瞬间加上 90 天并输出结果
- Calendar calendar = Calendar.getInstance();
- calendar.set(2000, Calendar.JANUARY, 1, 0, 0, 0);
- SimpleDateFormat sdf =
- new SimpleDateFormat("E MM/dd/yyyy HH:mm:ss.SSS");
- calendar.add(Calendar.DAY_OF_MONTH, 90);
- System.out.println(sdf.format(calendar.getTime()));
- // 以 Joda 的方式向某一个瞬间加上 90 天并输出结果
- DateTime dateTime = new DateTime(2000, 1, 1, 0, 0, 0, 0);
- System.out.println(dateTime.plusDays(90).toString("E MM/dd/yyyy HH:mm:ss.SSS");
两者之间的差距拉大了(Joda 用了两行代码,JDK 则是 5 行代码)。
现在假设我希望输出这样一个日期:距离 2000.1.1日 45 天之后的某天在下一个月的当前周的最后一天的日期。
坦白地说,我甚至不想使用 Calendar 处理这个问题。
使用 JDK 实在太痛苦了,即使是简单的日期计算,比如上面这个计算。
正是多年前的这样一个时刻,我第一次领略到 JodaTime的强大。使用 Joda,用于计算的代码所示:
- DateTime dateTime = new DateTime(2000, 1, 1, 0, 0, 0, 0);
- System.out.println(dateTime.plusDays(45).plusMonths(1).dayOfWeek()
- .withMaximumValue().toString("E MM/dd/yyyy HH:mm:ss.SSS");
- 输出为:
- Sun 03/19/2000 00:00:00.000
如果您正在寻找一种易于使用的方式替代 JDK 日期处理,那么您真的应该考虑 Joda。
二 创建Joda-Time对象
现在,我将展示在采用该库时会经常遇到的一些 Joda 类,并展示如何创建这些类的实例。
ReadableInstant
Joda 通过 ReadableInstant 类实现了瞬间性这一概念。表示时间上的不可变瞬间的 Joda 类都属于这个类的子类。
(将这个类命名为ReadOnlyInstant 可能更好,我认为这才是设计者需要传达的意思)。
换句话说,ReadableInstant 表示时间上的某一个不可修改的瞬间。
其中的两个子类分别为 DateTime 和 DateMidnight:
DateTime:这是最常用的一个类。它以毫秒级的精度封装时间上的某个瞬间时刻。
DateTime 始终与 DateTimeZone 相关,如果您不指定它的话,它将被默认设置为运行代码的机器所在的时区。
可以使用多种方式构建 DateTime 对象。这个构造函数使用系统时间:
- DateTime dateTime = new DateTime();
如果您创建了一个 DateTime 的实例,并且没有提供 Chronology 或 DateTimeZone,Joda将使用 ISOChronology(默认)和DateTimeZone(来自系统设置)
Joda 可以使您精确地控制创建 DateTime 对象的方式,该对象表示时间上的某个特定的瞬间。
- DateTime dateTime = new DateTime(
- 2000, //year
- 1, // month
- 1, // day
- 0, // hour (midnight is zero)
- 0, // minute
- 0, // second
- 0 // milliseconds
- );
下一个构造函数将指定从 epoch(1970年1月1日 子时 格林威治标准时间) 到某个时刻所经过的毫秒数。
它根据 JDK Date 对象的毫秒值创建一个DateTime 对象,其时间精度用毫秒表示,因为 epoch 与 Joda 是相同的:
- java.util.Date jdkDate = new Date();
- long timeInMillis = jdkDate.getTime();
- DateTime dateTime = new DateTime(timeInMillis);
- 或者Date 对象直接传递给构造函数:
- dateTime = new DateTime(new Date());
- Joda 支持使用许多其他对象作为构造函数的参数,用于创建 DateTime:
- // Use a Calendar
- dateTime = new DateTime(calendar);
- // Use another Joda DateTime
- dateTime = new DateTime(anotherDateTime);
- // Use a String (must be formatted properly)
- String timeString = "2006-01-26T13:30:00-06:00";
- dateTime = new DateTime(timeString);
- timeString = "2006-01-26";
- dateTime = new DateTime(timeString);
注意,如果您准备使用 String(必须经过解析),您必须对其进行精确地格式化。
DateMidnight:这个类封装某个时区(通常为默认时区)在特定年/月/日的午夜时分的时刻。
它基本上类似于 DateTime,不同之处在于时间部分总是为与该对象关联的特定 DateTimeZone 时区的午夜时分。
ReadablePartial
应用程序所需处理的日期问题并不全部都与时间上的某个完整时刻有关,因此您可以处理一个局部时刻。
例如,有时您比较关心年/月/日,或者一天中的时间,甚至是一周中的某天。Joda 设计者使用ReadablePartial 接口捕捉这种表示局部时间的概念,
这是一个不可变的局部时间片段。用于处理这种时间片段的两个有用类分别为 LocalDate 和 LocalTime:
LocalDate:该类封装了一个年/月/日的组合。当地理位置(即时区)变得不重要时,使用它存储日期将非常方便。
例如,某个特定对象的出生日期 可能为 1999 年 4 月 16 日,但是从技术角度来看,
在保存所有业务值的同时不会了解有关此日期的任何其他信息(比如这是一周中的星期几,或者这个人出生地所在的时区)。
在这种情况下,应当使用 LocalDate。
LocalTime:这个类封装一天中的某个时间,当地理位置不重要的情况下,可以使用这个类来只存储一天当中的某个时间。
例如,晚上 11:52 可能是一天当中的一个重要时刻(比如,一个 cron 任务将启动,它将备份文件系统的某个部分),
但是这个时间并没有特定于某一天,因此我不需要了解有关这一时刻的其他信息。
创建对象代码:
- package com.jt.joda;
- import java.util.Date;
- import org.joda.time.DateTime;
- import org.joda.time.LocalDate;
- import org.joda.time.LocalTime;
- import org.junit.Test;
- public class Demo {
- @Test
- public void test1(){
- //方法一:取系统点间
- DateTime dt1 = new DateTime();
- System.out.println(dt1);
- //方法二:通过java.util.Date对象生成
- DateTime dt2 = new DateTime(new Date());
- System.out.println(dt2);
- //方法三:指定年月日点分秒生成(参数依次是:年,月,日,时,分,秒,毫秒)
- DateTime dt3 = new DateTime(2012, 5, 20, 13, 14, 0, 0);
- System.out.println(dt3);
- //方法四:ISO8601形式生成
- DateTime dt4 = new DateTime("2012-05-20");
- System.out.println(dt4);
- DateTime dt5 = new DateTime("2012-05-20T13:14:00");
- System.out.println(dt5);
- //只需要年月日的时候
- LocalDate localDate = new LocalDate(2009, 9, 6);// September 6, 2009
- System.out.println(localDate);
- //只需要时分秒毫秒的时候
- LocalTime localTime = new LocalTime(13, 30, 26, 0);// 1:30:26PM
- System.out.println(localTime);
- }
- /*
- 2015-09-25T17:51:12.900+08:00
- 2015-09-25T17:51:12.977+08:00
- 2012-05-20T13:14:00.000+08:00
- 2012-05-20T00:00:00.000+08:00
- 2012-05-20T13:14:00.000+08:00
- 2009-09-06
- 13:30:26.000
- */
- }
三 与JDK日期对象转换
许多代码都使用了 JDK Date 和 Calendar 类。但是幸亏有 Joda,可以执行任何必要的日期算法,然后再转换回 JDK 类。
这将两者的优点集中到一起。您在本文中看到的所有 Joda 类都可以从 JDK Calendar 或 Date 创建,正如您在 创建 JodaTime对象 中看到的那样。
出于同样的原因,可以从您所见过的任何 Joda 类创建 JDK Calendar 或 Date。
- 1. DateTime dt = new DateTime();
- 2.
- 3. //转换成java.util.Date对象
- 4. Date d1 = new Date(dt.getMillis());
- 5. Date d2 = dt.toDate();
- 6.
- 7. //转换成java.util.Calendar对象
- 8. Calendar c1 = Calendar.getInstance();
- 9. c1.setTimeInMillis(dt.getMillis());
- 10. Calendar c2 = dt.toCalendar(Locale.getDefault());
对于 ReadablePartial 子类,您还需要经过额外一步,如所示:
- 1 Date date = localDate.toDateMidnight().toDate();
要创建 Date 对象,您必须首先将它转换为一个 DateMidnight 对象,然后只需要将 DateMidnight 对象作为 Date。
(当然,产生的 Date 对象将把它自己的时间部分设置为午夜时刻)。
JDK 互操作性被内置到 Joda API 中,因此您无需全部替换自己的接口,如果它们被绑定到 JDK 的话。比
如,您可以使用 Joda 完成复杂的部分,然后使用 JDK 处理接口。
四 日期计算
现在,您已经了解了如何创建一些非常有用的 Joda 类,我将向您展示如何使用它们执行日期计算。
假设在当前的系统日期下,我希望计算上一个月的最后一天。对于这个例子,我并不关心一天中的时间,因为我只需要获得年/月/日,如所示:
- LocalDate now = SystemFactory.getClock().getLocalDate();
- LocalDate lastDayOfPreviousMonth = now.minusMonths(1).dayOfMonth().withMaximumValue();
首先,我从当前月份减去一个月,得到 “上一个月”。
接着,我要求获得 dayOfMonth 的最大值,它使我得到这个月的最后一天。
注意,这些调用被连接到一起(注意 Joda ReadableInstant 子类是不可变的),这样您只需要捕捉调用链中最后一个方法的结果,从而获得整个计算的结果。
您可能对dayOfMonth() 调用感兴趣。这在 Joda 中被称为属性(property)。它相当于 Java对象的属性。
属性是根据所表示的常见结构命名的,并且它被用于访问这个结构,用于完成计算目的。
属性是实现 Joda 计算威力的关键。您目前所见到的所有 4 个 Joda 类都具有这样的属性。一些例子包括:
yearOfCentury
dayOfYear
monthOfYear
dayOfMonth
dayOfWeek
假设您希望获得任何一年中的第 11 月的第一个星期二的日期,而这天必须是在这个月的第一个星期一之后。
- LocalDate now = SystemFactory.getClock().getLocalDate();
- LocalDate electionDate = now.monthOfYear()
- .setCopy(11) // November
- .dayOfMonth() // Access Day Of Month Property
- .withMinimumValue() // Get its minimum value
- .plusDays(6) // Add 6 days
- .dayOfWeek() // Access Day Of Week Property
- .setCopy("Monday") // Set to Monday (it will round down)
- .plusDays(1); // Gives us Tuesday
.setCopy("Monday") 是整个计算的关键。不管中间LocalDate 值是多少,将其 dayOfWeek 属性设置为 Monday 总是能够四舍五入,
这样的话,在每月的开始再加上 6 天就能够让您得到第一个星期一。再加上一天就得到第一个星期二。Joda 使得执行此类计算变得非常容易。
下面是其他一些因为使用 Joda 而变得超级简单的计算:
- 1. DateTime dt = new DateTime();
- 2.
- 3. //昨天
- 4. DateTime yesterday = dt.minusDays(1);
- 5. //明天
- 6. DateTime tomorrow = dt.plusDays(1);
- 7. //1个月前
- 8. DateTime before1month = dt.minusMonths(1);
- 9. //3个月后
- 10. DateTime after3month = dt.plusMonths(3);
- 11. //2年前
- 12. DateTime before2year = dt.minusYears(2);
- 13. //5年后
- 14. DateTime after5year = dt.plusYears(5);
五 格式化时间
使用 JDK 格式化日期以实现打印是完全可以的,但是我始终认为它应该更简单一些。
这是 Joda 设计者进行了改进的另一个特性。要格式化一个 Joda 对象,调用它的 toString() 方法,
并且如果您愿意的话,传递一个标准的 ISO8601或一个 JDK 兼容的控制字符串,以告诉 JDK 如何执行格式化。
不需要创建单独的 SimpleDateFormat 对象
(但是 Joda 的确为那些喜欢自找麻烦的人提供了一个DateTimeFormatter 类)。
调用 Joda 对象的 toString() 方法,仅此而已。
- dateTime.toString(ISODateTimeFormat.basicDateTime());
- dateTime.toString(ISODateTimeFormat.basicDateTimeNoMillis());
- dateTime.toString(ISODateTimeFormat.basicOrdinalDateTime());
- dateTime.toString(ISODateTimeFormat.basicWeekDateTime());
- 20090906T080000.000-0500
- 20090906T080000-0500
- 2009249T080000.000-0500
- 2009W367T080000.000-0500
- DateTime dateTime = DateTime.now();
- dateTime.toString("MM/dd/yyyy hh:mm:ss.SSSa");
- dateTime.toString("dd-MM-yyyy HH:mm:ss");
- dateTime.toString("EEEE dd MMMM, yyyy HH:mm:ssa");
- dateTime.toString("MM/dd/yyyy HH:mm ZZZZ");
- dateTime.toString("MM/dd/yyyy HH:mm Z");
- 09/06/2009 02:30:00.000PM
- 06-Sep-2009 14:30:00
- Sunday 06 September, 2009 14:30:00PM
- 09/06/2009 14:30 America/Chicago
- 09/06/2009 14:30 -0500
结束语
谈到日期处理,Joda 是一种令人惊奇的高效工具。无论您是计算日期、打印日期,或是解析日期,Joda都将是工具箱中的便捷工具。
在本文中,我首先介绍了 Joda,它可以作为 JDK 日期/时间库的替代选择。然后介绍了一些 Joda 概念,以及如何使用 Joda 执行日期计算和格式化。
六 使用代码案例
- 2、获取年月日点分秒
- 1. DateTime dt = new DateTime();
- 2. //年
- 3. int year = dt.getYear();
- 4. //月
- 5. int month = dt.getMonthOfYear();
- 6. //日
- 7. int day = dt.getDayOfMonth();
- 8. //星期
- 9. int week = dt.getDayOfWeek();
- 10. //点
- 11. int hour = dt.getHourOfDay();
- 12. //分
- 13. int min = dt.getMinuteOfHour();
- 14. //秒
- 15. int sec = dt.getSecondOfMinute();
- 16. //毫秒
- 17. int msec = dt.getMillisOfSecond();
- 3 星期的特殊处理
- dt.getDayOfWeek()
- 1. DateTime dt = new DateTime();
- 2.
- 3. //星期
- 4. switch(dt.getDayOfWeek()) {
- 5. case DateTimeConstants.SUNDAY:
- 6. System.out.println("星期日");
- 7. break;
- 8. case DateTimeConstants.MONDAY:
- 9. System.out.println("星期一");
- 10. break;
- 11. case DateTimeConstants.TUESDAY:
- 12. System.out.println("星期二");
- 13. break;
- 14. case DateTimeConstants.WEDNESDAY:
- 15. System.out.println("星期三");
- 16. break;
- 17. case DateTimeConstants.THURSDAY:
- 18. System.out.println("星期四");
- 19. break;
- 20. case DateTimeConstants.FRIDAY:
- 21. System.out.println("星期五");
- 22. break;
- 23. case DateTimeConstants.SATURDAY:
- 24. System.out.println("星期六");
- 25. break;
- 26. }
- 4、与JDK日期对象的转换
- 1. DateTime dt = new DateTime();
- 2.
- 3. //转换成java.util.Date对象
- 4. Date d1 = new Date(dt.getMillis());
- 5. Date d2 = dt.toDate();
- 6.
- 7. //转换成java.util.Calendar对象
- 8. Calendar c1 = Calendar.getInstance();
- 9. c1.setTimeInMillis(dt.getMillis());
- 10. Calendar c2 = dt.toCalendar(Locale.getDefault());
- 5、日期前后推算
- 1. DateTime dt = new DateTime();
- 2.
- 3. //昨天
- 4. DateTime yesterday = dt.minusDays(1);
- 5. //明天
- 6. DateTime tomorrow = dt.plusDays(1);
- 7. //1个月前
- 8. DateTime before1month = dt.minusMonths(1);
- 9. //3个月后
- 10. DateTime after3month = dt.plusMonths(3);
- 11. //2年前
- 12. DateTime before2year = dt.minusYears(2);
- 13. //5年后
- 14. DateTime after5year = dt.plusYears(5);
- 6、取特殊日期
- 1. DateTime dt = new DateTime();
- 2.
- 3. //月末日期
- 4. DateTime lastday = dt.dayOfMonth().withMaximumValue();
- 5.
- 6. //90天后那周的周一
- 7. DateTime firstday = dt.plusDays(90).dayOfWeek().withMinimumValue();
- 7、时区
- 1. //默认设置为日本时间
- 2. DateTimeZone.setDefault(DateTimeZone.forID("Asia/Tokyo"));
- 3. DateTime dt1 = new DateTime();
- 4.
- 5. //伦敦时间
- 6. DateTime dt2 = new DateTime(DateTimeZone.forID("Europe/London"));
- 8、计算区间
- 1. DateTime begin = new DateTime("2012-02-01");
- 2. DateTime end = new DateTime("2012-05-01");
- 3.
- 4. //计算区间毫秒数
- 5. Duration d = new Duration(begin, end);
- 6. long time = d.getMillis();
- 7.
- 8. //计算区间天数
- 9. Period p = new Period(begin, end, PeriodType.days());
- 10. int days = p.getDays();
- 11.
- 12. //计算特定日期是否在该区间内
- 13. Interval i = new Interval(begin, end);
- 14. boolean contained = i.contains(new DateTime("2012-03-01"));
- 9、日期比较
- 1. DateTime d1 = new DateTime("2012-02-01");
- 2. DateTime d2 = new DateTime("2012-05-01");
- 3.
- 4. //和系统时间比
- 5. boolean b1 = d1.isAfterNow();
- 6. boolean b2 = d1.isBeforeNow();
- 7. boolean b3 = d1.isEqualNow();
- 8.
- 9. //和其他日期比
- 10. boolean f1 = d1.isAfter(d2);
- 11. boolean f2 = d1.isBefore(d2);
- 12. boolean f3 = d1.isEqual(d2);
- 10、格式化输出
- 1. DateTime dateTime = new DateTime();
- 2.
- 3. String s1 = dateTime.toString("yyyy/MM/dd hh:mm:ss.SSSa");
- 4. String s2 = dateTime.toString("yyyy-MM-dd HH:mm:ss");
- 5. String s3 = dateTime.toString("EEEE dd MMMM, yyyy HH:mm:ssa");
- 6. String s4 = dateTime.toString("yyyy/MM/dd HH:mm ZZZZ");
- 7. String s5 = dateTime.toString("yyyy/MM/dd HH:mm Z");
案例:
- public static DateTime getNowWeekMonday() {
- DateTime date = DateTime.now();
- int dayOfWeek = date.getDayOfWeek();
- return DateTime.parse(date.minusDays(dayOfWeek - 1).toString("yyyy-MM-dd"));
- }
- private static final String DATE_FORMAT = "yyyy-MM-dd";
- //每周一0点0分0秒触发,处理上上周
- @Scheduled(cron = "0 0 0 ? * MON ")
- public void weeklyRemind() {
- logger.info("CyclePendingReminderTask.weeklyRemind");
- logger.info("周期性待处理提醒任务开始");
- String now = DateTime.now().toString(DATE_FORMAT);
- //往前推2周,上上周周一
- String from = DateTime.parse(now, ISODateTimeFormat.dateElementParser())
- .minusWeeks(2).toString(DATE_FORMAT);
- //上上周周日
- String to = DateTime.parse(from, ISODateTimeFormat.dateElementParser())
- .plusWeeks(1).minusDays(1).toString(DATE_FORMAT);
- //上上周周一0点时间戳
- long fromTime = DateTime.parse(from, ISODateTimeFormat.dateElementParser()).getMillis();
- //上周周一0点时间戳
- long toTime = DateTime.parse(to, ISODateTimeFormat.dateElementParser()).plus(1).getMillis();
- List<String> userIdList = ideaService.getUserIdList();
- for (String userId : userIdList) {
- List<Idea> ideaList = ideaService.findIdeasByCreateAt(userId, fromTime, toTime);
- //有创建想法才会有提醒
- if (ideaList.size() > 0) {
- CyclePendingIdeaReminder reminder = new CyclePendingIdeaReminder();
- reminder.setUserId(userId);
- reminder.setFrom(from);
- reminder.setTo(to);
- reminder.setFinished(false);
- cpiReminderService.save(reminder);
- }
- }
- logger.info("周期性待处理提醒任务完成");
- }
- //每月一号0点0分0秒触发
- //当中再判断当前月份进行季度和年度的处理操作
- @Scheduled(cron = "0 0 0 1 * ? ")
- public void monthlySelectionRemind() {
- logger.info("IdeaSelectionReminderTask monthlySelectionRemind start.");
- DateTime nowTime = DateTime.now();
- int month = nowTime.getMonthOfYear();
- String now = nowTime.toString(DATE_FORMAT);
- //年度处理: 1
- if (month == 1) {
- logger.info("年度精选任务开始");
- String from = DateTime.parse(now, ISODateTimeFormat.dateElementParser())
- .minusYears(1).toString(DATE_FORMAT);
- String to = DateTime.parse(now, ISODateTimeFormat.dateElementParser())
- .minusDays(1).toString(DATE_FORMAT);
- doMonthly(from, to, OriginalityType.year);
- logger.info("年度精选任务完成");
- }
- //季度处理: 3(4) 6(7) 9(10) 12(1)
- if (month == 4 || month == 7 || month == 10 || month == 1) {
- logger.info("季度精选任务开始");
- String from = DateTime.parse(now, ISODateTimeFormat.dateElementParser())
- .minusMonths(3).toString(DATE_FORMAT);
- String to = DateTime.parse(now, ISODateTimeFormat.dateElementParser())
- .minusDays(1).toString(DATE_FORMAT);
- doMonthly(from, to, OriginalityType.quarter);
- logger.info("季度精选任务完成");
- }
- //月份处理
- logger.info("月精选任务开始");
- String from = DateTime.parse(now, ISODateTimeFormat.dateElementParser())
- .minusMonths(1).toString(DATE_FORMAT);
- String to = DateTime.parse(now, ISODateTimeFormat.dateElementParser())
- .minusDays(1).toString(DATE_FORMAT);
- doMonthly(from, to, OriginalityType.month);
- logger.info("月精选任务完成");
- logger.info("IdeaSelectionReminderTask monthlySelectionRemind finish.");
- }
- // 今日凌晨
- Date date = DateTime.parse(DateTime.now().toString("yyyy-MM-dd")).toDate()
- // 今天9点对应的日期
- Date date = DateTime.parse(DateTime.now().toString("yyyy-MM-dd")).hourOfDay().addToCopy(9).toDate();
- // 当前时间加1分钟
- Date date = DateTime.now().minuteOfHour().addToCopy(1)).toDate()
Joda-Time 学习笔记的更多相关文章
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- PHP-自定义模板-学习笔记
1. 开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2. 整体架构图 ...
- PHP-会员登录与注册例子解析-学习笔记
1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...
- 2014年暑假c#学习笔记目录
2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...
- JAVA GUI编程学习笔记目录
2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...
- seaJs学习笔记2 – seaJs组建库的使用
原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...
- CSS学习笔记
CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...
- HTML学习笔记
HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...
- DirectX Graphics Infrastructure(DXGI):最佳范例 学习笔记
今天要学习的这篇文章写的算是比较早的了,大概在DX11时代就写好了,当时龙书11版看得很潦草,并没有注意这篇文章,现在看12,觉得是跳不过去的一篇文章,地址如下: https://msdn.micro ...
- ucos实时操作系统学习笔记——任务间通信(消息)
ucos另一种任务间通信的机制是消息(mbox),个人感觉是它是queue中只有一个信息的特殊情况,从代码中可以很清楚的看到,因为之前有关于queue的学习笔记,所以一并讲一下mbox.为什么有了qu ...
随机推荐
- Android-Java卖票案例-推荐此方式Runnable
上一篇博客 Android-卖票案例static-不推荐此方式,讲解了卖票案例是 private static int ticket = 10;,static静态的这种方式来解决卖票多卖30张的问题, ...
- JavaScript中Ajax的使用
AJAX全称为“Asynchronous javascript and XML”(异步javascript和XML),是指一种创建交互式网页应用的网页开发技术.通过在后台与服务器进行少量数据交换,AJ ...
- 利用backtrace和backtrace_symbols函数打印调用栈信息
在头文件"execinfo.h"中声明了三个函数用于获取当前线程的函数调用堆栈. #include <execinfo.h> int backtrace(void * ...
- 数据库选项--ALTER DATABASE WITH 选项
指定当数据库从一种状态转换到另一种状态时,何时回滚未完成的事务. 如果终止子句被忽略,则当数据库中存在任何锁时,ALTER DATABASE 语句将无限期等待. 只能指定一条终止子句,而且该子句应跟在 ...
- jvm linux 时区设置
# 背景 在接入集团一个平台的时候,发现录制某个接口到测试环境回放,发现接口入参一致,一个start_day 一个end_day,但回放的时候会多调用一次数据库查询,很是奇怪: 查阅业务代码,发现确实 ...
- C#数组的定义,不定长的数组?
首先,在这里我要说明的是,C#中,定义了数组,那么就必须为其指定长度,且他的长度确定,不能够更改.一旦定义一个数组,那么操作系统就在内存中给这个数组指定了一块内存,他是不支持动态分配存储空间的.能够动 ...
- 浏览器对HTTP请求的编码行为
浏览器对请求的URL编码行为 浏览器会对请求的URL中非ASCII码字符进行编码.这里不是指对整个URL进行编码,而是仅仅对非ASCII码字符部分进行编码,详情请看下面的实验记录. 实验一:在URL参 ...
- 在QT中用git做版本管理时遇到的一些问题
1. 安装git sudo apt-get install git 2. 安装gitk sudo apt-get install gitk 要提交代码,点击 工具->git->local ...
- 配置阿里yum源,设置命令
配置阿里yum源 #linux的软件包管理 安装 软件的方式有三种 .源代码编译安装() .下载python3的源代码 .解压缩源代码 .进入源代码目录,开始编译安装 .配置环境变量 .yum方式安装 ...
- “全栈2019”Java多线程第十八章:同步代码块双重判断详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...