memset和bzero性能分析

22 篇文章 0 订阅
首先,我们需要了解bzero和memset的功能。

bzero是一个非标准函数,用于将一块内存区域的内容设置为0。它的原型如下:

void *bzero(void *s, size_t n);

其中,s是要设置的内存区域的起始地址,n是要设置的字节数。

memset是一个函数,用于将一块内存区域的内容设置为指定的值。它的原型如下:

void *memset(void *s, int c, size_t n);

其中,s是要设置的内存区域的起始地址,c是要设置的值(以整数形式表示),n是要设置的字节数。

接下来,我们可以通过以下代码来比较bzero和memset的性能:
#include <stdio.h>
#include <time.h>
#include <string.h>

#define SIZE 1024 * 1024
//#define SIZE 1024 * 512 
//#define SIZE 1024 * 256
//#define SIZE 1024 * 128
//#define SIZE 1024 * 64
//#define SIZE 1024 * 32
//#define SIZE 1024 * 16
//#define SIZE 1024


int main()
 {
    char buffer[SIZE];
    char zeroed_buffer[SIZE];
    char set_value = 'A';

    // 使用bzero填充buffer
    clock_t start = clock();
    bzero(buffer, SIZE);
    clock_t end = clock();
    double bzero_time = (double)(end - start) / CLOCKS_PER_SEC;

    // 使用memset填充buffer
    clock_t start2 = clock();
    memset(buffer,set_value, SIZE);
    clock_t end2 = clock();
    double memset_time = (double)(end2 - start2) / CLOCKS_PER_SEC;

    printf("\nbzero time: %f seconds\n", bzero_time);
    printf("\nmemset time: %f seconds\n", memset_time);

    return 0;
}
运行结果:
1MB
512KB
256KB
128KB
64KB

32KB
16KB
2KB
1KB

这段代码首先定义了一个大小从1KB至1MB的字符数组buffer,然后分别使用bzero和memset对其进行填充。针对每个不同大小的字符数组,通过计算两个操作的执行时间,我们可以得出它们之间的性能差异。

结论:

我们根据本示例的代码运行得到的结果可以看出:

(1)字符数组大小为2KB的时候,memset和bzero两者的性能相同;

(2)字符数组的大小小于2KB的时候,bzero性能高于memset;

(3)字符数组的大小大于2KB的时候,bzero性能低于memset。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

编码小哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值