Rumah > pembangunan bahagian belakang > C++ > Bagaimana untuk Mengukur Masa CPU dan Masa Jam Dinding Merentasi Platform Yang Berbeza?

Bagaimana untuk Mengukur Masa CPU dan Masa Jam Dinding Merentasi Platform Yang Berbeza?

Linda Hamilton
Lepaskan: 2024-11-10 04:15:02
asal
1022 orang telah melayarinya

How to Measure CPU Time and Wall Clock Time Across Different Platforms?

Mengukur Masa CPU dan Waktu Jam Dinding pada Berbilang Platform

Menentukan masa pelaksanaan kod adalah penting untuk pengoptimuman prestasi. Mengenal pasti berapa banyak masa yang diperuntukkan oleh fungsi untuk pemprosesan CPU berbanding jumlah masa yang berlalu daripada permulaannya memberikan cerapan berharga untuk analisis masa jalan. Untuk menangani keperluan ini, mari kita terokai kaedah pengukuran masa untuk kedua-dua platform Linux dan Windows, termasuk pertimbangan untuk pergantungan seni bina.

Fungsi C dan C:

Berikut ialah coretan kod yang menyediakan penyelesaian merentas platform:

#include <cstdio>
#include <ctime>

double get_wall_time() {
  struct timeval time;
  gettimeofday(&time, NULL);
  return (double)time.tv_sec + (double)time.tv_usec * .000001;
}

double get_cpu_time() {
  return (double)clock() / CLOCKS_PER_SEC;
}
Salin selepas log masuk

Untuk sistem Windows, fungsi yang sepadan akan be:

#include <Windows.h>

double get_wall_time() {
  LARGE_INTEGER time, freq;
  QueryPerformanceFrequency(&freq);
  QueryPerformanceCounter(&time);
  return (double)time.QuadPart / freq.QuadPart;
}

double get_cpu_time() {
  FILETIME a, b, c, d;
  GetProcessTimes(GetCurrentProcess(), &a, &b, &c, &d);
  return (double)(d.dwLowDateTime |
                 ((unsigned long long)d.dwHighDateTime << 32)) *
         0.0000001;
}
Salin selepas log masuk

Demonstrasi:

Untuk menggambarkan penggunaan fungsi ini, berikut ialah contoh:

#include <math.h>

int main() {
  double wall0 = get_wall_time();
  double cpu0 = get_cpu_time();

  // Perform some computation (e.g., a computationally intensive loop)

  double wall1 = get_wall_time();
  double cpu1 = get_cpu_time();

  printf("Wall Time: %.6f seconds\n", wall1 - wall0);
  printf("CPU Time: %.6f seconds\n", cpu1 - cpu0);

  return 0;
}
Salin selepas log masuk

Kod ini mengira masa jam dinding dan masa CPU yang digunakan oleh gelung intensif pengiraan dan mencetak keputusan untuk analisis.

Kemerdekaan Seni Bina:

Kaedah pengukuran masa yang dibentangkan sebahagian besarnya bebas seni bina. Mereka bergantung pada fungsi yang disediakan sistem yang direka bentuk untuk mengambil kira seni bina perkakasan tertentu. Walau bagaimanapun, kes kelebihan tertentu mungkin memerlukan pengoptimuman atau pertimbangan khusus platform.

Atas ialah kandungan terperinci Bagaimana untuk Mengukur Masa CPU dan Masa Jam Dinding Merentasi Platform Yang Berbeza?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan