C++獲取當前時間詳解

一、C++獲取當前時間月份最後一天

在C++中獲取當前時間,並獲取當前時間所在月份的最後一天,我們可以使用tm結構體和mktime函數實現。首先,我們使用time函數獲取當前時間的時間戳,然後轉化為tm結構體,並將其時間設置為下一個月的1號0點0分0秒。再將其時間減去86400秒(即一天的秒數),最後就可以獲得該月份的最後一天的時間戳。具體代碼如下所示:

#include <iostream>
#include <ctime>

using namespace std;

int main() {
  time_t rawtime;
  struct tm * timeinfo;
  time(&rawtime);
  timeinfo = localtime(&rawtime);
  timeinfo->tm_mday = 1;
  timeinfo->tm_mon++;
  mktime(timeinfo);
  timeinfo->tm_mday--;
  cout << "該月份的最後一天為:" << timeinfo->tm_mday << endl;
  return 0;
}

二、C++獲取當前時間的秒數

在C++中獲取當前時間的秒數,我們可以使用time函數獲取當前時間的時間戳,然後將其強制轉化為整型並取餘60,就可以獲取到當前時間的秒數。具體代碼如下所示:

int main() {
  time_t rawtime;
  time(&rawtime);
  int sec = rawtime % 60;
  cout << "當前時間的秒數為:" << sec << endl;
  return 0;
}

三、C++獲取當前時間年月日時分秒

在C++中獲取當前時間的年月日時分秒,我們同樣可以使用tm結構體和localtime函數實現。具體代碼如下所示:

int main() {
  time_t rawtime;
  struct tm * timeinfo;
  time(&rawtime);
  timeinfo = localtime(&rawtime);
  cout << "當前時間為:" << asctime(timeinfo);
  return 0;
}

四、C++獲取當前時間並格式化

在C++中獲取當前時間並格式化輸出,我們可以使用strftime函數實現。該函數的第一個參數為一個字符數組,用於存儲格式化後的字符串;第二個參數為字符數組的大小;第三個參數為格式字符串,用於指定格式;第四個參數為tm結構體指針,用於指定時間。具體代碼如下所示:

int main() {
  time_t rawtime;
  struct tm * timeinfo;
  char buffer[80];
  time(&rawtime);
  timeinfo = localtime(&rawtime);
  strftime(buffer, 80, "%Y-%m-%d %H:%M:%S", timeinfo);
  cout << "當前時間為:" << buffer << endl;
  return 0;
}

五、C++獲取當前時間的0點

在C++中獲取當前時間的0點,我們可以使用tm結構體和mktime函數實現。該函數的作用是將tm結構體轉化為time_t類型的時間戳,我們只需要將tm結構體的時間設置為0點即可。具體代碼如下所示:

int main() {
  time_t rawtime;
  struct tm * timeinfo;
  time(&rawtime);
  timeinfo = localtime(&rawtime);
  timeinfo->tm_hour = 0;
  timeinfo->tm_min = 0;
  timeinfo->tm_sec = 0;
  mktime(timeinfo);
  cout << "當前時間的0點為:" << asctime(timeinfo);
  return 0;
}

六、C++獲取當前時間轉時間戳

在C++中獲取當前時間並將其轉化為時間戳,我們可以使用time函數實現。具體代碼如下所示:

int main() {
  time_t rawtime;
  time(&rawtime);
  cout << "當前時間的時間戳為:" << rawtime << endl;
  return 0;
}

七、C++獲取當前時間的時分秒毫秒

在C++中獲取當前時間的時分秒毫秒,我們可以使用chrono頭文件中的函數和類型實現。具體代碼如下所示:

#include <iostream>
#include <chrono>

using namespace std;

int main() {
  auto now = chrono::system_clock::now();
  auto ms = chrono::duration_cast<chrono::milliseconds>(now.time_since_epoch()).count();
  auto s = chrono::duration_cast<chrono::seconds>(now.time_since_epoch()).count();
  s = s % 86400;
  auto hour = s / 3600;
  auto minute = (s - hour * 3600) / 60;
  auto second = s - hour * 3600 - minute * 60;
  auto millisecond = ms % 1000;
  cout << "當前時間為:" << hour << ":" << minute << ":" << second << "." << millisecond << endl;
  return 0;
}

八、Oracle獲取當前時間

在Oracle數據庫中獲取當前時間,我們可以使用sysdate函數實現。具體代碼如下所示:

SELECT sysdate FROM dual;

九、Qt獲取當前時間

在Qt應用程序中獲取當前時間,我們可以使用QDateTime類實現。具體代碼如下所示:

#include <iostream>
#include <QDateTime>

using namespace std;

int main() {
  QDateTime currentDateTime = QDateTime::currentDateTime();
  QString currentDateTimeString = currentDateTime.toString("yyyy-MM-dd hh:mm:ss");
  cout << "當前時間為:" << currentDateTimeString.toStdString() << endl;
  return 0;
}

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/185721.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-26 21:06
下一篇 2024-11-26 21:06

相關推薦

  • 解決docker-compose 容器時間和服務器時間不同步問題

    docker-compose是一種工具,能夠讓您使用YAML文件來定義和運行多個容器。然而,有時候容器的時間與服務器時間不同步,導致一些不必要的錯誤和麻煩。以下是解決方法的詳細介紹…

    編程 2025-04-29
  • 想把你和時間藏起來

    如果你覺得時間過得太快,每天都過得太匆忙,那麼你是否曾經想過想把時間藏起來,慢慢享受每一個瞬間?在這篇文章中,我們將會從多個方面,詳細地闡述如何想把你和時間藏起來。 一、一些時間管…

    編程 2025-04-28
  • 計算斐波那契數列的時間複雜度解析

    斐波那契數列是一個數列,其中每個數都是前兩個數的和,第一個數和第二個數都是1。斐波那契數列的前幾項為:1,1,2,3,5,8,13,21,34,…。計算斐波那契數列常用…

    編程 2025-04-28
  • 時間戳秒級可以用int嗎

    時間戳是指從某個固定的時間點開始計算的已經過去的時間。在計算機領域,時間戳通常使用秒級或毫秒級來表示。在實際使用中,我們經常會遇到需要將時間戳轉換為整數類型的情況。那麼,時間戳秒級…

    編程 2025-04-28
  • 如何在ACM競賽中優化開發時間

    ACM競賽旨在提高程序員的算法能力和解決問題的實力,然而在比賽中優化開發時間同樣至關重要。 一、規劃賽前準備 1、提前熟悉比賽規則和題目類型,了解常見算法、數據結構和快速編寫代碼的…

    編程 2025-04-28
  • 使用JavaScript日期函數掌握時間

    在本文中,我們將深入探討JavaScript日期函數,並且從多個視角介紹其應用方法和重要性。 一、日期的基本表示與獲取 在JavaScript中,使用Date對象來表示日期和時間,…

    編程 2025-04-28
  • Java Date時間大小比較

    本文將從多個角度詳細闡述Java中Date時間大小的比較,包含了時間字符串轉換、日期相減、使用Calendar比較、使用compareTo方法比較等多個方面。相信這篇文章能夠對你解…

    編程 2025-04-27
  • 二分查找時間複雜度為什麼是logN – 知乎

    二分查找是一種常用的查找算法。它通過將目標值與數組的中間元素進行比較,從而將查找範圍縮小一半,直到找到目標值。這種方法的時間複雜度為O(logN)。下面我們將從多個方面探討為什麼二…

    編程 2025-04-27
  • One change 時間:簡化項目開發的最佳實踐

    本文將介紹 One change 時間 (OCT) 的定義和實現方法,並探討它如何簡化項目開發。OCT 是一種項目開發和管理的策略,通過將更改限制在固定的時間間隔(通常為一周)內,…

    編程 2025-04-27
  • Java Date 比較時間大小

    本文將從以下方面對 Java Date 比較時間大小進行詳細闡述: 一、比較方法的介紹 Java Date 類提供了多種比較時間大小的方法,其中比較常用的包括: compareTo…

    編程 2025-04-27

發表回復

登錄後才能評論