目录一、brk()系统调用1、brk()的申请方式2、brk()系统调用的优缺点3、brk()系统调用的优化二、mmap()系统调用1、mmap基础概念2、mmap内存映射原理3、mmap优点4、适用场景我们知道malloc()并不是系统调用,也不是运算符,而是C库里的函数,用于动态分配内存。malloc申请内存的时候,会有两种方式向操作系统申请堆内存:方式一:通过brk()系统调用从堆分配内存方式二:通过mmap()系统调用在文件映射区域分配内存;一、brk()系统调用1、brk()的申请方式一般如果用户分配的内存小于128KB,则通过brk()申请内存。而brk()的实现的方式很简单,就是
本文参考书:操作系统真像还原 什么是malloc?malloc是用户态申请内存时使用的函数。 malloc在哪里申请?堆中。 什么是堆?程序运行过程中需要申请额外的内存都会在堆中分配,堆中的内存分为几个规格类型的块用链表保存,程序需要内存就分配一个大于等于所需内存大小的块。如果一个规格的块用完了就像系统申请页,再将页切分成规格块的大小一个一个用链表链接起来。 如何找到堆?一般堆在进程pcb处有指针,内核的堆可以是一个全局变量。 由以上几个问题我们可以知道,只要先搞定堆后,malloc的作用就是在堆中拿个内存块就好啦。 堆的结构图 堆的核心结构是个数组u_block_desc 代表用户堆,放
本文参考书:操作系统真像还原 什么是malloc?malloc是用户态申请内存时使用的函数。 malloc在哪里申请?堆中。 什么是堆?程序运行过程中需要申请额外的内存都会在堆中分配,堆中的内存分为几个规格类型的块用链表保存,程序需要内存就分配一个大于等于所需内存大小的块。如果一个规格的块用完了就像系统申请页,再将页切分成规格块的大小一个一个用链表链接起来。 如何找到堆?一般堆在进程pcb处有指针,内核的堆可以是一个全局变量。 由以上几个问题我们可以知道,只要先搞定堆后,malloc的作用就是在堆中拿个内存块就好啦。 堆的结构图 堆的核心结构是个数组u_block_desc 代表用户堆,放
1smartpointer思想 个人认为smartpointer实际上就是一个对原始指针类型的一个封装类,并对外提供了->和*两种操作,使得其能够表现出原始指针的操作行为。 要理解smartpointer思想首先要了解一个概念RAII(ResourceAcquisitionIsInitialization),直译为资源获取即初始化,核心理念为在对象创建时分配资源,而在对象销毁时释放资源. 根据RAII理念,如果对象创建在栈(stack)上,由于栈上的对象在销毁是会自动调用析构函数,因此仅仅需要在构造函数内完成资源分配,而在析构函数内完成资源释放,此时程序员就不需要自己关心资源的释放
1smartpointer思想 个人认为smartpointer实际上就是一个对原始指针类型的一个封装类,并对外提供了->和*两种操作,使得其能够表现出原始指针的操作行为。 要理解smartpointer思想首先要了解一个概念RAII(ResourceAcquisitionIsInitialization),直译为资源获取即初始化,核心理念为在对象创建时分配资源,而在对象销毁时释放资源. 根据RAII理念,如果对象创建在栈(stack)上,由于栈上的对象在销毁是会自动调用析构函数,因此仅仅需要在构造函数内完成资源分配,而在析构函数内完成资源释放,此时程序员就不需要自己关心资源的释放
C++11智能指针shared_ptrWrittenon2023-01-16个人学习智能指针记录合集:C++11智能指针C++11智能指针shared_ptrC++11智能指针unique_ptrC++11智能指针weak_ptrstd::shared_ptr共享智能指针,也被称为计数智能指针。共享智能指针会记录有多少个共享智能指针指向同一个对象,当这个数为0的时候,程序自动的默认释放(析构)这个对象,记录有多少个的这个方法叫做引用计数。共享智能指针可以有多个共享智能指针同时管理同一个对象。举个栗子普通指针管理#include#includeusingnamespacestd;classPer
C++11智能指针shared_ptrWrittenon2023-01-16个人学习智能指针记录合集:C++11智能指针C++11智能指针shared_ptrC++11智能指针unique_ptrC++11智能指针weak_ptrstd::shared_ptr共享智能指针,也被称为计数智能指针。共享智能指针会记录有多少个共享智能指针指向同一个对象,当这个数为0的时候,程序自动的默认释放(析构)这个对象,记录有多少个的这个方法叫做引用计数。共享智能指针可以有多个共享智能指针同时管理同一个对象。举个栗子普通指针管理#include#includeusingnamespacestd;classPer
对于提供了MMU(存储管理器,辅助操作系统进行内存管理,提供虚实地址转换等硬件支持)的处理器而言,Linux提供了复杂的存储管理系统,使得进程所能访问的内存达到4GB。 进程的4GB内存空间被人为的分为两个部分--用户空间与内核空间。用户空间地址分布从0到3GB(PAGE_OFFSET,在0x86中它等于0xC0000000),3GB到4GB为内核空间。 区别如下:1、kmalloc和vmalloc是分配的是内核的内存,malloc分配的是用户的内存2、kmalloc保证分配的内存在物理上是连续的,内存只有在要被DMA访问的时候才需要物理上连续,malloc和vmalloc保证的是在虚拟地址空
对于提供了MMU(存储管理器,辅助操作系统进行内存管理,提供虚实地址转换等硬件支持)的处理器而言,Linux提供了复杂的存储管理系统,使得进程所能访问的内存达到4GB。 进程的4GB内存空间被人为的分为两个部分--用户空间与内核空间。用户空间地址分布从0到3GB(PAGE_OFFSET,在0x86中它等于0xC0000000),3GB到4GB为内核空间。 区别如下:1、kmalloc和vmalloc是分配的是内核的内存,malloc分配的是用户的内存2、kmalloc保证分配的内存在物理上是连续的,内存只有在要被DMA访问的时候才需要物理上连续,malloc和vmalloc保证的是在虚拟地址空
项目中的dao层,我们用来查询数据库,获取想要数据。有时我们会需要查询数据给结构体赋值,并返回一个结构体指针,如下//结构体字段已与数据库对应funcGetCommunity(idint)(community*model.CommunityDetail,errerror){ sql:=`selectcommunity_id,community_name,introductionfromcommunitywherecommunity_id=?` err=db.Get(&community,sql,id) iferr!=nil{ return } return}这样的代码看似没有问题,但其实并不