C++怎么取出系统时间

//方案优点:仅使用C标准库;缺点:只能精确到秒级
#include <time.h>
#include <stdio.h>
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 <windows.h>
#include <stdio.h>
int main( void )
{
SYSTEMTIME sys;
GetLocalTime( &sys );
printf( "%4d/%02d/%02d %02d:%02d:%02d.%03d
星期%1d/n",sys.wYear,sys.wMonth,sys.wDay,sys.wHour,sys.wMinute, sys.wSecond,sys.wMilliseconds,sys.wDayOfWeek);
return 0;
}

//
方案三,优点:利用系统函数,还能修改系统时间
//
此文件必须是c++文件
#include<stdlib.h>
#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;
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
时间片轮转调度算法是一种常见的进程调度算法,它将 CPU 时间分成若干个时间片,每个进程在一个时间片内运行一定时间,然后被暂停并放回就绪队列,等待下一次调度。这样可以保证每个进程都能获得一定的 CPU 时间,避免某些进程长时间占用 CPU 而导致其他进程无法运行的情况。 在实现时间片轮转调度算法时,通常需要使用一个循环队列来维护就绪队列,每次从队头取出一个进程运行,并将其放到队尾。如果一个进程的时间片用完了还没有运行完,则将其重新放到队尾,等待下一次调度。 以下是一个简单的 C++ 实现: ```c++ #include <iostream> #include <queue> using namespace std; struct Process { int pid; // 进程 ID int burst_time; // 运行时间 int remaining_time; // 剩余时间 }; int main() { int n, quantum; // 进程数和时间片长度 cout << "Enter the number of processes: "; cin >> n; cout << "Enter the time quantum: "; cin >> quantum; queue<Process> ready_queue; // 就绪队列 for (int i = 1; i <= n; i++) { int burst_time; cout << "Enter the burst time of process " << i << ": "; cin >> burst_time; ready_queue.push({i, burst_time, burst_time}); } int current_time = 0; // 当前时间 while (!ready_queue.empty()) { Process p = ready_queue.front(); ready_queue.pop(); int run_time = min(quantum, p.remaining_time); // 运行时间 current_time += run_time; p.remaining_time -= run_time; cout << "Process " << p.pid << " runs from " << current_time - run_time << " to " << current_time << endl; if (p.remaining_time > 0) { ready_queue.push(p); } } return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值