GNU/Linux >> Znalost Linux >  >> Linux

Jak vytisknout aktuální čas (v milisekundách) pomocí C++ / C++11

Neztrácejte čas s Boostem (vím, že mnozí budou tímto prohlášením uraženi a budou to považovat za kacířství).

Tato diskuse obsahuje dvě velmi funkční řešení, která nevyžadují, abyste se zotročili nestandardními knihovnami třetích stran.

C++ získává v Linuxu čas v milisekundách -- clock() zřejmě nefunguje správně

http://linux.die.net/man/3/clock_gettime

Odkazy na gettimeofday lze nalézt zde na opengroup.org


Můžete použít Boost's Posix Time .

Můžete použít boost::posix_time::microsec_clock::local_time() získat aktuální čas z hodin s rozlišením mikrosekund:

boost::posix_time::ptime now = boost::posix_time::microsec_clock::local_time();

Poté můžete vypočítat časový posun v aktuálním dni (protože váš výstup trvání je ve tvaru <hours>:<minutes>:<seconds>.<milliseconds> , předpokládám, že se počítají jako offset aktuálního dne; pokud nejsou, klidně použijte jiný výchozí bod pro trvání/časový interval):

boost::posix_time::time_duration td = now.time_of_day();

Pak můžete použít .hours() , .minutes() , .seconds() přístupové prvky k získání odpovídajících hodnot.
Bohužel se nezdá, že existuje .milliseconds() přístupový objekt, ale existuje .total_milliseconds() jeden; takže můžete udělat malou matematiku pro odečítání, abyste získali zbývající milisekundy k formátování v řetězci.

Pak můžete použít sprintf() (nebo sprintf()_s pokud máte zájem o nepřenosný kód pouze pro VC++), naformátujte tato pole do nezpracovaného kódu char buffer a bezpečně zabalte tento nezpracovaný C řetězec buffer do robustního pohodlného std::string instance.

Další podrobnosti naleznete v komentovaném kódu níže.

Výstup v konzole je něco jako:

11:43:52.276

Ukázkový kód:

///////////////////////////////////////////////////////////////////////////////

#include <stdio.h>      // for sprintf()

#include <iostream>     // for console output
#include <string>       // for std::string

#include <boost/date_time/posix_time/posix_time.hpp>


//-----------------------------------------------------------------------------
// Format current time (calculated as an offset in current day) in this form:
//
//     "hh:mm:ss.SSS" (where "SSS" are milliseconds)
//-----------------------------------------------------------------------------
std::string now_str()
{
    // Get current time from the clock, using microseconds resolution
    const boost::posix_time::ptime now = 
        boost::posix_time::microsec_clock::local_time();

    // Get the time offset in current day
    const boost::posix_time::time_duration td = now.time_of_day();

    //
    // Extract hours, minutes, seconds and milliseconds.
    //
    // Since there is no direct accessor ".milliseconds()",
    // milliseconds are computed _by difference_ between total milliseconds
    // (for which there is an accessor), and the hours/minutes/seconds
    // values previously fetched.
    //
    const long hours        = td.hours();
    const long minutes      = td.minutes();
    const long seconds      = td.seconds();
    const long milliseconds = td.total_milliseconds() -
                              ((hours * 3600 + minutes * 60 + seconds) * 1000);

    //
    // Format like this:
    //
    //      hh:mm:ss.SSS
    //
    // e.g. 02:15:40:321
    //
    //      ^          ^
    //      |          |
    //      123456789*12
    //      ---------10-     --> 12 chars + \0 --> 13 chars should suffice
    //  
    // 
    char buf[40];
    sprintf(buf, "%02ld:%02ld:%02ld.%03ld", 
        hours, minutes, seconds, milliseconds);

    return buf;
}

int main()
{
    std::cout << now_str() << '\n';    
}

///////////////////////////////////////////////////////////////////////////////

Zde je řešení, které jsem našel bez použití boost

std::string getCurrentTimestamp()
{
using std::chrono::system_clock;
auto currentTime = std::chrono::system_clock::now();
char buffer[80];

auto transformed = currentTime.time_since_epoch().count() / 1000000;

auto millis = transformed % 1000;

std::time_t tt;
tt = system_clock::to_time_t ( currentTime );
auto timeinfo = localtime (&tt);
strftime (buffer,80,"%F %H:%M:%S",timeinfo);
sprintf(buffer, "%s:%03d",buffer,(int)millis);

return std::string(buffer);
}

Linux
  1. Jak získat trasování zásobníku pro C++ pomocí gcc s informacemi o čísle řádku?

  2. Jak vytisknout členy objektu c++ pomocí GDB z adresy, pokud je typ třídy objektu jako A::B

  3. Bash - Jak tisknout víceřádkové řetězce (s '\n') pomocí printf

  1. Jak synchronizovat čas pomocí NTP na serveru Ubuntu?

  2. Tisk aktuálního času v milisekundách nebo nanosekundách s vestavěným printf

  3. V Linuxu, jak vytvořit soubor s názvem, který je aktuální datum a čas

  1. Jak vytisknout proměnnou s vycpaným zarovnáním na střed?

  2. Jak naplánovat úlohy pomocí at v Linuxu

  3. Jak získat celkové využití CPU v Linuxu pomocí C++