C++中的内存分配
std::allocator<T>
std::vector<T>
template<class T>
class vector
{
public:
vector():elements(),first_free(),end(){}
void push_back(const T&);
//…
private:
static std::allocator<T> alloc;
void reallocate();
T* elements;
T* first_free;
T* end;
//…
};
std::vector<T>::push_back(const T& t)
template <class T>
void vector<T>::push_back(const T& t)
{
//are we out of space
if(first_free == end)
reallocate();// gets more space and copies existing elements to it
alloc.construct(first_free,t);
++first_free;
}
template <class T>
void vector<T>::reallocate()
{
std::ptrdiff_t size = first_free – elements;
std::ptrdiff_t newcapacity = * max(size,); T* newelements = alloc.allocate(newcapacity); uninitialized_copy(elements,first_free,newelements); for(T *p = first_free; p != elements;}
alloc.destroy(--p); if(elements)
alloc.deallocate(elements,end-elements);
elements = newelements;
first_free = elements + size;
end = elements + newcapacity;
}
operator new 函数和 operator delete 函数
//new expression
string *sp =new string(“initialized”);首先,该表达式调用名为 operator new 的标准库函数,分配足够大的原始的未类型化的内存;
delete sp;
首先,对 sp 指向的对象运行适当的析构函数;
operator new 和 operator delete 接口
void*operator new(size_t);
void*operator new[](size_t);
void*operator new(std::size_t size,void* ptr)throw();//placement void*operator delete(void*);
void*operator delete[](void*);
placement new 定位 new 表达式
std::allocator<std::string> alloc;
string *sp = alloc.allocate();// allocate space to hold 2 strings
new(sp) string(b,e);
alloc.construct(sp +, string(b,e));
类特定的 new 和 delete
一个内存分配器基类
template<class T>
class CachedObj
{
public:
void* operator new(std::size_t);
void* operator delete(void*, std::size_t);
virtual ~CachedObj(){}
protected:
T* next;
private:
static void add_to_freelist(T*);
static std::allocator<T> alloc_mem;
static T* freeStore;
static const std::size_t chunk;
}
template<class T>
void*CachedObj<T>::operator new(size_t sz)
{
if(sz != sizeof(T)) return nullptr;
if(!freeStore)
{
T* array = alloc_mem.allocate(chunk);
for(size_t i =; i != chunk;++i)
add_to_freelist(&array[i]);
}
T*p = freeStore;
freeStore = freeSore->CachedObj<T>::next;
return p;
}
template<class T>
void CachedObj<T>::add_to_freelist(T*p)
{
p->CachedObj<T>::next = freeStore;
freeStore = p;
}
template<class T>
void CachedObj<T>::operator delete(void*p)
{
if(p != )
add_to_freelist(static_cast<T*>(p));
}
template<classType>
class QueueItem:
publicCachedObj<QueueItem<Type>>{};
C++中的内存分配的更多相关文章
- C语言中的内存分配与释放
C语言中的内存分配与释放 对C语言一直都是抱着学习的态度,很多都不懂,今天突然被问道C语言的内存分配问题,说了一些自己知道的,但感觉回答的并不完善,所以才有这篇笔记,总结一下C语言中内存分配的主要内容 ...
- rt-thread中动态内存分配之小内存管理模块方法的一点理解
@2019-01-18 [小记] rt-thread中动态内存分配之小内存管理模块方法的一点理解 > 内存初始化后的布局示意 lfree指向内存空闲区首地址 /** * @ingroup Sys ...
- Java基础-Java中的内存分配与回收机制
Java基础-Java中的内存分配与回收机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一. 二.
- java中子类实例化过程中的内存分配
知识点: 子类继承父类之后,实例化子类时,内存中子类是如何分配内存的呢? 下面,自己会结合一个例子,解释一下,一个子类实例化过程中,内存是如何分配的 参考博客:http://www.cnblogs.c ...
- Java实例化对象过程中的内存分配
Java实例化对象过程中的内存分配: https://blog.csdn.net/qq_36934826/article/details/82685791 问题引入这里先定义一个很不标准的“书”类,这 ...
- Netty 中的内存分配浅析
Netty 出发点作为一款高性能的 RPC 框架必然涉及到频繁的内存分配销毁操作,如果是在堆上分配内存空间将会触发频繁的GC,JDK 在1.4之后提供的 NIO 也已经提供了直接直接分配堆外内存空间的 ...
- Netty 中的内存分配浅析-数据容器
本篇接续前一篇继续讲 Netty 中的内存分配.上一篇 先简单做一下回顾: Netty 为了更高效的管理内存,自己实现了一套内存管理的逻辑,借鉴 jemalloc 的思想实现了一套池化内存管理的思路: ...
- C语言中动态内存分配的本质是什么?
摘要:C语言中比较重要的就是指针,它可以用来链表操作,谈到链表,很多时候为此分配内存采用动态分配而不是静态分配. 本文分享自华为云社区<[云驻共创]C语言中动态内存分配的本质>,作者: G ...
- iOS程序中的内存分配 栈区堆区全局区
在计算机系统中,运行的应用程序的数据都是保存在内存中的,不同类型的数据,保存的内存区域不同.一.内存分区 栈区(stack) 由编译器自动分配并释放,存放函数的参数值,局部变量等.栈是系统数据结构,对 ...
- c++中函数中变量内存分配以及返回指针、引用类型的思考
众所周知,我们在编程的时候经常会在函数中声明局部变量(包括普通类型的变量.指针.引用等等). 同时,为了满足程序功能的需要,函数的返回值也经常是指针类型或是引用类型,而这返回的指针或是引用也经常指向函 ...
随机推荐
- G 小石的图形
题目链接:https://ac.nowcoder.com/acm/contest/949/G 思路: 思路是很简单,一个小学数学题.但是n次WA后才过,重点就在pi的表示上,pi最精确的表示方式是ac ...
- php单例模式的常见应用场景
单例模式(Singleton)也叫单态模式,是设计模式中最为简单的一种模式,甚至有些模式大师都不称其为模式,称其为一种实现技巧,因为设计模式讲究对象之间的关系的抽象,而单例模式只有自己一个对象,也因此 ...
- Dubbo与Nginx微服务架构
Dubbo的负载均衡已经是服务层面的了,和nginx的负载均衡还在http请求层面完全不同.至于二者哪个优秀,当然没办法直接比较. 涉及到负载均衡就涉及到你的业务,根据业务来选择才是最适合的. dub ...
- Python自动化之数据驱动(转载下自己的日常练习笔记)
一.execl数据驱动 1.xlutils简要说明 导包:pip3 install xlutils 注意⚠️:xlutils在介些Execl文件的时候,只识别.xls后缀的文件,如果是.xlsx后缀的 ...
- python实现经典冒泡算法
利用for循环,完成a=[1,7,4,89,34,2]的冒泡排序 冒泡排序:小的排在前,大的排在后面
- Python实现线程交替打印字符串
import threading con = threading.Condition() word = u"12345上山打老虎" def work(): global word ...
- 微软亚洲研究院开源图数据库GraphView
我们很高兴地宣布,由微软亚洲研究院系统算法组开发的图数据库GraphView通过GitHub平台开源.GraphView是一款中间件软件,方便用户使用关系数据库SQL Server 或Azure SQ ...
- HDU 5894 hannnnah_j’s Biological Test【组合数学】
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5894 题意: 一个圆桌上有$n$个不同的位置,$m$个相同的人安排到这$n$个位置上,要求两人相邻的 ...
- 能源科技,苹果和Google的新圣战?
细心的果粉可能会注意到,最新版本的IOS软体中,增加了一个不起眼的按钮,它是一款署名为"家庭"的App,之所以说它不起眼,是因为它好像真得没什么用,活跃率恐怕不及Wechat的万分 ...
- Python第一周基本语句学习整理
目录 Python第一周基本语句学习整理 一.字符串切割 二.体重单位转换 三.计算器的实现 四.猜年龄游戏 Python第一周基本语句学习整理 一.字符串切割 代码实现: s = 'luowenxi ...