linux下usleep函数对CPU占用率的影响

linux下usleep函数对CPU占用率的影响

2023-11-16

文章目录

  • linux下usleep函数对CPU占用率的影响
    • [1. 测试代码](#1. 测试代码)
    • [2. CPU占用率](#2. CPU占用率)
      • 不使用usleep延时
      • [#define SLEEP_US 1 (1微秒)](#define SLEEP_US 1 (1微秒))
      • [#define SLEEP_US 10 (10微秒)](#define SLEEP_US 10 (10微秒))
      • [#define SLEEP_US 100 (100微秒)](#define SLEEP_US 100 (100微秒))
      • [#define SLEEP_US 1000 (1000微秒=1毫秒)](#define SLEEP_US 1000 (1000微秒=1毫秒))
      • [#define SLEEP_US 10000 (10000微秒=10毫秒)](#define SLEEP_US 10000 (10000微秒=10毫秒))
      • [#define SLEEP_US 100000 (100000微秒=100毫秒)](#define SLEEP_US 100000 (100000微秒=100毫秒))

环境

复制代码
系统: ubuntu 22.04
内核版本: Linux 5.15.0-58-generic
cpu: Intel(R) Xeon(R) Platinum 8269CY CPU @ 2.50GHz
cpu核数: 1
架构: x86_64

1. 测试代码

main.cpp

复制代码
#include <unistd.h> // usleep

#define SLEEP_US 1

int main()
{
    while (1)
    {
        usleep(SLEEP_US);
    }

    return 0;
}

$ g++ main.cpp -o main
$ ./main
$ top -p `pidof main`

2. CPU占用率

不使用usleep延时

CPU占用率:95.3%

复制代码
$ top -p `pidof main`
    PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
2325638 root      20   0    2640    940    848 R  95.3   0.1   0:29.17 main

#define SLEEP_US 1 (1微秒)

CPU占用率:8.0%

复制代码
$ top -p `pidof main`
    PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
2324270 root      20   0    2640    928    840 R   8.0   0.1   0:07.92 main

#define SLEEP_US 10 (10微秒)

CPU占用率:7.0%

复制代码
$ top -p `pidof main`
    PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
2326872 root      20   0    2640    976    888 R   7.0   0.1   0:01.61 main

#define SLEEP_US 100 (100微秒)

CPU占用率:3.3%

复制代码
$ top -p `pidof main`
    PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
2327593 root      20   0    2640    988    900 R   3.3   0.1   0:00.73 main

#define SLEEP_US 1000 (1000微秒=1毫秒)

CPU占用率:0.7%

复制代码
$ top -p `pidof main`
    PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
2328327 root      20   0    2640    984    896 S   0.7   0.1   0:00.15 main

#define SLEEP_US 10000 (10000微秒=10毫秒)

CPU占用率:0.3%

复制代码
$ top -p `pidof main`
    PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
2329099 root      20   0    2640    988    900 S   0.3   0.1   0:00.02 main

#define SLEEP_US 100000 (100000微秒=100毫秒)

CPU占用率:0.0%

复制代码
$ top -p `pidof main`
    PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
2329719 root      20   0    2640    984    896 S   0.0   0.1   0:00.00 main

License

License under CC BY-NC-ND 4.0: 署名-非商业使用-禁止演绎


Reference:

NULL

相关推荐
facaixxx20241 分钟前
应用镜像是什么?轻量应用服务器的镜像大全
linux·运维·服务器
火龙谷29 分钟前
【hadoop】master一键启动hadoop集群(高可用)
linux·hadoop
noravinsc43 分钟前
Linux 下 Module 工具的介绍与使用
linux·运维·服务器
Sunlight_7771 小时前
第五章 SQLite数据库:1、SQLite 基础语法及使用案例
java·linux·服务器·jvm·数据库·tcp/ip·sqlite
Silence4Allen1 小时前
Ubuntu 安装WPS Office
linux·ubuntu·wps
程序员JerrySUN2 小时前
驱动开发硬核特训 · Day 11(下篇):从 virtio_blk 看虚拟总线驱动模型的真实落地
linux·驱动开发·嵌入式硬件
半兽先生2 小时前
CentOS 中安装 vim
linux·centos·vim
长流小哥3 小时前
Linux网络编程实战:从字节序到UDP协议栈的深度解析与开发指南
linux·c语言·开发语言·网络·udp
极小狐4 小时前
极狐GitLab 功能标志详解
linux·运维·服务器·elasticsearch·gitlab·极狐gitlab
雾原5 小时前
Red Hat Enterprise Linux (RHEL)系统部署
linux