linux时间戳转换为时间_linux时间转换为时间戳

linux时间戳转换为时间_linux时间转换为时间戳/***************************************************************************************************************************************************************************************************uni…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

/*************************************************************************************

**************************************************************************************

************************ unix timestamp to time string [begin] ***********************

**************************************************************************************

***************************************************************************************/

#define UTC_BASE_YEAR 1970

#define MONTH_PER_YEAR 12

#define DAY_PER_YEAR 365

#define SEC_PER_DAY 86400

#define SEC_PER_HOUR 3600

#define SEC_PER_MIN 60

/*每个月的天数*/

const unsigned char g_day_per_mon[MONTH_PER_YEAR] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};/** 功能:

* 判断是否是闰年

* 参数:

* year:需要判断的年份数

*

* 返回值:

* 闰年返回1,否则返回0*/

static unsigned char applib_dt_is_leap_year(unsigned shortyear)

{if ((year % 400) == 0) {return 1;

}else if ((year % 100) == 0) {return 0;

}else if ((year % 4) == 0) {return 1;

}else{return 0;

}

}/** 功能:

* 得到每个月有多少天

* 参数:

* month:需要得到天数的月份数

* year:该月所对应的年份数

*

* 返回值:

* 该月有多少天

**/

static unsigned char applib_dt_last_day_of_mon(unsigned char month, unsigned shortyear)

{if ((month == 0) || (month > 12)) {return g_day_per_mon[1] +applib_dt_is_leap_year(year);

}if (month != 2) {return g_day_per_mon[month – 1];

}else{return g_day_per_mon[1] +applib_dt_is_leap_year(year);

}

}static void change(longts)

{int year = 0;int month = 0;int day = 0;int hour = 0;int minute = 0;int second = 0;//将时间戳值转化成天数。通过天数可以比较方便地算出年、月、日。

int days = ts /SEC_PER_DAY;//这个时间戳值的年。

int yearTmp = 0;int dayTmp = 0;//使用夹逼法计算 days 天中包含的年数。

for (yearTmp = UTC_BASE_YEAR; days > 0; yearTmp++) {

dayTmp= (DAY_PER_YEAR + applib_dt_is_leap_year(yearTmp)); //这一年有多少天?

if (days >= dayTmp) //条件成立,则 yearTmp 即是这个时间戳值所代表的年数。

{

days-=dayTmp;

}else{break;

}

}

year=yearTmp;//这个时间戳值的月

int monthTmp = 0;for (monthTmp = 1; monthTmp < MONTH_PER_YEAR; monthTmp++) {

dayTmp=applib_dt_last_day_of_mon(monthTmp, year);if (days >=dayTmp) {

days-=dayTmp;

}else{break;

}

}

month=monthTmp;

day= days + 1;//转化成秒。

int secs = ts %SEC_PER_DAY;//这个时间戳值的小时数。

hour = secs /SEC_PER_HOUR;//这个时间戳值的分钟数。

secs %=SEC_PER_HOUR;

minute= secs /SEC_PER_MIN;//这个时间戳的秒钟数。

second = secs %SEC_PER_MIN;printf(“%d-%d-%d %d:%d:%d\n\n”, year, month, day, hour, minute, second);

}voidmain()

{

change(1558443421);

}/*************************************************************************************

**************************************************************************************

************************ unix timestamp to time string [ end ] ***********************

**************************************************************************************

***************************************************************************************/

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/189539.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • MONTHS_BETWEEN函数「建议收藏」

    MONTHS_BETWEEN函数「建议收藏」 MONTHS_BETWEEN函数MONTHS_BETWEEN(x,y)用于计算x和y之间有几个月。如果x在日历中比y早,那么MONTHS_BETWEEN()就返回一个负数。注意:在调用MONTHS_BETWEEN函数时,日期的次序非常重要:如果想让结果为正数,稍晚的时间必须出现在前面。下面这个例子显示了2008年5月25日和2008年1月15日之间相差的月数。注意由于

    2022年7月12日
    27
  • form 为什么上传文件enctype现场

    form 为什么上传文件enctype现场

    2022年1月11日
    40
  • dynamin_Dynamite

    dynamin_Dynamite摘自《JEDEC78-3F》在某种应用情况下,为了更好的提高数据总线的信号完整性,我们需要DDR3SDRAM的终端阻抗可以不需要通过MRS命令来改变。这种需求由“动态ODT”特性来支持。

    2025年10月17日
    1
  • svm 算法通俗介绍

    svm 算法通俗介绍http://blog.csdn.net/v_july_v/article/details/7624837作者:July、pluskid;致谢:白石、JerryLead出处:结构之法算法之道blog

    2022年8月1日
    5
  • Vue substring截取字符串报错

    Vue substring截取字符串报错这是我查出来的订单信息对象,当我只需要显示用户电话的前三位和后四位时,就需要对订单进行截取。可是当我这样截取之后,效果是出来了,只是控制台依然报错;原因:因为数据是异步加载的,当数据还没出来的时候,数据是空的,所以会报错解决办法:这是我一开始用来保存查出来的数据对象。但是这样依然会报错。我们只需要把这个对象需要截取的那个属性一开始赋值为空,这样就不会报错了。…

    2022年5月23日
    36
  • 回溯算法之N皇后问题[通俗易懂]

    回溯算法之N皇后问题[通俗易懂]问题描述什么是皇后问题八皇后问题(英文:Eightqueens),是由国际西洋棋棋手马克斯·贝瑟尔于1848年提出的问题,是回溯算法的典型案例。问题表述为:在8×8格的国际象棋上摆放8个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。高斯认为有76种方案。1854年在柏林的象棋杂志上不同的作者发表了40种不同的解,后来有人用图论的方法解出92种结果。如果经过±90度、±180度旋转,和对角线对称变换的摆法看成一类,共有42类。计算机发明后,有多种计算机语

    2022年9月30日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号