Linux下打印封装_统计函数执行时间_线程号时间戳打印

统计函数执行时间(多线程环境下统计结果不准)
// 无返回值
#define FUNC_EXEC_TIME_NORET(fun,promote) ({ \
unsigned long long timeDelta = 0; \
struct timespec t1 = {0}; \
struct timespec t2 = {0}; \
clock_gettime(CLOCK_MONOTONIC, &t1); \
fun; \
clock_gettime(CLOCK_MONOTONIC, &t2); \
timeDelta = (unsigned long long)(t2.tv_sec1000 + t2.tv_nsec/1000000) - (unsigned long long)(t1.tv_sec1000 + t1.tv_nsec/1000000); \
printf(“%s %lld \n”, promote, timeDelta); \
})

// 有返回值
#define FUNC_EXEC_TIME_WITHRET(fun,promote,ret) ({ \
typeof(ret) status1; \
unsigned long long timeDelta = 0; \
struct timespec t1 = {0}; \
struct timespec t2 = {0}; \
clock_gettime(CLOCK_MONOTONIC, &t1); \
status1 = fun; \
clock_gettime(CLOCK_MONOTONIC, &t2); \
timeDelta = (unsigned long long)(t2.tv_sec1000 + t2.tv_nsec/1000000) - (unsigned long long)(t1.tv_sec1000 + t1.tv_nsec/1000000); \
printf(“%s %llu \n”, promote, timeDelta); \
status1; \
})

#define DEBUG_BUFFER_MAX_LENGTH (512)
/// 当前打印中增加线程号和时间戳打印
void PRINT_EX(const char* format, …)
{
char buffer[DEBUG_BUFFER_MAX_LENGTH]={0};
pid_t tid = 0;
tid = syscall(SYS_gettid);
unsigned long long jiffer = 0;
struct timeval val = {0};
gettimeofday(&val, NULL);
jiffer = (unsigned long long)val.tv_sec * 1000 + (unsigned long long)val.tv_usec / 1000;
va_list arg;
va_start (arg, format);
vsnprintf(buffer, DEBUG_BUFFER_MAX_LENGTH, format, arg);
va_end (arg);
printf( “tid:%d jiffer:%llu %s”, tid, jiffer, buffer);
}

宏测试
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/time.h>
#include <time.h>
#include <syscall.h>
#include <stdarg.h>
void fun1(int a, int b)
{
int c = a + b;
sleep(3);
}

int fun2(int a, int b)
{
int c = a + b;
sleep(5);
return c;
}

void fun3()
{
sleep(2);
}

int main(int argc, char *argv[])
{
int ret = 0;
FUNC_EXEC_TIME_NORET(fun1(3,4),“fun1”);
ret = FUNC_EXEC_TIME_WITHRET(fun2(3,4),“fun2”,ret);
PRINT_EX(“fun3 start\n”);
fun3();
PRINT_EX(“fun3 end\n”);
}
在这里插入图片描述

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

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

相关文章

web3规则改变者:Linea的厉害之处

Linea 的厉害之处 想象一下&#xff0c;Linea 就像是一条神奇的高速公路&#xff0c;它让开车&#xff08;在这里指的是交易&#xff09;变得更快、更便宜&#xff0c;而且还很舒服。Linea 是由一个叫 Consensys 的大公司建造的&#xff0c;它用了一些超级酷的技术&#xff0c…

托盘图标结构体TBBUTTON和TRAYDATA相关说明文章记录

1、托盘图标管理器与跨进程SendMessage &#xff1a;http://www.qingfengju.com/article.asp?id294 2、TrayData 结构详解&#xff1a;http://llll123cccc.blog.163.com/blog/static/316586420105864647151/ 3、Shell Tray Info - Arrange your system tray icons&#xff1…

高考分数查询结果自动推送至微信(卷II)

祝各位端午节安康&#xff01;只要心中无结&#xff0c;每天都是节&#xff0c;开心最重要&#xff01; 在上一篇文章高考分数查询结果自动推送至微信&#xff08;卷Ⅰ&#xff09;-CSDN博客中谈了思路&#xff0c;今天具体实现。文中将敏感信息已做处理&#xff0c;读者根据自…

从零开始精通Onvif之获取设备信息

&#x1f4a1; 如果想阅读最新的文章&#xff0c;或者有技术问题需要交流和沟通&#xff0c;可搜索并关注微信公众号“希望睿智”。 与设备交互的第一步 发现设备之后&#xff0c;与设备进行交互的第一步&#xff0c;是连接上设备&#xff0c;并获取设备的信息。连接设备&#…

FiRa标准之认证流程

在实现FiRa MAC时需要考虑其兼容性&#xff0c;同时对外部而言&#xff0c;如何证明一个UWB设备是否满足FiRa的规范要求&#xff0c;就需要通过一定的组织对相应的设备进行检测、认证。 为此&#xff0c;FiRa联盟已经建立了国际认证程序&#xff0c;制定了验证待检设备&#x…

React+TS前台项目实战(四)-- layout整体布局搭建

文章目录 前言一、Layout组件代码注释说明二、Content全局组件注释说明三、Header基础布局组件1. Header父级组件注释说明2. NavMenu导航子组件详细说明 四、效果展示总结 前言 本文主要讲Layout整体布局的构建以及全局内容盒子Content组件的使用。还包括了导航栏组件的基本封…

【QT】QT6.3新特性,以及使用技巧

Qt 6.3作为Qt框架的一个重要更新&#xff0c;引入了许多新特性和改进&#xff0c;以提高开发效率和应用程序性能。以下是一些使用Qt 6.3的技巧和最佳实践&#xff1a; 利用新模块和特性&#xff1a; 了解并利用Qt 6.3中新增的模块和特性&#xff0c;例如Qt Quick 3D、Qt PDF等&…

未来几年,同样的性能,推理功耗降低为现在的几万分之一,有可能吗

未来几年,同样的性能,推理功耗降低为现在的几万分之一,有可能吗 一.数据二.抓取LLM排行榜,相同的MMLU精度,模型参数量缩减倍数三.其它 有人说未来几年,推理功耗能降低为现在的几万分之一,好奇怎么能做到呢 一.数据 二.抓取LLM排行榜,相同的MMLU精度,模型参数量缩减倍数 import…

spool 管道 小文件 mknod

Spool File In SQL*PLUS in Multiple Small Files ? (Doc ID 2152654.1)​编辑To Bottom In this Document Goal Solution APPLIES TO: Oracle Database - Enterprise Edition - Version 10.2.0.1 to 12.1.0.2 [Release 10.2 to 12.1] Oracle Database Cloud Schema Service…

从零开始搭建Electron项目之运行例程

最好的学习方式就是&#xff1a;给一段能够运行的代码示例。 本文给出了例程资源&#xff0c;以及运行的步骤。 在国内开发electron有一点特别不好&#xff0c;就是如果不爬梯子&#xff0c;下载依赖容易出错。 一、例程资源 到如下路径下载例程到本地。 GitCode - 全球开发者…

32、matlab:基于模板匹配的车牌识别

1、准备工作 1&#xff09;准备材料 车牌字符模板和测试的实验车牌 2&#xff09;车牌字符模板 数字、字母和省份缩写 3&#xff09;测试车牌 四张测试车牌 2、车牌识别实现(已将其嵌入matlab) 1&#xff09;打开APP 找到APP 找到我的APP双击点开 2)界面介绍 包括&am…

C语言考试内容

C语言考试通常会涵盖以下几个主要方面&#xff1a; 1. **基本概念**&#xff1a; - C语言的历史和特点 - C语言的编译过程 - 程序的基本结构&#xff08;包括预处理指令、主函数main()、函数定义等&#xff09; 2. **数据类型和运算符**&#xff1a; - 基本数据类…

一起学习Linux内核模块的知识,为编写复杂的设备驱动做好准备

一、Linux内核模块简介 Linux内核的整体架构非常庞大&#xff0c;包含的组件非常多&#xff0c;如果把所有的功能都编译到内核&#xff0c;有导致生成的内核映像越来越大&#xff0c;同时如果我们要修改现有内核的功能&#xff0c;需要重编内核&#xff0c;效率很低。 有没有…

【网络安全的神秘世界】web应用程序安全与风险

&#x1f31d;博客主页&#xff1a;泥菩萨 &#x1f496;专栏&#xff1a;Linux探索之旅 | 网络安全的神秘世界 | 专接本 第一章&#xff1a;web应用程序安全与风险 web攻击基础知识 1、什么是web应用攻击 web攻击的本质&#xff0c;就是通过http协议篡改应用程序&#xff0…

c#自定义ORM框架-实体类扩展属性

步骤一、建立扩展属性类 实体类扩展属性要继承Attribute基类完成 步骤二、创建实体类并引用扩展实体类属性 Attributes属性定义&#xff0c;主要标明表名和主键名字 /// <summary> /// 表名 /// </summary> [AttributeUsage(AttributeTargets.Class)] [System.S…

蓝牙安全入门——两道CTF题目复现

文章目录 蓝牙安全入门题目 low_energy_crypto获取私钥解密 题目 蓝牙钥匙的春天配对过程配对方法密钥分发数据加密安全漏洞和保护实际应用实际应用 蓝牙安全入门 &#x1f680;&#x1f680;最近一直对车联网比较感兴趣&#xff0c;但是面试官说我有些技术栈缺失&#xff0c;所…

==Redis淘汰策略(内存满了触发)==

好的&#xff0c;面试官。这个问题我需要从三个方面来回答。第一个方面&#xff1a; 当 Redis 使用的内存达到 maxmemory 参数配置的阈值的时候&#xff0c;Redis 就会根据配置的内存淘汰策略。 把访问频率不高的 key 从内存中移除。maxmemory 默认情况是当前服务器的最大内存…

html5实现个人网站源码

文章目录 1.设计来源1.1 网站首页页面1.2 个人工具页面1.3 个人日志页面1.4 个人相册页面1.5 给我留言页面 2.效果和源码2.1 动态效果2.2 目录结构 源码下载 作者&#xff1a;xcLeigh 文章地址&#xff1a;https://blog.csdn.net/weixin_43151418/article/details/139564407 ht…

Golang | Leetcode Golang题解之第141题环形链表

题目&#xff1a; 题解&#xff1a; func hasCycle(head *ListNode) bool {if head nil || head.Next nil {return false}slow, fast : head, head.Nextfor fast ! slow {if fast nil || fast.Next nil {return false}slow slow.Nextfast fast.Next.Next}return true }

unity到小游戏instantGame(流程演示,非内容制作 亲测可用)

unity到小游戏instantGame&#xff08;开发流程演示&#xff0c;非内容制作 亲测可用&#xff09; 写在前面直接 写在前面 instantGame 后妈级教学&#xff0c;主打一个填自己的坑&#xff0c;有问题下方评论交流 根据此教程使用后的一点心得记录和可能出现的问题补充&#xf…