获取两个日期之间剩余的天数、小时、分钟、秒
2015-07-17 09:55
337 查看
本帖最后由 wuxiaodony 于 2014-8-28 16:57 编辑
例如活动截止时间是:2015/01/01 10:00:00
然后就利用当前时间对比活动截止时间,获取剩余的时间!
我要的不仅仅是天数,还要获取剩余的小时、分钟、秒,就可以了
哪位大神路过帮帮忙,感激不尽!
兵长6666 发表于 2014-8-28 16:55:22
现在是2004-03-26 13:31:40
过去是:2004-01-02 11:30:24
要获得两个日期差,差的形式为:XX天XX小时XX分XX秒
方法一:
DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
try
{
Date d1 = df.parse("2004-03-26 13:31:40");
Date d2 = df.parse("2004-01-02 11:30:24");
long diff = d1.getTime() - d2.getTime();
long days = diff / (1000 * 60 * 60 * 24);
}
catch (Exception e)
{
}
方法二:
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
java.util.Date now = df.parse("2004-03-26 13:31:40");
java.util.Date date=df.parse("2004-01-02 11:30:24");
long l=now.getTime()-date.getTime();
long day=l/(24*60*60*1000);
long hour=(l/(60*60*1000)-day*24);
long min=((l/(60*1000))-day*24*60-hour*60);
long s=(l/1000-day*24*60*60-hour*60*60-min*60);
System.out.println(""+day+"天"+hour+"小时"+min+"分"+s+"秒");
方法三:
SimpleDateFormat dfs = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
java.util.Date begin=dfs.parse("2004-01-02 11:30:24");
java.util.Date end = dfs.parse("2004-03-26 13:31:40");
long between=(end.getTime()-begin.getTime())/1000;//除以1000是为了转换成秒
long day1=between/(24*3600);
long hour1=between%(24*3600)/3600;
long minute1=between%3600/60;
long second1=between%60/60;
System.out.println(""+day1+"天"+hour1+"小时"+minute1+"分"+second1+"秒");
http://download.csdn.net/category
相关文章推荐
- 社説 20150717 安保法案参院へ 日本の平和確保に重要な前進
- solr4.8 高亮查询和配置
- 1021: 组合数末尾的零
- 搜索专题题解
- javascript性能优化
- 【Android Studio快捷键】之导入相应包声明(import packages)
- 日经社説 20150717 本音の安保論議で理解深める努力を
- iOS开发-Day4-C的复习
- 根据开源项目的源代码生成相应的帮助文档
- VS2012变化的快捷键
- [C#] 谈谈异步编程async await
- Android Studio 使用笔记:给包重命名~~有点水
- 多态性 与 静态绑定
- IList, ICollection ,IEnumerable AND IEnumerator in C#
- SQL 数字、文本相互转换
- CSU 1559
- Windows下安装Django
- 常用结构体
- makefile的VPATH和vpath
- 关于 linux disable irq