如果以root身份运行它,为什么这个C++程序需要很长时间才能完成?

jsg*_*guy 4 c++ caching

我想通过执行以下代码清除L1,L2和L3缓存50次.但是如果我通过输入来运行它会变得非常慢sudo ./a.out.另一方面,如果我只是写./a.out它将几乎立即完成执行.我不明白这个的原因,因为我没有在终端中出现任何错误.

#include <iostream>
#include <cstdlib>
#include <vector>
#include <fstream>
#include <unistd.h>

using namespace std;

void clear_cache(){
    sync();
    std::ofstream ofs("/proc/sys/vm/drop_caches");
    ofs << "3" << std::endl;
    sync();
}


int main() {

    for(int i = 0; i < 50; i++)
        clear_cache();

    return 0;
};
Run Code Online (Sandbox Code Playgroud)

Nem*_*ric 14

您没有足够的权限以常规用户身份写入此文件:

-rw-r--r-- 1 root root 0 Feb 11 15:56 /proc/sys/vm/drop_caches
Run Code Online (Sandbox Code Playgroud)

只有作为特权用户运行的版本才能运行,因此需要更长时间.您没有收到任何错误的原因是您没有检查任何错误.

这是最简单的检查:

#include <iostream>
#include <cstdlib>
#include <vector>
#include <fstream>
#include <unistd.h>

using namespace std;

void clear_cache(){
    sync();
    std::ofstream ofs("/proc/sys/vm/drop_caches");

    if (!ofs)
    {
        std::cout << "could not open file" << std::endl;
        exit(EXIT_FAILURE);
    }

    ofs << "3" << std::endl;
    sync();
}


int main() {

    for(int i = 0; i < 50; i++)
        clear_cache();

    return 0;
};
Run Code Online (Sandbox Code Playgroud)

输出:

% ./a.out    
could not open file
Run Code Online (Sandbox Code Playgroud)