当前位置: 首页 > news >正文

时区设置函数【man 3 tzset】

1. NAME(名)

tzset, tzname, timezone, daylight - 初始化时间转换信息

2. SYNOPSIS(概要)

#include <time.h>void tzset(void);extern char *tzname[2];
extern long timezone;
extern int daylight;

glibc的功能测试宏要求(请参阅feature_test_macros(7)):

tzset(): _POSIX_C_SOURCE >= 1 || _XOPEN_SOURCE || _POSIX_SOURCE
tzname: _POSIX_C_SOURCE >= 1 || _XOPEN_SOURCE || _POSIX_SOURCE
timezone: _SVID_SOURCE || _XOPEN_SOURCE
daylight: _SVID_SOURCE || _XOPEN_SOURCE

3. DESCRIPTION(函数描述)

tzset()从TZ环境变量中取出相应字段初始化全局变量tznametzset()会被时区相关的时间转换函数自动调用。在类System-V系统中,tzset()还将设置全局变量timezone(UTC以西的秒数)和daylight(如果该时区没有任何夏令时规则,则设置为0;如果存在夏令时规则,则设置为非0。)

如果未设置TZ环境变量,则使用系统时区。通过将tzfile(5)格式的文件复制或链接到/etc/localtime来配置系统时区。这些文件的时区数据库可能位于系统时区目录中(请参阅下面的FILES小节)。如果TZ变量确实出现在环境中,但其值为空,或者其值无法使用下面指定的任何格式进行解析,则使用协调世界时(UTC),即UTC+0。

环境变量TZ的值有两种格式。第一种格式使用直接表示时区的字符串:

std offset[dst[offset][,start[/time],end[/time]]]

① 要注意上述格式中没有空格,std和其后offset之间的空格只是为了方便读者阅读而被鄙人故意加上的。
② std字符串指定时区的缩写,并且必须是三个或三个以上的字母字符,可随意起名。当包含在小于和大于(>)号之间时,字符集将扩展为包括加号(+)、减号(-)和数字。
③ offset字符串紧跟在std之后,指定要添加到本地时间以获得协调世界时(UTC)的时间值。如果当地时区位于本初子午线的西面,则偏移量为正,如果位于东面,则偏移为负。小时必须介于0 - 24之间,分钟和秒必须介于00 - 59之间:[+|-]hh[:mm[:ss]]
④ dst[offset]指定夏令时时区名称和偏移量,格式和std offset无异。如果dst存在而offset缺省,则会默认比标准时间快1小时。
⑤ start字段指定夏令时生效日期,end字段指定恢复到标准时间的日期。这些字段可能具有以下格式:

  • Jn:J为指示符,n的取1 - 365的儒略日(Julian day),不考虑闰年(Leap year),闰日(Leap day,即2月29日)不计算在内。2月28日是一年中的第59天,3月1日总是一年内的第60天,这种格式无法表示2月29日。
  • n:n取0 - 365的儒略日,2月29日会在闰年计数。全网发问:“好兄弟,请教个问题,n表示0 - 365的儒略日时,闰年的2月28 n=? 非闰年的2月28 n=?”
  • Mm.w.d:M为指示符,m月(1<=m<=12)第w周(1<=w<=5)的第d天(0<=d<=6)。d=0是周日,d=1是周一,d=6是周六。

⑥ /time字段指定当前时间对夏时制的生效或结束时间。“/”是日期和时间的分隔指示符,time格式为/hh:mm:ss。如果缺省,则默认值为02:00:00,凌晨2点整。

举个例子就明白了:
TZ="NZST-12:00:00NZDT-13:00:00,M10.1.0/03:00:00,M3.3.0/03:00:00"

  • NZST 表示新西兰标准时间。
  • -12:00:00 表示比UTC早12小时。
  • NZDT 表示新西兰夏时制时间。
  • -13:00:00 表示夏时制时间比UTC早13小时(即比标准时间快1小时)。
  • M10.1.0/03:00:00 表示夏时制从10月第1个星期日凌晨3点开始。(不奇怪,新西兰是南半球国家)
  • M3.3.0/03:00:00 表示夏时制到3月第三个星期日凌晨3点结束。

第二种设置环境变量TZ的格式:从指定文件中读取时区信息

:[filespec]

指定获取时区的文件,A:filespec指向了一个tzfile(5)格式的文件。如果省略了filespec或filespec无法解析则使用协调世界时(UTC+0)。B:如果filespec路径不是以’/’开头(绝对路径),则在系统时区目录(/usr/share/zoneinfo/)下查找对应文件。如果冒号被省略,则A、B都将被系统尝试。
举个例子就明白了:
TZ=":Pacific/Auckland"(太平洋/奥克兰,新西兰第一大城市,风帆之都)

  • 指定在系统时区数据库目录(/usr/share/zoneinfo/)下查找Pacific/Auckland文件,作为获取时区信息文件。

4. ENVIRONMENT (相关环境变量)

TZ:如果设置了此变量,则其值优先于系统配置的时区(即/etc/localtime)。
TZDIR:如果设置了此变量,则其值优先于系统配置的时区数据库目录路径(即/usr/share/zoneinfo/)。

5. FILES(文件)

  • /etc/localtime:系统时区文件,一般链接到某个具体的tzfile(5)格式时区文件。符合特定语法的文本文件经zic编译生成tzfile(5)格式的时区信息文件。
  • /usr/share/zoneinfo/:系统时区数据库目录。
  • /usr/share/zoneinfo/posixrules:当TZ变量包含DST时区,但未规定开始和结束时间时,则使用该文件规则规定DST的开始和结束时间。

以上是当前的标准文件路径,但是在编译glibc(tzfile.h)时可以配置它们。

6. CONFORMING TO(符合的规范)

POSIX.1-2001   POSIX.1-2008   SVr4   4.3BSD

7. NOTES(注意事项)

4.3BSD有一个函数char *timezone(zone, dst),返回与第一个参数(UTC以西的分钟数)相对应的时区名称。如果第二个参数为0,则使用标准名称,否则使用夏令时版本。

8. SEE ALSO(另请参阅)

date(1)   gettimeofday(2)   time(2)   ctime(2)   getenv(3)   tzfile(5)

9. COLOPHON(书籍的末页,出版社名称)

此页面是Linux man-pages项目4.04版本的一部分。项目描述、bug报告以及此页面的最新版本,可访问http://www.kernel.org/doc/man-pages/.

相关文章:

  • ✅生产问题之Emoji表情如何操作存储,MySQL是否支持
  • [C++] 从零实现一个ping服务
  • 中国平安:福布斯2024年全球企业2000强第29位 位列中国保险企业第1位
  • 垂直领域大模型微调最全指南
  • 无需配置MySQL,Navicat也有在线版了?
  • AcWing 477:神经网络 ← 拓扑排序+链式前向星
  • 从入门到精通:一步步打造稳定可靠的API服务
  • 学校还是专业?这些都不重要
  • PostgreSQL导出导出压缩文件大小
  • 活动集锦 | 英码科技积极参与行业盛会,AI赋能城市数字化转型
  • 个人云服务器已经被安全合规等卡脖子 建议不要买 买了必定后悔 安全是个大问题 没有能力维护
  • 2024 6.10~6.16 周报
  • NLP实战入门——文本分类任务(TextRNN,TextCNN,TextRNN_Att,TextRCNN,FastText,DPCNN,BERT,ERNIE)
  • 如何使用任意浏览器远程访问本地搭建的Jellyfin影音平台
  • java-内部类 2
  • #Java异常处理
  • [译]前端离线指南(上)
  • 《微软的软件测试之道》成书始末、出版宣告、补充致谢名单及相关信息
  • 【JavaScript】通过闭包创建具有私有属性的实例对象
  • Centos6.8 使用rpm安装mysql5.7
  • Dubbo 整合 Pinpoint 做分布式服务请求跟踪
  • export和import的用法总结
  • Fabric架构演变之路
  • java多线程
  • js
  • JS+CSS实现数字滚动
  • Just for fun——迅速写完快速排序
  • Python打包系统简单入门
  • REST架构的思考
  • SegmentFault 技术周刊 Vol.27 - Git 学习宝典:程序员走江湖必备
  • vue学习系列(二)vue-cli
  • 从零开始在ubuntu上搭建node开发环境
  • 使用API自动生成工具优化前端工作流
  • 要让cordova项目适配iphoneX + ios11.4,总共要几步?三步
  • 自动记录MySQL慢查询快照脚本
  • [地铁译]使用SSD缓存应用数据——Moneta项目: 低成本优化的下一代EVCache ...
  • 仓管云——企业云erp功能有哪些?
  • ​马来语翻译中文去哪比较好?
  • !$boo在php中什么意思,php前戏
  • # include “ “ 和 # include < >两者的区别
  • # 飞书APP集成平台-数字化落地
  • #includecmath
  • #ubuntu# #git# repository git config --global --add safe.directory
  • (1)svelte 教程:hello world
  • (cljs/run-at (JSVM. :browser) 搭建刚好可用的开发环境!)
  • (JS基础)String 类型
  • (MATLAB)第五章-矩阵运算
  • (第27天)Oracle 数据泵转换分区表
  • (附源码)spring boot网络空间安全实验教学示范中心网站 毕业设计 111454
  • (接上一篇)前端弄一个变量实现点击次数在前端页面实时更新
  • (每日一问)设计模式:设计模式的原则与分类——如何提升代码质量?
  • (全注解开发)学习Spring-MVC的第三天
  • (实战篇)如何缓存数据
  • (一)utf8mb4_general_ci 和 utf8mb4_unicode_ci 适用排序和比较规则场景
  • *p++,*(p++),*++p,(*p)++区别?