memset初始化值的效率秒杀for循环

本文通过实验对比了使用memset和for循环初始化一亿数据时的性能差异,在相同条件下,memset仅耗时1ms,而for循环则耗时136ms。文中还提供了具体的C++实现代码及计时方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">在一亿数据的赋值下,memset使用了1ms,而for循环使用了136ms</span>



贴上代码:


#include <string.h>
#include <iostream>
#include <string>
#include <iostream>
#define MAXSIZE 10000
using namespace std;
#include <time.h>
#include <sys/timeb.h>
int get_time(string r)
{
    struct timeb rawtime;
    ftime(&rawtime);
    static int ms = rawtime.millitm;
    static unsigned long s = rawtime.time;
    int out_ms = rawtime.millitm - ms;
    unsigned long out_s = rawtime.time - s;
    if (out_ms < 0)
    {
        out_ms += 1000;
        out_s -= 1;
    }
    ms = rawtime.millitm;
    s = rawtime.time;
    int total = 1000*out_s+out_ms;
    cout<<r<<": "<<total<<"ms"<<endl;
    return total;
}


int main()
{
int (*arr)[MAXSIZE]=new int[MAXSIZE][MAXSIZE]; //MAXSIZE 10000
get_time("memset begin");
memset(arr,'9',sizeof(arr));
get_time("memset end");
get_time("for begin");
for(int i=0;i<MAXSIZE;++i)
for(int j=0;j<MAXSIZE;++j)arr[i][j]=99;
get_time("for end");
delete[] arr;
return 0;
}

转载于:https://www.cnblogs.com/freeopen/p/5482946.html

任务描述 本关任务:通过线程池实现高并发Socket通信,模拟高并发的秒杀过程,响应前100个用户的读取特定文件的请求。 相关知识 为了完成本关任务,你需要掌握:1.Socket编程,2.线程池,3.文件读写等。 Socket编程 网络中进程可以通过socket通信,socket起源于Unix,满足“一切皆文件”原理,即操作为“打开open->读写write/read->关闭close”。 ①socket的调用函数主要有: socket()/*创建描述符,设定协议域和socket类型*/ bind()/*绑定地址*/ listen()/*监听*/ connect()/*连接*/ read()/*I/O读操作*/ write()/*I/O写操作*/ close()/*断开连接*/ shutdown()/*部分断连*/ 详细内容请参考 Socket编程 线程池 简单线程池 1.简单的线程池数据结构 #include <stdio.h> #include <pthread.h> #include <stdlib.h> #include <string.h> #include <signal.h> #include <errno.h> #include <unistd.h> typedef struct { void *(*function)(void *); /*函数指针,回调函数*/ void *arg; /*上面函数的参数*/ } threadpool_task_t; /*各子线程任务结构体*/ typedef struct threadpool_s { pthread_mutex_t lock; /* 互斥锁 */ pthread_cond_t notify; /* 条件变量 */ pthread_t *threads; /* 线程数组的起始指针 */ threadpool_task_t *queue; /* 任务队列数组的起始指针 */ int thread_count; /* 线程数量 */ int queue_size; /* 任务队列长度 */ int head; /* 当前任务队列头 */ int tail; /* 当前任务队列尾 */ int count; /* 当前待运行的任务数 */ int shutdown; /* 线程池当前状态是否关闭 */ int started; /* 正在运行的线程数 */ } threadpool_t; 2.辅助函数 static void *threadpool_thread(void *threadpool);; /*线程池单个线程执行函数*/ int threadpool_free(threadpool_t *pool); /*释放线程池内存*/ 3.接口函数 threadpool_t *threadpool_create(int thread_count, int queue_size, int flags); /*创建线程池*/ int threadpool_add(threadpool_t *pool, void (*routine)(void *),void *arg, int flags); /*往线程池中添加任务*/ int threadpool_destroy(threadpool_t *pool, int flags);/*销毁线程池*/ 文件读写 文件读写常用函数为open()、lseek()、read()、write()等 详细内容请参考文件读写 测试说明 请根据提示,在右侧完成综合实践,平台会对你编写的代码进行测试。用c语言
最新发布
06-14
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值