Namespaces
Variants

std::chrono::duration<Rep,Period>:: operator+=, -=, *=, /=, %=

From cppreference.net
(1)
duration & operator + = ( const duration & d ) ;
(seit C++11)
(constexpr seit C++17)
(2)
duration & operator - = ( const duration & d ) ;
(seit C++11)
(constexpr seit C++17)
(3)
duration & operator * = ( const rep & rhs ) ;
(seit C++11)
(constexpr seit C++17)
(4)
duration & operator / = ( const rep & rhs ) ;
(seit C++11)
(constexpr seit C++17)
(5)
duration & operator % = ( const rep & rhs ) ;
(seit C++11)
(constexpr seit C++17)
(6)
duration & operator % = ( const duration & rhs ) ;
(seit C++11)
(constexpr seit C++17)

Führt zusammengesetzte Zuweisungen zwischen zwei Dauern mit derselben Periode oder zwischen einer Dauer und einem Tick-Zählwert durch.

Wenn rep_ die Membervariable ist, die die Anzahl der Ticks in diesem Dauer-Objekt enthält,

1) Entspricht rep_ + = d. count ( ) ; return * this ; .
2) Entspricht rep_ - = d. count ( ) ; return * this ; .
3) Entspricht rep_ * = rhs ; return * this ; .
4) Entspricht rep_ / = rhs ; return * this ; .
5) Entspricht rep_ % = rhs ; return * this ; .
6) Entspricht rep_ % = d. count ( ) ; return * this ; .

Inhaltsverzeichnis

Parameter

d - Dauer auf der rechten Seite des Operators
rhs - Anzahl der Ticks auf der rechten Seite des Operators

Rückgabewert

Eine Referenz auf diese Dauer nach der Modifikation.

Beispiel

#include <chrono>
#include <iostream>
int main()
{
    std::chrono::minutes m(11);
    m *= 2;
    m += std::chrono::hours(10); // Stunden werden implizit in Minuten umgewandelt
    std::cout << m.count() << " Minuten entsprechen "
              << std::chrono::duration_cast<std::chrono::hours>(m).count() 
              << " Stunden und ";
    m %= std::chrono::hours(1);
    std::cout << m.count() << " Minuten\n";
}

Ausgabe:

622 Minuten entsprechen 10 Stunden und 22 Minuten

Siehe auch

erhöht oder verringert die Tickanzahl
(öffentliche Elementfunktion)
implementiert arithmetische Operationen mit Dauern als Argumente
(Funktions-Template)