Estou escrevendo uma biblioteca C++, que trabalha com dados que têm alguns valores de tempo neles - valores que não se originam no sistema em que a biblioteca é executada. Quero colocar esses valores em std::chrono::time_point
's (que serão expostos aos usuários da biblioteca).
Agora, para fazer isso, preciso especificar um Clock
tipo. Ok, isso não deve ser um problema, certo? Posso atender a todos os requisitos de , não posso? ... hmm, não, não realmente, tenho um obstáculo: a now()
função. Não posso fornecer um now()
valor para o sistema onde os valores de ponto de tempo que estou olhando foram gerados! Não tenho acesso a ele, e talvez ele nem exista mais; e pode ter parado, ou sido reiniciado, ou deixado de existir completamente.
Isso significa que eu não devo usar std::chrono
tipos? Ou devo criar um tipo de relógio cuja now()
função retorna um valor fictício fixo? Ou um valor artificialmente crescente?
A versão C++20
<chrono>
contém um relógio que não tem umanow()
função e, na verdade, não tem absolutamente nada nele:local_t
é um relógio, mais ou menos. Ele é usado para definir a família detime_point
s chamadalocal_time
. Um horário local não se refere a uma instância específica no tempo até ser pareado com umtime_zone
.local_t
não atende aos requisitos do Cpp17Clock . No entanto, não há nenhum requisito no modeloque
Clock
atendem aos requisitos do Cpp17Clock . Caso contrário,local_t
não poderia existir.Então o que acontece quando você tenta dizer:
?
Você obtém um erro de tempo de compilação. Isso significa que você não pode usar
local_time
em uma chamada parasleep_until
por exemplo, porquesleep_until
requer que otime_point
'sclock
atenda aos requisitos do Cpp17Clock .Esse relaxamento dos requisitos de clock para
time_point
não foi padronizado até C++20, expressamente com o propósito de introduzirlocal_time
. No entanto, os requisitos mais restritos paratime_point
também nunca foram impostos antes de C++20. Então, de um ponto de vista prático, você está bem em aproveitar esses requisitos relaxados antes de C++20.Editar: Agora que vejo que estamos usando uma biblioteca, não, isso não é legítimo. Minha resposta original explica o porquê abaixo.
Essas são as expectativas da biblioteca padrão, não do código de alguém fora desse escopo. Deve-se esperar, no entanto, que qualquer código de biblioteca que possa ser usado fora de si mesmo esteja em conformidade com esses requisitos para facilitar para aqueles que o usam. Internamente, no entanto, isso é menos importante (embora, algo pelo qual se deve lutar)
Então, a menos que você esteja escrevendo uma biblioteca que passa isso de volta para um usuário, um programador, isso não é um problema.
No entanto, você deve analisar outras possibilidades, garantir que não seja possível implementar uma função .now(), se nenhuma for encontrada, documentar que .now() não foi implementado, juntamente com uma explicação do motivo e, se possível, garantir que um bom erro seja apresentado se seu uso for tentado.
Para responder de forma mais concisa, depende do contexto. Se for interno, sustentável e facilmente explicável, então está tudo bem. Se puder se tornar externo, não for explicável, não for sustentável, então não. Encontre uma maneira diferente.