39. clock_getres - 获取时钟精度

函数介绍

clock_getres系统调用用于获取指定时钟的精度(分辨率)。它返回时钟能够表示的最小时间间隔。

函数原型

#include <time.h>int clock_getres(clockid_t clk_id, struct timespec *res);

功能

获取指定时钟的精度,即能够表示的最小时间间隔。

参数

  • clockid_t clk_id: 时钟ID
  • struct timespec *res: 指向timespec结构体的指针,用于存储精度信息

返回值

  • 成功时返回0
  • 失败时返回-1,并设置errno

特似函数

  • clock_gettime(): 获取时钟时间
  • gettimeofday(): 获取系统时间

示例代码

#define _GNU_SOURCE
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <errno.h>
#include <string.h>int main() {struct timespec res;int result;printf("=== Clock_getres 函数示例 ===\n");// 示例1: 获取各种时钟的精度printf("\n示例1: 不同时钟的精度\n");// CLOCK_REALTIMEresult = clock_getres(CLOCK_REALTIME, &res);if (result == -1) {printf("  CLOCK_REALTIME精度获取失败: %s\n", strerror(errno));} else {printf("  CLOCK_REALTIME精度: %ld.%09ld 秒\n", res.tv_sec, res.tv_nsec);printf("  即: %ld 纳秒\n", res.tv_nsec);}// CLOCK_MONOTONICresult = clock_getres(CLOCK_MONOTONIC, &res);if (result == -1) {printf("  CLOCK_MONOTONIC精度获取失败: %s\n", strerror(errno));} else {printf("  CLOCK_MONOTONIC精度: %ld.%09ld 秒\n", res.tv_sec, res.tv_nsec);printf("  即: %ld 纳秒\n", res.tv_nsec);}// CLOCK_PROCESS_CPUTIME_IDresult = clock_getres(CLOCK_PROCESS_CPUTIME_ID, &res);if (result == -1) {printf("  CLOCK_PROCESS_CPUTIME_ID精度获取失败: %s\n", strerror(errno));} else {printf("  CLOCK_PROCESS_CPUTIME_ID精度: %ld.%09ld 秒\n", res.tv_sec, res.tv_nsec);printf("  即: %ld 纳秒\n", res.tv_nsec);}// CLOCK_THREAD_CPUTIME_IDresult = clock_getres(CLOCK_THREAD_CPUTIME_ID, &res);if (result == -1) {printf("  CLOCK_THREAD_CPUTIME_ID精度获取失败: %s\n", strerror(errno));} else {printf("  CLOCK_THREAD_CPUTIME_ID精度: %ld.%09ld 秒\n", res.tv_sec, res.tv_nsec);printf("  即: %ld 纳秒\n", res.tv_nsec);}// 示例2: 错误处理演示printf("\n示例2: 错误处理演示\n");// 使用无效的时钟IDresult = clock_getres(999, &res);if (result == -1) {if (errno == EINVAL) {printf("  无效时钟ID错误处理正确: %s\n", strerror(errno));}}// 使用NULL指针result = clock_getres(CLOCK_REALTIME, NULL);if (result == 0) {printf("  NULL指针参数被接受(用于查询时钟是否存在)\n");}// 示例3: 时钟类型说明printf("\n示例3: 支持的时钟类型\n");printf("CLOCK_REALTIME: 系统实时钟\n");printf("  - 可以被设置和调整\n");printf("  - 受NTP和手动调整影响\n");printf("  - 用于获取当前时间\n\n");printf("CLOCK_MONOTONIC: 单调时钟\n");printf("  - 不会倒退\n");printf("  - 不受系统时间调整影响\n");printf("  - 用于测量时间间隔\n\n");printf("CLOCK_PROCESS_CPUTIME_ID: 进程CPU时间\n");printf("  - 测量进程使用的CPU时间\n");printf("  - 通常有较高精度\n\n");printf("CLOCK_THREAD_CPUTIME_ID: 线程CPU时间\n");printf("  - 测量线程使用的CPU时间\n");printf("  - 用于性能分析\n\n");// 示例4: 精度对比printf("示例4: 不同时钟精度对比\n");clockid_t clocks[] = {CLOCK_REALTIME,CLOCK_MONOTONIC,CLOCK_PROCESS_CPUTIME_ID,CLOCK_THREAD_CPUTIME_ID};const char *clock_names[] = {"CLOCK_REALTIME","CLOCK_MONOTONIC","CLOCK_PROCESS_CPUTIME_ID","CLOCK_THREAD_CPUTIME_ID"};for (int i = 0; i < 4; i++) {if (clock_getres(clocks[i], &res) == 0) {printf("  %-25s: %10ld ns\n", clock_names[i], res.tv_nsec);}}// 示例5: 实际应用演示printf("\n示例5: 实际应用演示\n");printf("时钟精度对程序设计的影响:\n");// 演示高精度计时struct timespec start, end, diff;if (clock_getres(CLOCK_MONOTONIC, &res) == 0) {printf("  使用CLOCK_MONOTONIC进行高精度计时:\n");printf("  理论精度: %ld 纳秒\n", res.tv_nsec);// 进行简单计时演示if (clock_gettime(CLOCK_MONOTONIC, &start) == 0) {// 执行一些操作volatile int sum = 0;for (int i = 0; i < 1000; i++) {sum += i;}if (clock_gettime(CLOCK_MONOTONIC, &end) == 0) {// 计算时间差if (end.tv_nsec < start.tv_nsec) {diff.tv_sec = end.tv_sec - start.tv_sec - 1;diff.tv_nsec = 1000000000 + end.tv_nsec - start.tv_nsec;} else {diff.tv_sec = end.tv_sec - start.tv_sec;diff.tv_nsec = end.tv_nsec - start.tv_nsec;}printf("  实际测量时间: %ld.%09ld 秒\n", diff.tv_sec, diff.tv_nsec);}}}// 示例6: 性能考虑printf("\n示例6: 性能考虑\n");printf("不同精度时钟的性能特点:\n");printf("1. 高精度时钟通常开销较大\n");printf("2. 需要在精度和性能间平衡\n");printf("3. 选择合适的时钟类型很重要\n");printf("4. 避免不必要的高精度要求\n\n");printf("时钟选择建议:\n");printf("- 一般计时: CLOCK_REALTIME\n");printf("- 性能测量: CLOCK_MONOTONIC\n");printf("- CPU使用率: CLOCK_PROCESS_CPUTIME_ID\n");printf("- 线程性能: CLOCK_THREAD_CPUTIME_ID\n\n");printf("总结:\n");printf("clock_getres用于查询时钟精度\n");printf("不同类型的时钟有不同的精度\n");printf("了解时钟精度有助于正确使用计时函数\n");printf("合理选择时钟类型可以提高程序性能\n");return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/91055.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/91055.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/91055.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MCU+RTOS调试

1. 引言在做项目时&#xff0c;百分之三十的时间写代码&#xff0c;还有百分之70的时间用于调试。本期将以Keil为例进行调试章节的讲解&#xff0c;目的在于做出一个标准化的调试步骤&#xff0c;方便大家学习如何调试代码。内容分为基础调试、中级调试及进阶调试三部分&#x…

Redis的数据淘汰策略是什么?有哪些?

1.监测设置了TTL的数据volatile-lru&#xff1a;淘汰最近最少使用的数据volatile-lfu&#xff1a;淘汰最近使用次数最少的数据volatile-ttl&#xff1b;淘汰将要过期的数据volatile-random&#xff1a;随机淘汰2.监测全库数据allkeys-lru&#xff1a;淘汰最近最少使用的数据all…

相控阵波束跃度指向误差Matlab仿真

波束跃度影响&#xff1a;TR芯片移相器位数、阵元数量、校准后阵元初始相位、TR芯片移相器精度、波控计算精度等。用MATLAB进行TR芯片移相器位数、阵元数量对指向误差进行仿真。 close all; %线阵波束跃度仿真 20250726 %beam displacement % 波束跃度影响&#xff1a;TR芯片移…

板凳-------Mysql cookbook学习 (十二--------6)

MySQL 8 导入二进制文件(trailer.ogv)操作指南 在MySQL中导入二进制文件(如trailer.ogv视频文件)通常有几种方法&#xff0c;我将详细介绍每种方法的操作步骤。 方法一&#xff1a;使用LOAD_FILE函数导入BLOB字段 这是最直接的方法&#xff0c;适合中小型二进制文件。sql - 1. …

昇思学习营-【模型推理和性能优化】学习心得_20250730

一、权重的加载 模型包含两部分&#xff1a; base model 和 LoRA adapter 其中base model的权重在微调时被冻结&#xff0c; 推理时加载原权重即可&#xff0c;LoRA adapter可通过PeftModel.from_pretrained进行加载。 二、启动推理 通过model.generate&#xff0c;启动推理…

[AI8051U入门第十一步]W5500-服务端

学习目标: 1、连接TCP/IP 2、学习W5500作为服务端代码一、TCP/IP介绍 TCP/IP 协议栈介绍 TCP/IP(Transmission Control Protocol / Internet Protocol)是互联网通信的核心协议族,定义了数据如何在网络中进行传输和路由。它由多个协议组成,采用分层架构,确保不同设备之间…

C 标准库 <time.h> 函数详解

目录 概述 1 核心数据类型 1.1 time_t 1.2 clock_t 1.3 struct tm 1.4 size_t 2 核心函数 2.1 时间获取函数 2.2 时间转换函数 2.3 时间差计算 2.4 时间格式化函数 3 线程安全版本&#xff08;POSIX 扩展&#xff09; 3.1 函数列表 3.2 时间处理完整示例 4 重要…

基于BEKK-GARCH模型的参数估计、最大似然估计以及参数标准误估计的MATLAB实现

基于BEKK-GARCH模型的参数估计、最大似然估计以及参数标准误估计的MATLAB实现。BEKK-GARCH模型是一种多变量GARCH模型&#xff0c;用于估计多个时间序列的条件方差和协方差矩阵。 MATLAB实现BEKK-GARCH模型 1. 准备数据 假设你已经有一个时间序列数据矩阵 returns&#xff0c;每…

TDengine 中 TDgpt 用于异常检测

介绍 TDgpt 内置时序数据异常检测模型 TDengine 中定义了异常&#xff08;状态&#xff09;窗口来提供异常检测服务。异常窗口可以视为一种特殊的事件窗口&#xff08;Event Window&#xff09;&#xff0c;即异常检测算法确定的连续异常时间序列数据所在的时间窗口。与普通事件…

统计学08:概率分布

一、随机变量随机变量是一个将 随机事件 映射到 数值 的数学函数&#xff0c;用于描述事件的结果。随机变量可以是离散的&#xff08;如骰子&#xff09;或连续的&#xff08;如人的身高、体重&#xff09;。1&#xff09;概率质量函数PMF——离散随机变量P(X x) 对应于某个值…

vue3【组件封装】消息反馈 S-msgWin.vue (针对父容器对齐,左右居中,可自定义顶部距离)

最终效果成功的提示报错的提示代码实现components/SUI/S-msgWin.vue <script lang"ts" setup> const props defineProps({msg: {type: Object,required: true,},top: {type: String,default: "50%",},duration: {type: Number,default: 3000,}, });…

MySQL 8.0.42创建MGR集群

MySQL 8.0.42创建MGR集群 概述 关于MySQL MGR集群的介绍就不在这里做详细的介绍了&#xff0c;大家可以自己到官网上查看阅读。在这里主要是实际操作方面的内容 总体结构设计如下图服务器节点信息序号角色IP地址数据库端口MGR端口1主节点192.168.56.1043309100612从节点192.168…

《Go Web编程实战派--从入门到精通》的随笔笔记

第二章 Go Web 开发基础2.1第一个Go Web 程序package mainimport ("fmt""net/http" )func hello(w http.ResponseWriter, r *http.Request) {fmt.Fprintf(w, "Hello World") } func main() {server : &http.Server{Addr: "0.0.0.0:80&q…

MySQL在Linux环境下的性能调优

&#x1f4ca; MySQL性能基准测试&#xff1a;知己知彼建立性能基线的关键指标# 核心性能指标监控脚本 #!/bin/bash echo " MySQL Performance Baseline " mysql -e "SHOW GLOBAL STATUS LIKE Questions;" mysql -e "SHOW GLOBAL STATUS LIKE Uptime;…

PyQt事件处理机制深度指南:超越信号与槽的底层掌控

—— 5大核心策略实战案例&#xff0c;解锁GUI交互的底层密码 &#x1f50d; 事件与信号槽的本质差异维度事件处理机制信号与槽机制抽象层级操作系统消息的原始封装对事件的高级封装应用场景控件行为定制/底层交互常规业务逻辑绑定执行顺序先于信号槽触发在事件处理完成后触发性…

10_opencv_分离颜色通道、多通道图像混合

split() 通道分离 void cv::split(const Mat & src,Mat * mvbegin ) merge() 通道合并 void cv::merge(InputArrayOfArrays mv,OutputArray dst ) Mat::at()方法 Mat::at()方法返回一个引用到指定的数组元素。 注意是引用&#xff0c;相当于两者等价&#xff0c;也就是…

Kotlin的datetime库

kotlinx 是一组不是 Kotlin 标准库一部分&#xff0c;但非常实用的扩展项目集合。其中&#xff0c;kotlinx-datetime 是一个跨平台的 Kotlin 时间日期处理库。 如何在项目中使用该库 Gradle 项目中 在 repositories 块中添加 Maven Central 仓库&#xff1a; repositories {…

基于模型蒸馏的大模型文案生成最佳实践

背景 大语言模型在生成高质量文案方面表现优异&#xff0c;然而其巨大的计算资源消耗和存储需求&#xff0c;使得实际应用尤其是在资源受限场景中的应用充满挑战。企业在寻求高效的文案生成时&#xff0c;常常面临着在性能和资源之间权衡的困境。在这种背景下&#xff0c;模型…

调用通义千问大模型实现流式对话

前言 我使用的是硅基流动中通义千问免费的大模型&#xff1a;我的技术栈使用的 Next14.2 全栈框架。 代码结构 需要使用的库&#xff1a; npm i ai openai目录结构&#xff1a; 基础测试页面 test-openai/page.tsx&#xff1a; use client;import { useChat } from ai/react;ex…

如何搭建Linux环境下的flink本地集群

第一步&#xff0c;搭建Linux环境 这里我使用的是 WSL2 安装前&#xff0c;先用管理员打开终端&#xff0c;执行以下三条命令&#xff0c;目的是开启安装 WSL2所需要的环境 //开启适用于windows的Linux子系统 dism.exe /online /enable-feature /featurename:Microsoft-Wind…