getrusage.c 1.1 KB

123456789101112131415161718192021222324252627282930313233
  1. #include <errno.h>
  2. #include <stdio.h>
  3. #include <sys/resource.h>
  4. void ptimeval(struct timeval* val) {
  5. printf("{ tv_sec: %ld, tv_usec: %ld }\n", val->tv_sec, val->tv_usec);
  6. }
  7. int main() {
  8. struct rusage r_usage;
  9. if (getrusage(RUSAGE_SELF, &r_usage) < 0) {
  10. perror("getrusage");
  11. return 1;
  12. }
  13. printf("ru_utime:");
  14. ptimeval(&r_usage.ru_utime);
  15. printf("ru_stime:");
  16. ptimeval(&r_usage.ru_utime);
  17. printf("ru_maxrss: %ld\n", r_usage.ru_maxrss);
  18. printf("ru_ixrss: %ld\n", r_usage.ru_ixrss);
  19. printf("ru_idrss: %ld\n", r_usage.ru_idrss);
  20. printf("ru_isrss: %ld\n", r_usage.ru_isrss);
  21. printf("ru_minflt: %ld\n", r_usage.ru_minflt);
  22. printf("ru_majflt: %ld\n", r_usage.ru_majflt);
  23. printf("ru_nswap: %ld\n", r_usage.ru_nswap);
  24. printf("ru_inblock: %ld\n", r_usage.ru_inblock);
  25. printf("ru_oublock: %ld\n", r_usage.ru_oublock);
  26. printf("ru_msgsnd: %ld\n", r_usage.ru_msgsnd);
  27. printf("ru_msgrcv: %ld\n", r_usage.ru_msgrcv);
  28. printf("ru_nsignals: %ld\n", r_usage.ru_nsignals);
  29. printf("ru_nvcsw: %ld\n", r_usage.ru_nvcsw);
  30. printf("ru_nivcsw: %ld\n", r_usage.ru_nivcsw);
  31. }