[C语言] memset的效率分析

测试100M(1亿)个元素的初始化时间长度作为效率对比参考值。CPU: Intel [email protected]

最后封装一个优化后的自定义双字节memset函数。

cpp 复制代码
typedef unsigned char      uint8_t;
typedef unsigned short     uint16_t;
typedef unsigned int       uint32_t;
typedef unsigned long long uint64_t;

#define MAX_SIZE (1024*1024*100)  //100MiByte
uint8_t pBuff[MAX_SIZE] = { 0 };
      
    uint64_t len = MAX_SIZE;
    uint16_t value = 0x1234;    
    uint8_t ch_High = value >> 8;
    uint8_t ch_Low  = value&0xFF;
  
    //测试1:传统for运行耗时47ms  
    for (uint64_t i = 0; i < len/2; i++)
    {
       pBuff[i] = ch_High;
       pBuff[i+1] = ch_Low;
    }
    //测试2:指针for运行耗时31ms  
    uint8_t* pt = pBuff;
    for (uint64_t i = 0; i < len/2; i ++ )
    {
        *(uint16_t*)pt = value;
        pt += 2;
     }

//通过以上测试可以看出用指针赋值比传统数组赋值快51%
//故有优化后的my_memset函数,用于初始化双字节函数。

void my_memset(uint8_t *buf,uint16_t value,uint64_t len)
{
    for (uint64_t i = 0; i < len/2; i ++)
    {
        *(uint16_t*)buf = value;//关键:指针类型的转换
        buf += 2;
    }   
}


//整体测试使用
void main()
{
    uint8_t testData[10] = { 0 };

    my_memset(testData, 0x1234, sizeof(testData));

    for (size_t i = 0; i < sizeof(testData); i++)
    {
        printf("%02x ",testData[i]);
    }
}

//最终输出:34 12 34 12 34 12 34 12 34 12
相关推荐
liuyang-neu14 分钟前
java内存模型JMM
java·开发语言
int型码农21 分钟前
数据结构第八章(一) 插入排序
c语言·数据结构·算法·排序算法·希尔排序
我很好我还能学2 小时前
【面试篇 9】c++生成可执行文件的四个步骤、悬挂指针、define和const区别、c++定义和声明、将引用作为返回值的好处、类的四个缺省函数
开发语言·c++
蓝婷儿2 小时前
6个月Python学习计划 Day 16 - 面向对象编程(OOP)基础
开发语言·python·学习
渣渣盟2 小时前
基于Scala实现Flink的三种基本时间窗口操作
开发语言·flink·scala
学习噢学个屁3 小时前
基于STM32语音识别柔光台灯
c语言·stm32·单片机·嵌入式硬件·语音识别
糯米导航3 小时前
Java毕业设计:办公自动化系统的设计与实现
java·开发语言·课程设计
糯米导航3 小时前
Java毕业设计:WML信息查询与后端信息发布系统开发
java·开发语言·课程设计
MessiGo3 小时前
Javascript 编程基础(5)面向对象 | 5.1、构造函数实例化对象
开发语言·javascript·原型模式
大霞上仙3 小时前
nonlocal 与global关键字
开发语言·python