用cstlib函数time,比如
#include <iostream>
#include <cstlib>
using namespace std;
int main()
{
int t, h, m, s;
t = time( 0 );
t = t % 86400;
s = t % 60;
t = ( t - s ) / 60;
m = t % 60;
t = ( t - m ) / 60;
h = t;
cout << "现在是" << h << ":" << m << ":" << s << endl;
return 0;
}
即可显示
需要借助其他函数。linux函数只能得到秒精度的时间,为了获得更高精度的时间戳,需要其他函数。函数,数学术语。其定义通常分为传统定义和近代定义,函数的两个定义本质是相同的,只是叙述概念的出发点不同,传统定义是从运动变化的观点出发,而近代定义是从集合、映射的观点出发。
题主你好,
linux下使用 date 命令获取日期和时间
说明: 单独使用date命令显示的比较全, 年月日时分秒,星期几都会显示出来如果只需要显示某一维度或某几个维度的值,可能加参数实现 如果题主想知道请追问
希望可以帮到题主, 欢迎追问
1)
找到相应的时区文件
/usr/share/zoneinfo/asia/shanghai
用这个文件替换当前的/etc/localtime文件。
2)
修改/etc/sysconfig/clock文件,修改为:
zone="asia/shanghai"
[color=red]utc=true[/color]
arc=false
3)
时间设定成2005年8月30日的命令如下:
#date
-s
08/30/2005
将系统时间设定成下午6点40分0秒的命令如下。
#date
-s
18:40:00
4)
同步bios时钟,强制把系统时间写入cmos,命令如下:
#clock
-w
5)重启apache。
参考资料二、
本文档解释了如何从linux下设置计算机的时钟,如何设置您的时区和其它与linux如何保存时间相关的材料。
您的计算机有两个时钟,一个是始终运行的、由电池供电的(
硬件的、bios或cmos
)时钟,另一个是由运行在您的计算机上的 *** 作系统维护的(
系统
)时钟。硬件时钟通常只在 *** 作系统启动时用来设置系统时钟,然后直到重启或关闭系统,由系统时钟来记录时间。在linux
系统中,您可以选择用utc/gmt
时间或本地时间来记录硬件时钟。推荐的选项是用utc
记录,因为夏令时可以自动记录。使用utc
记录硬件时钟的唯一不足是,如果您使用双系统,其它 *** 作系统,如dos
要求硬件时钟用本地时间设置,那么在那个 *** 作系统里时间将是错误的。
设置时区:
linux
下的时区是通过建立从/etc/localtime[1]
到/usr/share/zoneinfo
[2]
目录下与您所在时区相符的文件的符号链结实现的。例如,由于我在南澳大利亚,/etc/localtime就是到
/usr/share/zoneinfo/australia/south的符号链结。要建立这个链结,运行:
ln
-sf
/usr/share/zoneinfo/your/zone
/etc/localtime
替换your/zone
为形如australia/nsw或australia/perth
的文件。看看/usr/share/zoneinfo目录都有什么时区。
[1]
这里假设/usr/share/zoneinfo
是到/etc/localtime
的链结的前提是redhat
linux
[2]
在旧版本的系统里,您会发现使用/usr/lib/zoneinfo而不是/usr/share/zoneinfo。参考后面“一些应用程序中时间错误”。
第一条命令,时间同步的结果是调整了-0005236秒,这当然不是明显的时间变化
第二条命令,显示了系统时钟和硬件时钟相差-0282976秒这也是正常的,没有问题
所以看来你的时间基本准确,时间同步不会产生明显的变化
你关心的应该是另一个网友提到的时区问题,你现在用的是EST也就是北美东部时间(GMT-5,比格林威治标准时间晚5个小时,每年3月的第二个周日到11月第一个周日使用夏令时,时钟往前一小时),本地使用的话应该改成中国标准时间(GMT+8,比格林威治标准时间早8个小时,没有夏令时),修改的话很简单网友已经提供了
cp
/usr/share/zoneinfo/Asia/Shanghai
/etc/localtime
然后logout再login就会显示你熟悉的时间了,系统时钟本身没有调整,但是从显示纽约时间变成了本地时间
//方案— 优点:仅使用C标准库;缺点:只能精确到秒级
#include <timeh>
#include <stdioh>
int main( void )
{
time_t t = time(0);
char tmp[64];
strftime( tmp, sizeof(tmp), "%Y/%m/%d %X %A 本年第%j天 %z",localtime(&t) );
puts( tmp );
return 0;
}
size_t strftime(char strDest, size_t maxsize, const char format, const struct tm timeptr);
根据格式字符串生成字符串。
struct tm localtime(const time_t timer);
取得当地时间,localtime获取的结果由结构tm返回
返回的字符串可以依下列的格式而定:
%a 星期几的缩写。Eg:Tue
%A 星期几的全名。 Eg: Tuesday
%b 月份名称的缩写。
%B 月份名称的全名。
%c 本地端日期时间较佳表示字符串。
%d 用数字表示本月的第几天 (范围为 00 至 31)。日期
%H 用 24 小时制数字表示小时数 (范围为 00 至 23)。
%I 用 12 小时制数字表示小时数 (范围为 01 至 12)。
%j 以数字表示当年度的第几天 (范围为 001 至 366)。
%m 月份的数字 (范围由 1 至 12)。
%M 分钟。
%p 以 ''AM'' 或 ''PM'' 表示本地端时间。
%S 秒数。
%U 数字表示为本年度的第几周,第一个星期由第一个周日开始。
%W 数字表示为本年度的第几周,第一个星期由第一个周一开始。
%w 用数字表示本周的第几天 ( 0 为周日)。
%x 不含时间的日期表示法。
%X 不含日期的时间表示法。 Eg: 15:26:30
%y 二位数字表示年份 (范围由 00 至 99)。
%Y 完整的年份数字表示,即四位数。 Eg:2008
%Z(%z) 时区或名称缩写。Eg:中国标准时间
%% % 字符。
//方案二 优点:能精确到毫秒级;缺点:使用了windows API
#include <windowsh>
#include <stdioh>
int main( void )
{
SYSTEMTIME sys;
GetLocalTime( &sys );
printf( "%4d/%02d/%02d %02d:%02d:%02d%03d 星期%1d\n",syswYear,syswMonth,syswDay,syswHour,syswMinute, syswSecond,syswMilliseconds,syswDayOfWeek);
return 0;
}
//方案三,优点:利用系统函数,还能修改系统时间
//此文件必须是c++文件
#include<stdlibh>
#include<iostream>
using namespace std;
void main()
{
system("time");
}
//方案四,将当前时间折算为秒级,再通过相应的时间换算即可
//此文件必须是c++文件
#include<iostream>
#include<ctime>
using namespace std;
int main()
{
time_t now_time;
now_time = time(NULL);
cout<<now_time;
return 0;
}
第一条命令,时间同步的结果是调整了-0005236秒,这当然不是明显的时间变化
第二条命令,显示了系统时钟和硬件时钟相差-0282976秒这也是正常的,没有问题
所以看来你的时间基本准确,时间同步不会产生明显的变化
你关心的应该是另一个网友提到的时区问题,你现在用的是EST也就是北美东部时间(GMT-5,比格林威治标准时间晚5个小时,每年3月的第二个周日到11月第一个周日使用夏令时,时钟往前一小时),本地使用的话应该改成中国标准时间(GMT+8,比格林威治标准时间早8个小时,没有夏令时),修改的话很简单网友已经提供了
cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
然后logout再login就会显示你熟悉的时间了,系统时钟本身没有调整,但是从显示纽约时间变成了本地时间
以上就是关于linux c++ 如何获取 系统时间全部的内容,包括:linux c++ 如何获取 系统时间、linux如何获取当前时间后五分钟、linux获取当前时间的命令等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)