7. 系统信息与系统资源
7. 系统信息与系统资源
- 1. 系统信息
- 1.1 系统标识 uname()
- 1.2 sysinfo()
- 1.3 gethostname()
- 1.4 sysconf()
- 2. 时间、日期
- 2.1 Linux 系统中的时间
- 2.1.1 Linux 怎么记录时间
- 2.1.2 jiffies 的引入
- 2.2 获取时间 time/gettimeofday
- 2.2.1 time()
- 2.2.2 gettimeofday()
- 2.3 时间转换函数
- 2.3.1 ctime()
- 2.3.2 localtime()
- 2.3.3 gmtime()
- 2.3.4 mktime()
- 2.3.5 asctime()
- 2.3.6 strftime()
- 2.4 设置时间 settimeofday
- 3. 进程时间
- 3.1 times()
- 3.2 clock()
- 4. 产生随机数
- 4.1 rand()
- 4.2 srand()
- 5. 休眠
- 5.1 秒级休眠 sleep()
- 5.2 微秒级休眠 usleep()
- 5.3 高进度休眠 nanosleep()
- 6. 申请堆内存
- 6.1 在堆上分配内存
- 6.2 在堆上分配对齐内存
- 7. proc 文件系统
- 7.1 使用cat命令读取
- 7.2 使用read读取
1. 系统信息
1.1 系统标识 uname()
系统调用 uname() 用于获取当前操作系统内核的名称和信息。调用时先创建一个结构体类型变量,然后传入地址即可
#include <sys/utsname.h>
int uname(struct utsname *buf);
1.2 sysinfo()
可用于获取一些系统统计信息
#include <sys/sysinfo.h>
int sysinfo(const sysinfo *info);
1.3 gethostname()
可以单独获取 Linux 系统主机名
#include <unistd.h>
int gethostname(char *name, size_t len);
// 参数:用于存放主机名的缓冲区以及缓冲区大小
1.4 sysconf()
可在运行时获取系统的一些配置信息
#include <unistd.h>
long sysconf(int name);
/* name:指定要获取哪个配置信息,可以使用 man 手册查看* _SC_ARG_MAX:exec族函数的参数的最大长度,这里先不用了解exec族* _SC_CHILD_MAX:每个用户的最大并发进程数* _SC_HOST_NAME_MAX:主机名的最大长度* _SC_LOGIN_NAME_MAX:登录名的最大长度* _SC_CLK_TCK:每秒时钟滴答数,也就是系统节拍率* _SC_OPEN_MAX:一个进程可以打开的最大文件数* _SC_PAGESIZE:系统页大小* _SC_TTY_NAME_MAX:终端设备名的最大长度* ...* /
2. 时间、日期
2.1 Linux 系统中的时间
操作系统中有两个时钟,一个是系统时钟,一个是实时时钟,也叫 RTC。系统时钟在系统启动之后由内核来维护,使用 date 命令获取到的就是系统时钟,在系统关机情况下不存在;实时时钟一般由 RTC 时钟芯片提供,该芯片有相应的电池,可以保证在系统关机的情况下依旧能够继续工作。
2.1.1 Linux 怎么记录时间
在启动之后先读取 RTC 作为系统时钟的初始值,之后一直维护系统时钟,然后就不会再对 RTC 进行读取操作。系统关机后,会将系统时钟写入到 RTC,进行同步操作。
2.1.2 jiffies 的引入
内核定义的一个全局变量,使用该变量来记录系统从启动以来的系统节拍数,所以这个变量用来记录以系统节拍时间为单位的时间长度,Linux 内核在编译配置时定义了一个节拍时间,使用节拍率(一秒钟多少个节拍数)来表示,譬如节拍率为 200Hz,就表示一秒钟 200 个节拍,节拍时间为 1s/200。节拍率越低,每一个系统节拍的时间就越短,意味着 jiffies 记录的时间精度越高。 但是高节拍率会导致系统中断的产生更加频繁,会加剧系统的负担,一般默认情况下都是采用 100Hz 作为系统节拍率。
内核其实通过 jiffies 来维护系统时钟,在系统开机时会设置一个初始值,上面所说的读取 RTC就是用来初始化 jiffies 变量的。当我们需要获取到系统当前时间点时,就可以使用 jiffies 变量去计算。
2.2 获取时间 time/gettimeofday
2.2.1 time()
获取当前时间,以秒为单位,返回值是从 1970-01-01 00:00:00 +0000(UTC) 以来的秒数
#include <time.h>
time_t time(time_t *tloc);
// 如果 tloc 不是空,则返回值存储在 tloc 指向的内存中
2.2.2 gettimeofday()
time 函数只能精确到秒,而这个函数可以精确到微秒
#include <sys/time.h>
int gettimeofday(struct timeval *tv, struct timezone *tz);
// tz 直接设置为NULL即可
// 获取到的时间存储在tv中,这个结构体的有两个变量,得到的时间就是 tv_sec+tv_usec。tv_sec 的值和time获取的值相同
2.3 时间转换函数
2.3.1 ctime()
将时间转换为字符串形式
#include <time.h>
char *ctime(const time_t *timep);
char *ctime_r(const time_t *timep, char *buf);
// 成功就返回指向得到的字符串的指针,失败就返回NULl
// 但是 ctime 是一个不可重入的函数,推荐使用 ctime_r,是一个可重入函数,buf就是用于存放字符串的缓冲区地址。可重入后面再讲,_r 就一般表示可重入,也就是如果成功就返回buf
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <iostream>
using namespace std;
int main()
{char str[100]={0};time_t tm;tm=time(NULL);ctimr_t(&tm,str);cout << str<<endl;return 0;
}
2.3.2 localtime()
讲时间转换为一个 struct tm 结构体所表示的时间,对应的是本地时间
#include <time.h>
struct tm *localtime(const time_t *timep);
struct tm *localtime_r(const time_t *timep, struct tm *result);
2.3.3 gmtime()
将 time_t 转换为 struct tm 结构体表示的时间,但是是 UTC 时间,不是本地时间
#include <time.h>
struct tm *gmtime(const time_t *timep);
struct tm *gmtime_r(const time_t *timep, struct tm *result);
2.3.4 mktime()
将 struct tm 结构体表示的时间转换为 time_t 时间
#include <time.h>
time_t mktime(struct tm *tm);
2.3.5 asctime()
和 ctime() 一样,但是可以将时间分解转换为固定格式字符串。
#include <time.h>
char *asctime(const struct tm *tm);
char *asctime_r(const struct tm *tm, char *buf);
2.3.6 strftime()
可以根据自己的需要设定格式
#include <time.h>
size_t strftime(char *s, size_t max, const char *format, const struct tm *tm);
/* s:存放生成的字符串* max:字符串的最大字节数* format:格式* tm:指向结构体的指针 * /
这些格式字段可以任意组合,比如:"%Y-%m-%d %H:%M:%S<%p> %B %A"
可以输出"2021-01-14 16:30:25<PM> January Thursday"
2.4 设置时间 settimeofday
设置系统本地时间,而且只有超级用户才能设置时间
#include <sys/time.h>
int settimeofday(const struct timeval *tv, const struct timezone *tz);
// tz 目前已经废弃,直接设置NULL即可
3. 进程时间
进程时间指的是进程从创建后,也就是程序运行后,到目前为止这段时间内使用 CPU 资源的时间总数。内核将 CPU 时间,也就是进程时间分为两部分:
- 用户 CPU 时间:进程在用户空间下运行所花费的 CPU 时间,也成为虚拟时间
- 系统 CPU 时间:进程在内核态下运行所花费的时间。这是内核执行系统调用或代表进程执行的其他任务所花费的时间。
一般来说,进程时间指的是这两个时间总和
注意: 进程时间不等于程序的整个生命周期所消耗的时间,如果进程一直处于休眠状态(进程被挂起、不会得到系统调度),那么它并不会使用 CPU 资源,所以休眠这段时间不计算在进程时间中。
3.1 times()
获取当前进程时间
#include <sys/times.h>
clock_t times(struct tms *buf);
// 返回值类型实际就是long类型,成功时返回从过去任意一个时间点所经过的时钟滴答数,就是系统节拍数,将节拍数/节拍率就是秒数,返回值可能会溢出,调用失败返回-1
// 计算一段程序耗费的进程时间和总的时间
#include <stdio.h>
#include <stdlib.h>
#include <sys/times.h>
#include <unistd.h>
#include <iostream>
using namespace std;
int main(int argc, char *argv[])
{struct tms _start;struct tms _end;clock_t start;clock_t end;long tck;int i,j;// 获取系统节拍率tck = sysconf(_SC_CLK_TCK);// 开始时间start = times(&_start);for(i=0;i<20000;i++);{for(j=0;j<20000;j++);{}}sleep(1);end = times(&_end);cout << "时间总和: << (end-start)/double(tck) << endl;// 2.910000秒,从起点到终点所经过的时间,并不是进程时间cout << "用户时间: << (_end.tms_utime-_start.tms_utime)/double(tck) << endl;// 1.900000秒cout << "系统时间: << (_end.tms_stime-_start.tms_stime)/double(tck) << endl;// 0.000000秒
}
3.2 clock()
更简单的函数获取进程时间,返回值描述了进程使用的总的 CPU 时间,也就是进程时间。
#include <time.h>
clock_t clock();
// 返回值就是到目前为止程序的进程时间,并不是系统节拍数,如果想要获取秒数,需要除 CLOCKS_PER_SEC,失败返回-1。但是此函数不能获取到单独的用户CPU时间和系统CPU时间
4. 产生随机数
4.1 rand()
#include <stdlib.h>
int rand();
// 这个函数每一次运行程序获得的随机数都是相同的,需要使用srand函数设置随机数种子。rand将1作为随机数种子
4.2 srand()
#include <stdlib.h>
void srand(unsigned int seed);
一般都是将当前时间作为种子传递给seed,因为时间是一直在变化的。
// 生成一组随机数
#include <stdio.h>
#include <stdlib.h>
#include <time.h>int main()
{int random_number_arr[8];int count;srand(time(NULL));for(count = 0; count<8;count++){random_number_arr[count] = rand()%100;}for(count = 0; count<8;count++){cout << random_number_arr[count] << " ";}cout << endl;return 0;
}
5. 休眠
5.1 秒级休眠 sleep()
#include <unistd.h>
unsigned int sleep(unsigned int seconds);
// 如果休眠时长等于seconds,就返回0;如果被信号中断,返回剩余的秒数
5.2 微秒级休眠 usleep()
#include <unistd.h>
int usleep(useconds_t usec);
// 成功返回0,失败返回-1
5.3 高进度休眠 nanosleep()
#include <time.h>
int nanosleep(const struct timespec *req, struct timespec *rem);
// req:设置休眠时长,可精确到纳秒级
// rem:可以设置NULL
// 如果成功休眠设定的时长,返回0;如果被信号中断或错误,返回-1,并将剩余时间记录在rem中,如果为NULL,表示不接收剩余时间
6. 申请堆内存
6.1 在堆上分配内存
#include <stdlib.h>
void *malloc(size_t size); // 在使用时通常需要强制类型转换,该函数不会初始化内存空间
void *calloc(size_t nmemb, size_t size); // 分配nmemb个单位长度为size的连续空间,并初始化为0,总的大小是nmemb*size
void *realloc(void *ptr, size_t size); // 可以在原有的空间上扩容
void free(void *ptr); // 释放堆内存空间
当进程终止时,会自动释放申请的空间,有时,因为加入了多次的 free() 调用,可能会消耗掉大量的 CPU 时间。但是依旧建议手动释放,否则容易发生内存泄漏。
6.2 在堆上分配对齐内存
#include <stdlib.h>
int posix_memalign(void **memptr, size_t alignment, size_t size);
void *aligned_alloc(size_t alignment, size_t size);
void *valloc(size_t size);// 不建议使用#include <malloc.h>
void *memalign(size_t alignment, size_t size); // 不建议使用
void *pvalloc(size_t size);
posix_memalign: 在堆上分配 size 个字节大小的对齐内存空间,将 *memptr 指向分配的空间。alignment 表示对其字节数,必须是 2 的幂次方,也是指针大小的整数倍。size 是分配的内存大小,如果为0,指向的空间值为NULL
aligned_alloc: 分配 size 个字节大小的内存空间,返回指向该空间的指针
valloc: 以 pagesize 页大小作为对齐的长度,可以通过 getpagesize() 获取页大小
7. proc 文件系统
是一个虚拟文件系统,它以文件系统的方式为应用层访问系统内核数据提供了接口,用户和应用程序可以通过 proc 文件系统得到系统信息和进程相关信息,对 proc 文件系统的读写作为与内核进行通信的一种手段。但是与普通文件不同的是,proc 文件系统是动态创建的,文件本身不存在于磁盘当中,只存在于内存中。该文件系统挂载在 /proc 目录下
7.1 使用cat命令读取
比如查看内核版本信息cat /proc/version
7.2 使用read读取
将你需要直到的信息读取到文件中
相关文章:

7. 系统信息与系统资源
7. 系统信息与系统资源 1. 系统信息1.1 系统标识 uname()1.2 sysinfo()1.3 gethostname()1.4 sysconf() 2. 时间、日期2.1 Linux 系统中的时间2.1.1 Linux 怎么记录时间2.1.2 jiffies 的引入 2.2 获取时间 time/gettimeofday2.2.1 time()2.2.2 gettimeofday() 2.3 时间转换函数…...
【重点】【滑动窗口】239. 滑动窗口最大值
题目 也可参考:剑指offer——面试题65:滑动窗口的最大值 class Solution {public int[] maxSlidingWindow(int[] nums, int k) {int[] res new int[nums.length - k 1];Deque<Integer> q new LinkedList<>();int inx 0;while (inx <…...

d3dx9_43.dll丢失原因以及5个解决方法详解
在电脑使用过程中,我们可能会遇到一些错误提示,其中之一就是“d3dx9_43.dll缺失”。这个错误提示通常表示我们的电脑上缺少了DirectX的一个组件,而DirectX是游戏和多媒体应用所必需的软件。本文将介绍d3dx9_43.dll缺失对电脑的影响以及其原因…...

Python实现FA萤火虫优化算法优化卷积神经网络分类模型(CNN分类算法)项目实战
说明:这是一个机器学习实战项目(附带数据代码文档视频讲解),如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 萤火虫算法(Fire-fly algorithm,FA)由剑桥大学Yang于2009年提出 , …...

不瞒各位,不安装软件也能操作Xmind文档
大家好,我是小悟 作为搞技术的一个人群,时不时就要接收产品经理发过来的思维脑图,而此类文档往往是以Xmind编写的,如果你的电脑里面没有安装Xmind的话,不好意思,是打不开这类后缀结尾的文档。 打不开的话…...
你了解Redis 的二进制安全吗
最近面试的时候被问到Redis 的二进制安全相关八股文面试题。Redis二进制安全内容比较多,以下是简单的总结大致的过程,需要深入学习的建议跳过 Redis是基于C语言进行开发的,而C语言中的字符串是二进制不安全的,所以Redis就没有直接…...

探索前端设计的新境界——介绍IVueUI工具助力Vue页面设计
在快速发展的前端领域,Vue.js作为一款渐进式JavaScript框架,一直备受开发者喜爱。然而,在Vue前端开发的旅程中,页面设计常常是一个不可避免的挑战。今天,我要向大家介绍一款令Vue前端开发者受益匪浅的工具——www.ivue…...
数据管理系统-week10-数据库安全
文章目录 前言一、什么是数据库安全?二、威胁三、对抗措施四、授权和认证五、访问控制(重点)自由访问控制(DAC)强制访问控制(MAC)补充一个贝尔-lapadula模型六、加密参考文献前言 数据库安全意味着保护数据库免受有意或无意的未经授权的访问,数据库安全需要保护数据库…...

MySQL笔记-第05章_排序与分页
视频链接:【MySQL数据库入门到大牛,mysql安装到优化,百科全书级,全网天花板】 文章目录 第05章_排序与分页1. 排序数据1.1 排序规则1.2 单列排序1.3 多列排序 2. 分页2.1 背景2.2 实现规则2.3 拓展 第05章_排序与分页 讲师&#…...

MySQL笔记-第02章_MySQL环境搭建
视频链接:【MySQL数据库入门到大牛,mysql安装到优化,百科全书级,全网天花板】 文章目录 第02章_MySQL环境搭建1. MySQL的卸载步骤1:停止MySQL服务步骤2:软件的卸载步骤3:残余文件的清理步骤4&am…...

★136. 只出现一次的数字(位运算)
136. 只出现一次的数字 这个题主要考察的知识点是位运算(这里是异或) 如果不要求空间复杂度为O(1),那有很多方法。但是这里有这样的要求。 可以通过位运算 的方法来实现。 异或运算 ⊕有以下三个性质: 任…...

阿里云效一键部署前后端
静态站点到OSS 阿里云-云效,阿里云企业级一站式 DevOps,可以免费使用(会限制人数、流水线数量等,个人项目够用了)。相关文章 CI 持续集成 - 阿里云云效 OSS 是对象存储的意思,一般一个项目对应一个 Bucke…...
【算法集训】基础数据结构:一、顺序表(上)
顺序表是最基础的数组结构,所有数据都按顺序存储。 第一题 1464. 数组中两元素的最大乘积 https://leetcode.cn/problems/maximum-product-of-two-elements-in-an-array/description/ 第一种:常规解法,遍历两次数组根据条件比较出最大的即可…...
封装websocket并在vuejs中调用
1、创建JS文件ce-websocket-util.js class CeWebsocketUtil {websocket null;reConnectTimes 0; // 失败后重新连接次数wsInterVal null; // 重新连接定时器maxReConnectTimes 10; // 最大连接次数,默认10次reIntervalTime 60 * 1000; // 重连间隔时间,默认1m…...

博捷芯:半导体芯片切割,一道精细工艺的科技之门
在半导体制造的过程中,芯片切割是一道重要的环节,它不仅决定了芯片的尺寸和形状,还直接影响到芯片的性能和使用效果。随着科技的不断进步,芯片切割技术也在不断发展,成为半导体制造领域中一道精细工艺的科技之门。 芯片…...

BiseNet实现遥感影像地物分类
遥感地物分类通过对遥感图像中的地物进行准确识别和分类,为资源管理、环境保护、城市规划、灾害监测等领域提供重要信息,有助于实现精细化管理和科学决策,提升社会治理和经济发展水平。深度学习遥感地物分类在提高分类精度、自动化程度、处理…...

【SpringBoot系列】SpringBoot时间字段格式化
💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...

.net core 连接数据库,通过数据库生成Modell
1、安装EF Core Power Tools:打开Vs开发工具→扩展→管理扩展 2、(切记执行这步之前确保自己的代码不存在编写或者编译错误!)安装完成后在你需要创建数据库实体的项目文件夹上面单击右键,找到EF Core 工具(必须安装扩展之和才会有…...
开发工具idea中推荐插件
主要是记录一下idea中实用插件,方便开发,换个电脑工作的时候也可以直接在市场中下载使用。 1、Easy Javadoc 自动生成javadoc文档注释,基本上是按照字段名或者方法名翻译的,还是相当好用的。 2、EasyYapi 可以快捷生成接口文档…...

[c++]—string类___深度学习string标准库成员函数与非成员函数
要相信别人能做出来自己一定可以做出来,只不过是时间没到而已 目录 🚩string类对象capacity操作 💻reserve()保留 💻resize() 🚩string类对象元素访问操作 💻operator[]和at() 💻operator…...

Chapter03-Authentication vulnerabilities
文章目录 1. 身份验证简介1.1 What is authentication1.2 difference between authentication and authorization1.3 身份验证机制失效的原因1.4 身份验证机制失效的影响 2. 基于登录功能的漏洞2.1 密码爆破2.2 用户名枚举2.3 有缺陷的暴力破解防护2.3.1 如果用户登录尝试失败次…...

.Net框架,除了EF还有很多很多......
文章目录 1. 引言2. Dapper2.1 概述与设计原理2.2 核心功能与代码示例基本查询多映射查询存储过程调用 2.3 性能优化原理2.4 适用场景 3. NHibernate3.1 概述与架构设计3.2 映射配置示例Fluent映射XML映射 3.3 查询示例HQL查询Criteria APILINQ提供程序 3.4 高级特性3.5 适用场…...

大数据零基础学习day1之环境准备和大数据初步理解
学习大数据会使用到多台Linux服务器。 一、环境准备 1、VMware 基于VMware构建Linux虚拟机 是大数据从业者或者IT从业者的必备技能之一也是成本低廉的方案 所以VMware虚拟机方案是必须要学习的。 (1)设置网关 打开VMware虚拟机,点击编辑…...

【第二十一章 SDIO接口(SDIO)】
第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...
Auto-Coder使用GPT-4o完成:在用TabPFN这个模型构建一个预测未来3天涨跌的分类任务
通过akshare库,获取股票数据,并生成TabPFN这个模型 可以识别、处理的格式,写一个完整的预处理示例,并构建一个预测未来 3 天股价涨跌的分类任务 用TabPFN这个模型构建一个预测未来 3 天股价涨跌的分类任务,进行预测并输…...
测试markdown--肇兴
day1: 1、去程:7:04 --11:32高铁 高铁右转上售票大厅2楼,穿过候车厅下一楼,上大巴车 ¥10/人 **2、到达:**12点多到达寨子,买门票,美团/抖音:¥78人 3、中饭&a…...

苍穹外卖--缓存菜品
1.问题说明 用户端小程序展示的菜品数据都是通过查询数据库获得,如果用户端访问量比较大,数据库访问压力随之增大 2.实现思路 通过Redis来缓存菜品数据,减少数据库查询操作。 缓存逻辑分析: ①每个分类下的菜品保持一份缓存数据…...
Python爬虫(二):爬虫完整流程
爬虫完整流程详解(7大核心步骤实战技巧) 一、爬虫完整工作流程 以下是爬虫开发的完整流程,我将结合具体技术点和实战经验展开说明: 1. 目标分析与前期准备 网站技术分析: 使用浏览器开发者工具(F12&…...
关于 WASM:1. WASM 基础原理
一、WASM 简介 1.1 WebAssembly 是什么? WebAssembly(WASM) 是一种能在现代浏览器中高效运行的二进制指令格式,它不是传统的编程语言,而是一种 低级字节码格式,可由高级语言(如 C、C、Rust&am…...

dify打造数据可视化图表
一、概述 在日常工作和学习中,我们经常需要和数据打交道。无论是分析报告、项目展示,还是简单的数据洞察,一个清晰直观的图表,往往能胜过千言万语。 一款能让数据可视化变得超级简单的 MCP Server,由蚂蚁集团 AntV 团队…...