Rumah >pembangunan bahagian belakang >C++ >Bagaimana untuk menanda aras prestasi fungsi C++?

Bagaimana untuk menanda aras prestasi fungsi C++?

王林
王林asal
2024-04-19 09:00:02792semak imbas

Untuk menanda aras fungsi C++, ambil langkah berikut: Gunakan alat pemasaan seperti perpustakaan std::chrono untuk mengukur masa pelaksanaan. Tulis fungsi penanda aras yang melaksanakan kod dan mengembalikan masa pelaksanaan. Manfaatkan perpustakaan penanda aras untuk ciri lanjutan seperti pengumpulan dan perbandingan statistik.

如何对 C++ 函数性能进行基准测试?

Cara Menanda Aras Prestasi Fungsi C++

Tanda aras ialah teknik penting untuk mengukur prestasi kod dan membandingkan pelaksanaan yang berbeza. Dalam C++, kita boleh menanda aras prestasi fungsi melalui kaedah berikut:

1. Menggunakan alat pemasaan

C++ menyediakan perpustakaan std::chrono, yang mengandungi alat ukuran masa. Kita boleh menggunakan std::chrono::high_resolution_clock untuk mendapatkan pemasaan ketepatan tinggi: std::chrono 库,其中包含用于衡量时间的类。我们可以使用 std::chrono::high_resolution_clock 获取高精度计时:

#include <chrono>

using namespace std::chrono;

auto start = high_resolution_clock::now();
// 待测试代码
auto end = high_resolution_clock::now();

2. 编写基准测试函数

编写一个函数来执行要测试的代码并返回执行时间:

#include <chrono>

using namespace std::chrono;

double benchmark(int n) {
  auto start = high_resolution_clock::now();
  // 待测试代码
  auto end = high_resolution_clock::now();
  return duration_cast<duration<double>>(end - start).count();
}

3. 使用基准测试库

还有各种 C++ 基准测试库可供使用,它们提供更高级的功能,如统计收集和比较。以下是一些流行的库:

  • [benchmark](https://github.com/google/benchmark)
  • [boost::benchmark](https://www.boost.org/doc/libs/1_65_1/libs/benchmark/doc/html/index.html)
  • [google-benchmark](https://github.com/google/benchmark)
  • [Catch2](https://github.com/catchorg/Catch2)

实战案例:

假设我们要基准测试一个查找给定数组中元素的函数 find_element()

#include <chrono>
#include <vector>

using namespace std::chrono;

double find_element_benchmark(size_t n) {
  // 生成一个包含 n 个元素的数组
  std::vector<int> arr(n, 0);
  
  // 查找一个不存在的元素
  auto start = high_resolution_clock::now();
  auto pos = std::find(arr.begin(), arr.end(), -1);
  auto end = high_resolution_clock::now();
  if (pos != arr.end()) return -1;  // 仅在元素找到时返回 -1

  return duration_cast<duration<double>>(end - start).count();
}

int main() {
  // 多次测试不同数组大小
  for (size_t n = 1000; n <= 1000000; n *= 10) {
    // 运行基准测试
    double time = find_element_benchmark(n);
    
    // 打印结果
    std::cout << "数组大小: " << n << "\t执行时间: " << time << " 秒" << std::endl;
  }

  return 0;
}

🎜2 Tulis fungsi penanda aras 🎜🎜🎜Tulis fungsi untuk melaksanakan kod yang akan diuji dan kembalikan. masa pelaksanaan: 🎜 rrreee🎜🎜3. Gunakan perpustakaan penanda aras🎜🎜🎜 Terdapat juga pelbagai perpustakaan penanda aras C++ yang menyediakan fungsi yang lebih maju seperti pengumpulan dan perbandingan statistik. Berikut ialah beberapa perpustakaan popular: 🎜
  • [penanda aras](https://github.com/google/benchmark)
  • [boost::benchmark](https://www. boost .org/doc/libs/1_65_1/libs/benchmark/doc/html/index.html)
  • [google-benchmark](https://github.com/google/benchmark)
  • [Catch2](https://github.com/catchorg/Catch2)
🎜🎜Kes praktikal: 🎜🎜🎜Andaikan kita ingin menanda aras fungsi yang mencari elemen dalam tatasusunan tertentu elemen_cari():🎜rrreee

Atas ialah kandungan terperinci Bagaimana untuk menanda aras prestasi fungsi C++?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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