Справочник по консольным командам Toybox для Android 12


  Ver.0.8.4     Ver.0.8.9     Pending  

Путь: Toys/POSIX, команды версии: Ver.4     Ver.9


time

Комментарии в файле time.c :

usage: time [-pv] COMMAND...

Запустите командную строку и сообщите реальное, пользовательское и системное время, прошедшее в секундах. (real = часы на стене, user = процессор, используемый кодом команды, system = процессор, используемый ОС от имени команды.)
  • -p Вывод в формате POSIX
  • -v Подробно

  • usage: time [-pv] COMMAND...

    Run command line and report real, user, and system time elapsed in seconds. (real = clock on the wall, user = cpu used by command's code, system = cpu used by OS on behalf of command.)
  • -p POSIX format output
  • -v Verbose

  • Исходный текст в файле time.c

    #define FOR_time
    #include "toys.h"
    
    
    void time_main(void)
    {
      struct timespec ts, ts2;
      struct rusage ru;
      long long sec[3];
      int stat, ii, idx, nano[3];
      pid_t pid;
      char *labels[] = {"\nreal"+!!FLAG(p), "user", "sys"}, **label = labels,
           *vlabels[] ={"Real", "User", "System"}, tab = toys.optflags ? ' ' : '\t';
    
      if (FLAG(v)) label = vlabels;
      clock_gettime(CLOCK_MONOTONIC, &ts);
      if (!(pid = XVFORK())) xexec(toys.optargs);
      wait4(pid, &stat, 0, &ru);
      clock_gettime(CLOCK_MONOTONIC, &ts2);
      sec[0] = nanodiff(&ts, &ts2);
      nano[0] = (sec[0] % 1000000000)/(toys.optflags ? 1000 : 1000000);
      sec[0] /= 1000000000;
      sec[1] = ru.ru_utime.tv_sec, nano[1] = ru.ru_utime.tv_usec;
      sec[2] = ru.ru_stime.tv_sec, nano[2] = ru.ru_stime.tv_usec;
      for (ii = idx = 0; ii<3; ii++)
        idx += sprintf(toybuf+idx, "%s%s%c%lld.%0*d\n", label[ii],
                       FLAG(v) ? " time (s):" : "", tab, sec[ii],
                       6>>!toys.optflags, nano[ii]);
      if (FLAG(v)) idx += sprintf(toybuf+idx,
        "Max RSS (KiB): %ld\nMajor faults: %ld\n"
        "Minor faults: %ld\nFile system inputs: %ld\nFile system outputs: %ld\n"
        "Voluntary context switches: %ld\nInvoluntary context switches: %ld\n",
        ru.ru_maxrss, ru.ru_majflt, ru.ru_minflt, ru.ru_inblock,
        ru.ru_oublock, ru.ru_nvcsw, ru.ru_nivcsw);
      writeall(2, toybuf, idx);
    
      toys.exitval = WIFEXITED(stat) ? WEXITSTATUS(stat) : WTERMSIG(stat);
    }