1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
use lazy_static::lazy_static;
use time::{macros::format_description, Duration, OffsetDateTime};
lazy_static! {
static ref UNIX_TIME_UNIT_OFFSET: i128 = (Duration::MILLISECOND / Duration::NANOSECOND) as i128;
}
#[inline]
pub fn unix_time_unit_offset() -> u64 {
*UNIX_TIME_UNIT_OFFSET as u64
}
#[inline]
pub fn sleep_for_ms(ms: u64) {
std::thread::sleep(std::time::Duration::from_millis(ms));
}
#[inline]
pub fn sleep_for_ns(ns: u64) {
std::thread::sleep(std::time::Duration::from_nanos(ns));
}
#[inline]
fn cal_curr_time_millis() -> u64 {
(OffsetDateTime::now_utc().unix_timestamp_nanos() / (*UNIX_TIME_UNIT_OFFSET)) as u64
}
#[inline]
pub fn format_time_millis(ts_millis: u64) -> String {
OffsetDateTime::from_unix_timestamp_nanos(milli2nano(ts_millis))
.unwrap()
.format(format_description!("[hour]:[minute]:[second]"))
.unwrap()
}
#[inline]
pub fn format_date(ts_millis: u64) -> String {
OffsetDateTime::from_unix_timestamp_nanos(milli2nano(ts_millis))
.unwrap()
.format(format_description!("[year]-[month]-[day]"))
.unwrap()
}
#[inline]
pub fn format_time_nanos_curr() -> String {
OffsetDateTime::from_unix_timestamp_nanos(curr_time_nanos())
.unwrap()
.format(format_description!("[hour]:[minute]:[second]"))
.unwrap()
}
pub fn curr_time_millis() -> u64 {
let ticker_time = curr_time_millis_with_ticker();
if ticker_time > 0 {
ticker_time
} else {
cal_curr_time_millis()
}
}
#[inline]
pub fn curr_time_nanos() -> i128 {
OffsetDateTime::now_utc().unix_timestamp_nanos()
}
#[inline]
pub fn milli2nano<T: Into<i128>>(t: T) -> i128 {
*UNIX_TIME_UNIT_OFFSET * t.into()
}
pub use ticker::*;
pub mod ticker {
use super::*;
use lazy_static::lazy_static;
use std::sync::atomic::{AtomicU64, Ordering};
lazy_static! {
static ref NOW_IN_MS: AtomicU64 = AtomicU64::new(0);
}
pub fn start_time_ticker() {
update_time();
std::thread::spawn(move || loop {
update_time();
std::thread::sleep(std::time::Duration::from_millis(1));
});
}
#[inline]
fn update_time() {
let curr = cal_curr_time_millis();
NOW_IN_MS.store(curr, Ordering::SeqCst);
}
#[inline]
pub(super) fn curr_time_millis_with_ticker() -> u64 {
NOW_IN_MS.load(Ordering::SeqCst)
}
}