基本信息
源码名称:C++实现高并发内存池
源码大小:7.12KB
文件格式:.rar
开发语言:C/C++
更新时间:2019-06-12
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
使用C 语言,实现高并发内存池
使用C 语言,实现高并发内存池
void BenchmarkMalloc(size_t ntimes, size_t nworks, size_t rounds) { std::vector<std::thread> vthread(nworks); size_t malloc_costtime = 0; size_t free_costtime = 0; for (size_t k = 0; k < nworks; k) { vthread[k] = std::thread([&, k]() { std::vector<void*> v; v.reserve(ntimes); for (size_t j = 0; j < rounds; j) { size_t begin1 = clock(); for (size_t i = 0; i < ntimes; i ) { v.push_back(malloc(16)); } size_t end1 = clock(); size_t begin2 = clock(); for (size_t i = 0; i < ntimes; i ) { free(v[i]); } size_t end2 = clock(); v.clear(); malloc_costtime = end1 - begin1; free_costtime = end2 - begin2; } }); } for (auto& t : vthread) { t.join(); } printf("%u个线程并发执行%u轮次,每轮次malloc %u次: 花费:%u ms\n", nworks, rounds, ntimes, malloc_costtime); printf("%u个线程并发执行%u轮次,每轮次free %u次: 花费:%u ms\n", nworks, rounds, ntimes, free_costtime); printf("%u个线程并发malloc&free %u次,总计花费:%u ms\n", nworks, nworks*rounds*ntimes, malloc_costtime free_costtime); } // 单轮次申请释放次数 线程数 轮次 void BenchmarkConcurrentMalloc(size_t ntimes, size_t nworks, size_t rounds) { std::vector<std::thread> vthread(nworks); size_t malloc_costtime = 0; size_t free_costtime = 0; for (size_t k = 0; k < nworks; k) { vthread[k] = std::thread([&]() { std::vector<void*> v; v.reserve(ntimes); for (size_t j = 0; j < rounds; j) { size_t begin1 = clock(); for (size_t i = 0; i < ntimes; i ) { v.push_back(ConcurrentAlloc(16)); } size_t end1 = clock(); size_t begin2 = clock(); for (size_t i = 0; i < ntimes; i ) { ConcurrentFree(v[i],sizeof(v[i])); } size_t end2 = clock(); v.clear(); malloc_costtime = end1 - begin1; free_costtime = end2 - begin2; } }); } for (auto& t : vthread) { t.join(); } printf("%u个线程并发执行%u轮次,每轮次concurrent alloc %u次: 花费:%u ms\n", nworks, rounds, ntimes, malloc_costtime); printf("%u个线程并发执行%u轮次,每轮次concurrent dealloc %u次: 花费:%u ms\n", nworks, rounds, ntimes, free_costtime); printf("%u个线程并发concurrent alloc&dealloc %u次,总计花费:%u ms\n", nworks, nworks*rounds*ntimes, malloc_costtime free_costtime); } int main() { cout << "==========================================================" << endl; BenchmarkMalloc(100000, 4, 10); cout << endl << endl; BenchmarkConcurrentMalloc(100000, 4, 10); cout << "==========================================================" << endl; system("pause"); return 0; }