• 【C++项目】高并发内存池第六讲 当申请内存大于256K时的处理


    项目源代码:高并发内存池

    1.申请过程

    当申请的内存大于256kb时直接向堆中申请:
    在这里插入图片描述

    static void* ConcurrentAlloc(size_t size)
    {
    	if (size > MAX_BYTES)
    	{
    		size_t alignSize = SizeClass::RoundUp(size);
    		size_t kpage = alignSize >> PAGE_SHIFT;
    		PageCache::GetInstance()->_pageMtx.lock();
    		Span* span = PageCache::GetInstance()->NewSpan(kpage);
    		span->_objSize = size;
    		PageCache::GetInstance()->_pageMtx.unlock();
    		void* ptr = (void*)(span->_pageId << PAGE_SHIFT);
    		return ptr;
    	}
    	else
    	{
    		//通过TLS每个线程无锁的获取自己专属的ThreadCache对象
    		if (pTLSThreadCache == nullptr)
    		{
    			
    			//pTLSThreadCache = new ThreadCache;
    			static ObjectPool<ThreadCache> tcPool;
    			pTLSThreadCache = tcPool.New();
    		}
    		//cout << "id:" << std::this_thread::get_id() << " pTLSThreadCache :" << pTLSThreadCache << endl;
    		return pTLSThreadCache->Allocate(size); 
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • NewSpan
      在这里插入图片描述
    //获取一个K页的span
    Span* PageCache::NewSpan(size_t k)
    {
    	assert(k > 0 );
    	//大于128页的直接向堆申请
    	if (k > NPAGES - 1)
    	{
    		void* ptr = SystemAlloc(k);
    		//Span* span = new Span;
    		Span* span = _spanPool.New();
    		span->_pageId = (PAGE_ID)ptr >> PAGE_SHIFT;
    		span->_n = k;
    		//_idSpanMap[span->_pageId] = span;
    		_idSpanMap.set(span->_pageId, span);
    		return span;
    	}
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    2.释放过程

    00

    static void ConcurrentFree(void* ptr)
    {
    	assert(pTLSThreadCache);
    	assert(ptr);
    	Span* span = PageCache::GetInstance()->MapObjectToSpan(ptr);
    	size_t size = span->_objSize;
    	if (size > MAX_BYTES)
    	{
    		
    		
    		PageCache::GetInstance()->_pageMtx.lock();
    		PageCache::GetInstance()->ReleaseSpanToPageCache(span);
    		PageCache::GetInstance()->_pageMtx.unlock();
    	}
    	else
    	{
    		pTLSThreadCache->Deallocate(ptr, size);
    	}
    
    	
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    00
    直接还给堆。

  • 相关阅读:
    Leetcode581. 最短无序连续子数组
    从此以后,将硬件接入大语言模型(LLM)将变得如此简单~
    计算机毕设(附源码)JAVA-SSM绩效考核管理系统
    牛客网刷题(四)
    JMETER 时间函数使用
    java游戏制作-飞翔的鸟游戏
    C++教程从入门到实战
    【数据结构】双向链表
    mysql与磁盘的关系
    计算机系统(18)----- 进程互斥的软件实现方法
  • 原文地址:https://blog.csdn.net/weixin_62892290/article/details/134089227