Namespaces
Variants

std::chrono::duration<Rep,Period>:: operator=

From cppreference.net
duration & operator = ( const duration & other ) = default ;
(seit C++11)

Weist den Inhalt eines duration einem anderen zu.

Parameter

andere - duration zu kopieren von

Beispiel

#include <chrono>
#include <iostream>
int main()
{
    using namespace std::chrono_literals;
    std::chrono::hours z_hours{};
    std::chrono::seconds z_seconds{};
    z_hours = 2h; // ok, keine Konvertierung erforderlich
    z_seconds = z_hours;
    // Zuerst wird der konvertierende Konstruktor verwendet, um ein temporäres Objekt vom Typ `lhs` zu erstellen.
    // Dieser Konstruktor ruft implizit die Umwandlungsfunktion
    // chrono::duration_cast<std::seconds>(z_hours) auf. Der resultierende `rhs`-Rvalue
    // hat denselben Typ wie `lhs`, und der `operator=` führt schließlich die Zuweisung durch.
    std::cout << "hours: " << z_hours.count() << '\n';
    std::cout << "seconds: " << z_seconds.count() << '\n';
    z_seconds -= 42s;
//  z_hours = z_seconds; // Kompilierzeitfehler (was gut ist): inkompatible Typen.
    // Die Bibliothek vermeidet die implizite Umwandlung, um einen potenziellen Genauigkeitsverlust zu verhindern.
    z_hours = std::chrono::duration_cast<std::chrono::hours>(z_seconds); // ok
    z_hours = std::chrono::duration_cast<decltype(z_hours)>(z_seconds);  // dito
    std::cout << "hours: " << z_hours.count() << '\n';
    std::cout << "seconds: " << z_seconds.count() << '\n';
    std::chrono::duration<double, std::ratio<3600>> z2_hours{};
    z2_hours = z_seconds; // ok, keine Abrundung, implizite Umwandlung
    std::cout << "hours: " << z2_hours.count() << '\n';
}

Ausgabe:

hours: 2
seconds: 7200
hours: 1
seconds: 7158
hours: 1.98833

Siehe auch

Konstruiert neue Duration
(öffentliche Member-Funktion)