- 浏览: 261087 次
- 性别:
- 来自: 武汉
文章分类
最新评论
-
天使建站:
写得不错,可以看这里,和这里的这篇文章一起看,有在线 ...
JQuery 遍历List,数组等 -
zdd001:
666666
request.getParameterMap()使用方法 -
javawangzilong:
66666666
request.getParameterMap()使用方法 -
chaixiaodi:
灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌灌 ...
request.getParameterMap()使用方法 -
ifWhileCaseFor:
...
request.getParameterMap()使用方法
1.计算某一月份的最大天数
注:在使用set方法之前,必须先clear一下,否则很多信息会继承自系统当前时间
2.Calendar和Date的转化
(1) Calendar转化为Date
(2) Date转化为Calendar
3.格式化输出日期时间 (这个用的比较多)
其一
其二
4.计算一年中的第几星期
(1)计算某一天是一年中的第几星期
(2)计算一年中的第几星期是几号
输出:
2006-01-02
5.add()和roll()的用法(不太常用)
(1)add()方法
输出:
2006-08-30
2006-09-03
(2)roll方法
2006-09-29
2006-09-03
可见,roll()方法在本月内循环,一般使用add()方法;
6.计算两个任意时间中间的间隔天数(这个比较常用)
(1)传进Calendar对象
(2)传进Date对象
注意:通过上面的方法可以衍生出求任何时间,如要查出邮箱三周之内收到的邮件(得到当前系统时间-再得到三周前时间)用收件的时间去匹配 最好装化成 long去比较
如:1年前日期(注意毫秒的转换)
7. String 和 Date ,Long 之间相互转换 (最常用)
字符串转化成时间类型(字符串可以是任意类型,只要和SimpleDateFormat中的格式一致即可)
通常我们取时间跨度的时候,会substring出具体时间--long-比较
8. 通过时间求时间
年月周求日期
求是星期几
9. java 和 具体的数据库结合
在开发web应用中,针对不同的数据库日期类型,我们需要在我们的程序中对日期类型做各种不同的转换。若对应数据库数据是oracle的Date类型,即只需要年月日的,可以选择使用java.sql.Date类型,若对应的是MSsqlserver 数据库的DateTime类型,即需要年月日时分秒的,选择java.sql.Timestamp类型
你可以使用dateFormat定义时间日期的格式,转一个字符串即可
1Calendar time=Calendar.getInstance(); 2time.clear(); 3time.set(Calendar.YEAR,year); //year 为 int 4time.set(Calendar.MONTH,i-1);//注意,Calendar对象默认一月为0 5int day=time.getActualMaximum(Calendar.DAY_OF_MONTH);//本月份的天数
注:在使用set方法之前,必须先clear一下,否则很多信息会继承自系统当前时间
2.Calendar和Date的转化
(1) Calendar转化为Date
Calendar cal=Calendar.getInstance(); Date date=cal.getTime();
(2) Date转化为Calendar
Date date=new Date(); Calendar cal=Calendar.getInstance(); cal.setTime(date);
3.格式化输出日期时间 (这个用的比较多)
其一
1Date date=new Date(); 2SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); 3String time=df.format(date); 4System.out.println(time);//2008-10-27 08:52:32
其二
1Calendar c = Calendar.getInstance(); 2System.out.println(c.getTime());//Mon Oct 27 08:51:21 CST 2008 3SimpleDateFormat simpleDateTimeFormat = new SimpleDateFormat(" yyyy-MM-dd HH:mm:ss "); 4c = Calendar.getInstance(Locale.CHINESE); 5System.out.println(simpleDateTimeFormat.format(c.getTime()));// 2008-10-27 08:51:21
4.计算一年中的第几星期
(1)计算某一天是一年中的第几星期
1Calendar cal=Calendar.getInstance(); 2cal.set(Calendar.YEAR, 2006); 3cal.set(Calendar.MONTH, 8); 4cal.set(Calendar.DAY_OF_MONTH, 3); 5int weekno=cal.get(Calendar.WEEK_OF_YEAR);
(2)计算一年中的第几星期是几号
1SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd"); 2Calendar cal=Calendar.getInstance(); 3cal.set(Calendar.YEAR, 2006); 4cal.set(Calendar.WEEK_OF_YEAR, 1); 5cal.set(Calendar.DAY_OF_WEEK, Calendar.MONDAY); 6System.out.println(df.format(cal.getTime()));
输出:
2006-01-02
5.add()和roll()的用法(不太常用)
(1)add()方法
1SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd"); 2Calendar cal=Calendar.getInstance(); 3cal.set(Calendar.YEAR, 2006); 4cal.set(Calendar.MONTH, 8); 5cal.set(Calendar.DAY_OF_MONTH, 3); 6cal.add(Calendar.DATE, -4); 7Date date=cal.getTime(); 8System.out.println(df.format(date)); 9cal.add(Calendar.DATE, 4); 10date=cal.getTime(); 11System.out.println(df.format(date));
输出:
2006-08-30
2006-09-03
(2)roll方法
1cal.set(Calendar.YEAR, 2006); 2cal.set(Calendar.MONTH, 8); 3cal.set(Calendar.DAY_OF_MONTH, 3); 4cal.roll(Calendar.DATE, -4); 5date=cal.getTime(); 6System.out.println(df.format(date)); 7cal.roll(Calendar.DATE, 4); 8date=cal.getTime(); 9System.out.println(df.format(date));输出:
2006-09-29
2006-09-03
可见,roll()方法在本月内循环,一般使用add()方法;
6.计算两个任意时间中间的间隔天数(这个比较常用)
(1)传进Calendar对象
1 public int getIntervalDays(Calendar startday,Calendar endday){ 2 if(startday.after(endday)){ 3 Calendar cal=startday; 4 startday=endday; 5 endday=cal; 6 } 7 long sl=startday.getTimeInMillis(); 8 long el=endday.getTimeInMillis(); 9 10 long ei=el-sl; 11 return (int)(ei/(1000*60*60*24)); 12 } 13
(2)传进Date对象
1 public int getIntervalDays(Date startday,Date endday){ 2 if(startday.after(endday)){ 3 Date cal=startday; 4 startday=endday; 5 endday=cal; 6 } 7 long sl=startday.getTime(); 8 long el=endday.getTime(); 9 long ei=el-sl; 10 return (int)(ei/(1000*60*60*24)); 11 }(3)改进精确计算相隔天数的方法
1 public int getDaysBetween (Calendar d1, Calendar d2) { 2 if (d1.after(d2)) { 3 java.util.Calendar swap = d1; 4 d1 = d2; 5 d2 = swap; 6 } 7 int days = d2.get(Calendar.DAY_OF_YEAR) - d1.get(Calendar.DAY_OF_YEAR); 8 int y2 = d2.get(Calendar.YEAR); 9 if (d1.get(Calendar.YEAR) != y2) { 10 d1 = (Calendar) d1.clone(); 11 do { 12 days += d1.getActualMaximum(Calendar.DAY_OF_YEAR);//得到当年的实际天数 13 d1.add(Calendar.YEAR, 1); 14 } while (d1.get(Calendar.YEAR) != y2); 15 } 16 return days; 17 } 18
注意:通过上面的方法可以衍生出求任何时间,如要查出邮箱三周之内收到的邮件(得到当前系统时间-再得到三周前时间)用收件的时间去匹配 最好装化成 long去比较
如:1年前日期(注意毫秒的转换)
java.util.Date myDate=new java.util.Date(); long myTime=(myDate.getTime()/1000)-60*60*24*365; myDate.setTime(myTime*1000); String mDate=formatter.format(myDate);
7. String 和 Date ,Long 之间相互转换 (最常用)
字符串转化成时间类型(字符串可以是任意类型,只要和SimpleDateFormat中的格式一致即可)
通常我们取时间跨度的时候,会substring出具体时间--long-比较
1java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("M/dd/yyyy hh:mm:ss a",java.util.Locale.US); 2java.util.Date d = sdf.parse("5/13/2003 10:31:37 AM"); 3long dvalue=d.getTime(); 4SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 5String mDateTime1=formatter.format(d);
8. 通过时间求时间
年月周求日期
1SimpleDateFormat formatter2 = new SimpleDateFormat("yyyy-MM F E"); 2java.util.Date date2= formatter2.parse("2003-05 5 星期五"); 3SimpleDateFormat formatter3 = new SimpleDateFormat("yyyy-MM-dd"); 4String mydate2=formatter3.format(date2);
求是星期几
mydate= myFormatter.parse("2001-1-1"); SimpleDateFormat formatter4 = new SimpleDateFormat("E"); String mydate3=formatter4.format(mydate);
9. java 和 具体的数据库结合
在开发web应用中,针对不同的数据库日期类型,我们需要在我们的程序中对日期类型做各种不同的转换。若对应数据库数据是oracle的Date类型,即只需要年月日的,可以选择使用java.sql.Date类型,若对应的是MSsqlserver 数据库的DateTime类型,即需要年月日时分秒的,选择java.sql.Timestamp类型
你可以使用dateFormat定义时间日期的格式,转一个字符串即可
1class Datetest{ 2*method 将字符串类型的日期转换为一个timestamp(时间戳记java.sql.Timestamp) 3*@param dateString 需要转换为timestamp的字符串 4*@return dataTime timestamp 5 6public final static java.sql.Timestamp string2Time(String dateString) 7throws java.text.ParseException { 8DateFormat dateFormat; 9dateFormat = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss.SSS", Locale.ENGLISH);//设定格式 10//dateFormat = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss", Locale.ENGLISH); 11dateFormat.setLenient(false); 12java.util.Date timeDate = dateFormat.parse(dateString);//util类型 13java.sql.Timestamp dateTime = new java.sql.Timestamp(timeDate.getTime());//Timestamp类型,timeDate.getTime()返回一个long型 14return dateTime; 15} 16 17*method 将字符串类型的日期转换为一个Date(java.sql.Date) 18*@param dateString 需要转换为Date的字符串 19*@return dataTime Date 20 21public final static java.sql.Date string2Date(String dateString) 22throws java.lang.Exception { 23DateFormat dateFormat; 24dateFormat = new SimpleDateFormat("yyyy-MM-dd", Locale.ENGLISH); 25dateFormat.setLenient(false); 26java.util.Date timeDate = dateFormat.parse(dateString);//util类型 27java.sql.Date dateTime = new java.sql.Date(timeDate.getTime());//sql类型 28return dateTime; 29} 30 31public static void main(String[] args){ 32Date da = new Date(); 33注意:这个地方da.getTime()得到的是一个long型的值 34System.out.println(da.getTime()); 35 36由日期date转换为timestamp 37 38第一种方法:使用new Timestamp(long) 39Timestamp t = new Timestamp(new Date().getTime()); 40System.out.println(t); 41 42第二种方法:使用Timestamp(int year,int month,int date,int hour,int minute,int second,int nano) 43Timestamp tt = new Timestamp(Calendar.getInstance().get( 44 Calendar.YEAR) - 1900, Calendar.getInstance().get( 45 Calendar.MONTH), Calendar.getInstance().get( 46 Calendar.DATE), Calendar.getInstance().get( 47 Calendar.HOUR), Calendar.getInstance().get( 48 Calendar.MINUTE), Calendar.getInstance().get( 49 Calendar.SECOND), 0); 50System.out.println(tt); 51 52try { 53String sToDate = "2005-8-18";//用于转换成java.sql.Date的字符串 54 String sToTimestamp = "2005-8-18 14:21:12.123";//用于转换成java.sql.Timestamp的字符串 55 Date date1 = string2Date(sToDate); 56 Timestamp date2 = string2Time(sToTimestamp); 57System.out.println("Date:"+date1.toString());//结果显示 58System.out.println("Timestamp:"+date2.toString());//结果显示 59}catch(Exception e) { 60e.printStackTrace(); 61} 62} 63} 64
发表评论
-
耗时计算的部分代码
2012-08-20 06:47 1029package com.happy.sqlite.test; ... -
Java常用方法
2012-08-21 09:33 8251、Java新建线程异步调用示例 new Thread(ne ... -
获取系统运行信息
2012-08-22 18:02 911/** * 获得服务器网卡地址 * * @ ... -
String基本知识
2012-08-23 09:13 9061、replace和replaceAll区别(replaceF ... -
List与数组转换
2012-08-21 09:33 1180//字符数组转List String[] s = {&quo ... -
常用正则表达式收集
2012-03-31 15:51 803更新2012-03-31 1、[ ]{2,}//正则替换多余的 ... -
final,static,nested使用2012-03-30(转载)
2012-03-30 10:07 10281。final 篇 final 做为一 ... -
双重检查加锁
2012-03-28 10:46 1289双重检查加锁机制 并不是每次进入getInstance方法都需 ... -
Java路径2012年3月22日
2012-03-22 23:55 1255Web中获取路径的方法 ServletActionContex ... -
关于interface特征的归纳
2011-08-30 14:58 8621.接口中的成员变量默认都是public、static、fin ... -
解析properties资源文件
2011-08-23 21:06 1094import java.io.FileInputStream; ... -
判断是否为汉字
2011-04-17 21:41 877Pattern pattern = Pattern.compi ...
相关推荐
曾经我不太会日期类的算法,通过学习后总结了一些,有好用的东西是要分享给大家的,希望大家也能学的越来越好。
Java 日期算法大全 Java 中日期类操作算法大全是 Java ...Java 日期算法大全涵盖了日期类的基本操作、日期类的加减、日期类的格式化输出、日期类的计算等多个方面的知识点,为开发者提供了详细的Java日期算法指南。
本文将深入探讨C#和Java这两种广泛使用的编程语言中的日期算法,以及如何利用它们来实现一个万年历系统。 首先,C#中的日期处理主要依赖于`System.DateTime`类。这个类提供了丰富的日期和时间操作方法,如获取年、...
3. **农历日期的加减操作**:类中可能包含了类似 `addMonths(LunarDate lunar, int months)` 和 `subtractDays(LunarDate lunar, int days)` 的方法,允许用户对农历日期进行月份和天数的加减。 4. **农历节日和...
7. **日期加减操作**:`java.time`包中的日期时间类提供了加减操作,如`plusDays()`, `minusMonths()`等,可以方便地对日期进行增加或减少。 8. **日期时间API的线程安全**:`java.util.Date`和`Calendar`不是线程...
3. **日期工具类(DateUtil.java)**:与TimeUtil类似,但更专注于日期的处理,例如日期比较、日期加减、日期转换等。对于需要处理日期计算的场景,如判断日期是否在某个范围内,这类工具类非常方便。 4. **时间工具...
Java中的`java.time`包提供了丰富的API,如`LocalDateTime`, `ZonedDateTime`, `Duration`等,用于处理日期、时间的计算,如获取两个日期之间的差值,或者进行时间的加减操作。 2. **小技巧**:`.java` 文件可能...
在Java编程语言中,日历(Calendar)类是处理...开发者可能需要对Java日期API有深入理解,并能编写复杂的金融计算算法。通过这个项目,可以学习到如何在实际应用中使用Java进行日期操作以及实现一个实用的金融工具。
例如,可以方便地进行日期的加减、日期之间的比较,以及转换为各种格式的字符串。 2. **字符串操作工具类**: - 字符串工具类通常提供字符串的拼接、分割、替换、检查、去除空白字符等操作。比如,可能会有方法...
- 掌握日期处理算法,如计算星期几和日期加减。 - 学习Java编程思想,包括面向对象编程和异常处理。 7. **实验条件**: - 编译器:Jcreator - Java环境:JDK 6.0 - 操作系统:Windows XP SP2 8. **程序结构**...
这个类提供了处理日期和时间的各种方法,包括获取年、月、日、小时等信息,以及进行日期的加减操作。`java.util.Date` 类则代表了具体的日期和时间点。`GregorianCalendar` 是 `Calendar` 的一个具体实现,它遵循...
通过以上分析,我们可以看到Java时间工具类的设计和实现涵盖了Java日期时间API的多个方面,包括日期时间的创建、转换、比较、加减、时区处理以及业务逻辑等。理解并熟练掌握这些知识点,有助于我们在实际开发中更加...
这个大数类计算器小程序可能包含了加减乘除以及其他高级运算,比如取模、乘方等。BigInteger类通过提供各种方法来实现这些操作,如`add()`, `subtract()`, `multiply()`, `divide()`, `mod()` 和 `pow()`。 大数类...
这些类支持复杂的算术运算,如加减、比较和格式化。此外,`Cycle`类允许创建和处理重复的日期时间模式,如每周二或每月最后一个星期五。 **4. 高级日期时间计算** Time4J提供了强大的日期时间计算功能,如闰年、...
- `JAVA1-5-03`提出了复数类的设计,要求实现基本的属性和方法,包括构造函数、getters和setters、toString方法,以及加减运算。 通过这些练习,初学者可以逐步熟悉Java的语法特性,掌握面向对象编程的基本思想,...
4. 使用`add`方法进行日期的加减操作。 5. 修正星期计算的错误,可能是通过重新实现或覆盖`getDayOfWeek()`方法。 `MyCalendar.jar`文件是项目的可执行jar包,包含已编译的代码和必要的资源。用户可以通过运行这个...
2. **日期运算**:包括加减日期、获取星期几、判断是否为闰年等操作。这通常需要对日期对象进行操作,如`Date.addDays(int days)`或使用`java.time`中的`plusDays`, `minusDays`等方法。 3. **用户界面设计**:展示...
开发者可以轻松地进行日期间的加减运算,或者根据指定格式进行日期的字符串与对象之间的转换。 3. **集合工具类(CollectionUtil)**:集合处理是Java开发中的重要环节,CollectionUtil提供了一系列针对List、Set、...
3. **Arith.java**:可能是数学运算的工具类,包括加减乘除、取模、求幂、平均值、最大最小值等数学计算功能,方便在程序中进行数值处理。 4. **DownloadUtil.java**:这个类专门处理文件下载功能,可能包含HTTP或...