iPhone: Как получить текущие миллисекунды?

Каков наилучший способ получения текущего системного времени в миллисекундах?

Если вы хотите использовать его для относительной синхронизации (например, в играх или анимации), лучше использовать CACurrentMediaTime().

double CurrentTime = CACurrentMediaTime();

Это рекомендуемый способ; NSDate берет синхрочасы из сети и будет иногда икать при повторной синхронизации с сетью.

Он возвращает текущее абсолютное время в секундах.


Если вам нужна только десятичная часть (часто используется при синхронизации анимации),

let ct = CACurrentMediaTime().truncatingRemainder(dividingBy: 1)
Комментарии (8)
Решение
[[NSDate date] timeIntervalSince1970];

Она возвращает количество секунд с момента эпохи в виде двойки. Я почти уверен, что вы можете получить доступ к миллисекундам из дробной части.

Комментарии (13)

Я протестированные всех других ответов на iPhone 4s и iPad 3 (выпусков). CACurrentMediaTime имеет минимум накладных расходов с небольшим перевесом. timeIntervalSince1970 гораздо медленнее, чем другие, вероятно, из-за NSDate экземпляра накладных, хотя это может не иметь значения для многих случаях использовать.

Я'd рекомендую CACurrentMediaTime если вы хотите, наименьших издержек и Дон'т ум добавлением кварца структуры зависимостей. Или gettimeofday, если мобильность является приоритетом для вас.

айфон 4С

CACurrentMediaTime: 1.33 µs/call
gettimeofday: 1.38 µs/call
[NSDate timeIntervalSinceReferenceDate]: 1.45 µs/call
CFAbsoluteTimeGetCurrent: 1.48 µs/call
[[NSDate date] timeIntervalSince1970]: 4.93 µs/call

для iPad 3

CACurrentMediaTime: 1.25 µs/call
gettimeofday: 1.33 µs/call
CFAbsoluteTimeGetCurrent: 1.34 µs/call
[NSDate timeIntervalSinceReferenceDate]: 1.37 µs/call
[[NSDate date] timeIntervalSince1970]: 3.47 µs/call
Комментарии (3)

В Swift мы можем сделать функцию и сделать следующим образом

func getCurrentMillis()->Int64{
    return  Int64(NSDate().timeIntervalSince1970 * 1000)
}

var currentTime = getCurrentMillis()

Хотя его прекрасно работать в Свифт 3.0 но мы можем изменить и использовать класс дата вместо `NSDate в 3.0

Свифт 3.0

func getCurrentMillis()->Int64 {
    return Int64(Date().timeIntervalSince1970 * 1000)
}

var currentTime = getCurrentMillis()
Комментарии (0)

Пока я нашел gettimeofday` хорошим решением на iOS (для iPad), когда вы хотите выполнить какое-интервал оценки (скажем, по частоте кадров, времени рендеринга кадров...) :

#include 
struct timeval time;
gettimeofday(&time, NULL);
long millis = (time.tv_sec * 1000) + (time.tv_usec / 1000);
Комментарии (5)

Чтобы получить миллисекунд на текущую дату.

Свифт 4+:

func currentTimeInMilliSeconds()-> Int
    {
        let currentDate = Date()
        let since1970 = currentDate.timeIntervalSince1970
        return Int(since1970 * 1000)
    }
Комментарии (0)

Свифт 2

let seconds = NSDate().timeIntervalSince1970
let milliseconds = seconds * 1000.0

Свифт 3

let currentTimeInMiliseconds = Date().timeIntervalSince1970.milliseconds
Комментарии (2)

Это может быть полезно знать о CodeTimestamps, которые предоставляют оболочкой Маха-функциями времени. Это дает вам наносекундного разрешения данных сроков - 1000000x более точным, чем миллисекунд. Да, миллион раз точнее. (С префиксами Милли, микро, нано, каждый в 1000 раз более точные, чем в прошлом.) Даже если вы Don'т нужна CodeTimestamps, проверьте код (он'с открытым исходным кодом), чтобы увидеть, как они используют Маха, чтобы получить данные о времени. Это будет полезно, когда вам нужно больше точности и хотите быстрее вызова метода, чем подход NSDate.

http://eng.pulse.me/line-by-line-speed-analysis-for-ios-apps/

Комментарии (3)
// Timestamp after converting to milliseconds.

NSString * timeInMS = [NSString stringWithFormat:@"%lld", [@(floor([date timeIntervalSince1970] * 1000)) longLongValue]];
Комментарии (0)

Мне нужен NSNumber объект, содержащий точный результат[[NSDate дата] timeIntervalSince1970]`. Поскольку эта функция была вызвана много раз, и я не't действительно нужно создать NSDate объект, перформанс был не велик.

Так, чтобы получить формат, что исходная функция дает мне, попробуйте это:

#include 
struct timeval tv;
gettimeofday(&tv,NULL);
double perciseTimeStamp = tv.tv_sec + tv.tv_usec * 0.000001;

Что должно дать вам тот же результат, как [[NSDate дата] timeIntervalSince1970]

Комментарии (0)

Попробуйте это :

NSDate * timestamp = [NSDate dateWithTimeIntervalSince1970:[[NSDate date] timeIntervalSince1970]];

NSDateFormatter *dateFormatter = [[NSDateFormatter alloc] init];
[dateFormatter setDateFormat:@"YYYY-MM-dd HH:mm:ss.SSS"];

NSString *newDateString = [dateFormatter stringFromDate:timestamp];
timestamp = (NSDate*)newDateString;

В этом примере dateWithTimeIntervalSince1970 используется в сочетании форматера @то"гггг-ММ-ДД чч:мм:СС.ССС", Что будет возвращать дату в год, месяц, день и время часы, минуты, секунды и миллисекунды. Пример : "на 2015-12-02 04:43:15.008-то". Я использовал NSString, чтобы быть уверенным, что формат будет написано раньше.

Комментарии (0)

[CFAbsoluteTimeGetCurrent()][1]

абсолютное время измеряется в секундах относительно абсолютной дата ведения 1 января 2001 00:00:00 по Гринвичу. Положительное значение представляет дату после даты отсчета, отрицательное значение представляет дату перед ней. Например, абсолютное время -32940326 эквивалентно 16 декабря 1999 года в 17:54:34. Повторные вызовы этой функции не гарантируют монотонно возрастающей результаты. Системное время может снизиться за счет синхронизации с внешними временных ссылок или из-за явной смены пользователя часов.

Комментарии (0)

Это в принципе такой же ответ, как написал @TristanLorach, просто перекодируется на Свифт 3:

   /// Method to get Unix-style time (Java variant), i.e., time since 1970 in milliseconds. This 
   /// copied from here: http://stackoverflow.com/a/24655601/253938 and here:
   /// http://stackoverflow.com/a/7885923/253938
   /// (This should give good performance according to this: 
   ///  http://stackoverflow.com/a/12020300/253938 )
   ///
   /// Note that it is possible that multiple calls to this method and computing the difference may 
   /// occasionally give problematic results, like an apparently negative interval or a major jump 
   /// forward in time. This is because system time occasionally gets updated due to synchronization 
   /// with a time source on the network (maybe "leap second"), or user setting the clock.
   public static func currentTimeMillis() -> Int64 {
      var darwinTime : timeval = timeval(tv_sec: 0, tv_usec: 0)
      gettimeofday(&darwinTime, nil)
      return (Int64(darwinTime.tv_sec) * 1000) + Int64(darwinTime.tv_usec / 1000)
   }
Комментарии (0)
 func currentmicrotimeTimeMillis() -> Int64{
let nowDoublevaluseis = NSDate().timeIntervalSince1970
return Int64(nowDoublevaluseis*1000)

}

Комментарии (0)
let timeInMiliSecDate = Date()
let timeInMiliSec = Int (timeInMiliSecDate.timeIntervalSince1970 * 1000)
print(timeInMiliSec)
Комментарии (1)

Это то, что я использовал для Swift

var date = NSDate()
let currentTime = Int64(date.timeIntervalSince1970 * 1000)

print("Time in milliseconds is \(currentTime)")

использовал этот сайт, чтобы проверить точность http://currentmillis.com/

Комментарии (0)
NSTimeInterval time = ([[NSDate date] timeIntervalSince1970]); //double
long digits = (long)time; //first 10 digits        
int decimalDigits = (int)(fmod(time, 1) * 1000); //3 missing digits
/*** long ***/
long timestamp = (digits * 1000) + decimalDigits;
/*** string ***/
NSString *timestampString = [NSString stringWithFormat:@"%ld%03d",digits ,decimalDigits];
Комментарии (0)

[NSDate timeIntervalSinceReferenceDate] - еще один вариант, если вы не хотите включать фреймворк Quartz. Он возвращает двойное значение, представляющее секунды.

Комментарии (0)