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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • java swing 多层_java swing布局嵌套[通俗易懂]

    java swing 多层_java swing布局嵌套[通俗易懂]小菜一枚,刚接触Java,想写个注册界面,但却遇到一个奇怪问题:代码如下:publicvoidframe(){this.frame=newJFrame(“用户注册”);//窗体基本属性this.frame.setSize(600,400);this.frame.setLocationRelativeTo(null);this.frame.setVisible(true);this.fr…

    2025年6月14日
    2
  • java——异常

    java——异常

    2021年9月29日
    43
  • Idea激活码最新教程2019.3.2版本,永久有效激活码,亲测可用,记得收藏

    Idea激活码最新教程2019.3.2版本,永久有效激活码,亲测可用,记得收藏Idea 激活码教程永久有效 2019 3 2 激活码教程 Windows 版永久激活 持续更新 Idea 激活码 2019 3 2 成功激活

    2025年5月24日
    5
  • Django(21)migrate报错的解决方案

    Django(21)migrate报错的解决方案前言在讲解如何解决migrate报错原因前,我们先要了解migrate做了什么事情,migrate:将新生成的迁移脚本。映射到数据库中。创建新的表或者修改表的结构。问题1:migrate怎么判断哪

    2022年7月30日
    4
  • linux lefse分析,LEfSe分析,你真的懂了么

    linux lefse分析,LEfSe分析,你真的懂了么在微生物多样性分析中,LEfSe分析自从”出生“就倍受青睐,今天小昌宝宝就跟大家唠唠这个高频出镜的LEfSe分析,从LEfSe的定义、结果、原理、涉及到的检验四个方面进行解释。一LEfSe的定义LEfSe分析即LDAEffectSize分析,是一种用于发现和解释高维度数据生物标识(基因、通路和分类单元等)的分析工具,可以进行两个或多个分组的比较,它强调统计意义和生物相关性,能够在组与组之间寻…

    2022年6月13日
    81
  • 7-10 公路村村通(并查集kruskal)

    7-10 公路村村通(并查集kruskal)最小生成树题目链接现有村落间道路的统计数据表中,列出了有可能建设成标准公路的若干条道路的成本,求使每个村落都有公路连通所需要的最低成本。输入格式:输入数据包括城镇数目正整数N(≤1000)和候选道路数目M(≤3N);随后的M行对应M条道路,每行给出3个正整数,分别是该条道路直接连通的两个城镇的编号以及该道路改建的预算成本。为简单起见,城镇从1到N编号。输出格式:输出村村通需要的最低成本。如果输入数据不足以保证畅通,则输出−1,表示需要建设更多公路。输入样例:6 151 2 51 3 3

    2022年8月8日
    6

发表回复

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

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