CN104571953A - 一种扩展进程中内存地址控制的方法 - Google Patents

一种扩展进程中内存地址控制的方法 Download PDF

Info

Publication number
CN104571953A
CN104571953A CN201410830319.7A CN201410830319A CN104571953A CN 104571953 A CN104571953 A CN 104571953A CN 201410830319 A CN201410830319 A CN 201410830319A CN 104571953 A CN104571953 A CN 104571953A
Authority
CN
China
Prior art keywords
internal memory
memory
block
module
sub
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201410830319.7A
Other languages
English (en)
Other versions
CN104571953B (zh
Inventor
李翔威
刘畅
谭贤亮
梁波
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Chengdu Xishanju Interactive Entertainment Technology Co Ltd
Zhuhai Kingsoft Digital Network Technology Co Ltd
Original Assignee
Zhuhai Kingsoft Online Game Technology Co Ltd
Chengdu Xishanju Interactive Entertainment Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Zhuhai Kingsoft Online Game Technology Co Ltd, Chengdu Xishanju Interactive Entertainment Technology Co Ltd filed Critical Zhuhai Kingsoft Online Game Technology Co Ltd
Priority to CN201410830319.7A priority Critical patent/CN104571953B/zh
Publication of CN104571953A publication Critical patent/CN104571953A/zh
Application granted granted Critical
Publication of CN104571953B publication Critical patent/CN104571953B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/062Securing storage systems
    • G06F3/0623Securing storage systems in relation to content
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Stored Programmes (AREA)

Abstract

本发明公开了一种扩展进程中内存地址控制的方法,主进程通过主分配器模块创建多个扩展进程,并由扩展进程中的次分配器模块分配实际的内存。所有内存不通过内存地址标识,而是通过一个全局唯一的内存ID标识。本发明在无需升级机器硬件和系统的前提下,仅通过改进软件即可充分的利用电脑的物理内存。且本方法通过扩展进程方式实现,使得单个进程所使用的物理内存总量没有上限。即便是在64位系统中,运用此方法的系统仍然可以正常运行。即通过此方法扩展内存不会产生兼容性问题。同时此方法的系统也能扩展64位系统的内存最大使用量。

Description

一种扩展进程中内存地址控制的方法
技术领域
 本发明涉及计算机内存分配的方法、特别是一种扩展进程中内存地址控制的方法。
背景技术
目前32位X86架构中CPU、内存控制器、操作系统都是按32位地址总线设计。32位地址总线可以支持的内存地址代码是 4096MB,也就是有4GB的地址代码。这4GB的地址码在操作系统层面对应叫做4GB的虚拟地址空间。这4GB的地址空间正好可以分配给4GB内存。因此,因此一个在32位系统下运行的进程,最多只能使用4GB以下的内存。
在32位系统地址空间不足这种限制条件下。即便是在一台拥有更高物理内存的电脑上(如8GB内存),一个进程也仅仅能申请出不到4GB的内存,这相当的不划算。
虽然x64架构的系统和电脑可以解决上述问题。但是在一些老的机器(如32位硬件的电脑)或是正在运营的软件产品上做这种升级成本相当之高。
发明内容
为解决上述问题,本发明的目的在于提供一种能通过软件的方式在32位系统使用4GB以上内存的扩展进程中内存地址控制的方法。
本发明解决其问题所采用的技术方案是:
一种扩展进程中内存地址控制的方法,包括主进程和由主进程创建的一个或以上的扩展进程,所述主进程包括原程序业务组件和第一扩展内存地址空间组件,所述第一扩展内存地址空间组件包括内存-进程映射模块和主分配器模块,所述扩展进程包括第二扩展内存地址空间组件和所扩展的内存地址空间,所述第二扩展内存地址空间组件包括内存-区块映射模块和次分配器模块,所述扩展进程通过扩展进程ID号唯一进行识别,内存地址空间内的内存通过内存ID号进行识别,每一段独立的内存对应一个独立的内存ID号,所述主分配器模块根据内存-进程映射模块维护内存ID与扩展进程ID的关系,所述次分配器模块通过内存-区块映射模块维护内存ID及其对应的内存区块的关系。
进一步,主进程中的内存-进程映射模块中维护了一个内存ID到扩展进程ID的映射表。其输入为内存ID,其输出为扩展进程的ID。
进一步,扩展进程中的内存-区块映射模块中维护了一个内存ID到区块的映射表。其输入为内存ID,其输出为区块信息。一个区块信息由地址、大小这样一个二元组组成,所述区块为内存ID对应的内存在本进程中地址空间的位置。
进一步,主进程中的主分配器模块以管道方式与扩展进程中的次分配器模块通讯,主分配器模块和次分配器模块配合完成内存分配、内存释放、内存读取、内存写入4个不同功能的操作。
具体地,内存分配的步骤为,主分配器模块接受业务逻辑发送过来的内存分配请求,并将请求的内存大小逐一发给各个扩展进程中的次分配器模块,若扩展进程可以分配出内存,则主分配器模块将内存ID,扩展进程ID的对应关系记录到内存-进程映射表中,若所有扩展进程都无法分配出内存,则主分配器模块将启动一个全新的扩展进程,并将分配请求传给这个全新的扩展进程的次分配器;接到主分配器发送过来的内存分配请求后:扩展进程中的次分配器模块如果可以分配出足量的内存,则会给这个内存块分配一个系统中的全局ID值,同时将内存ID、地址、大小记录到本扩展进程的内存-区块映射模块中,最后将内存ID传回给主分配器模块,若扩展进程中的次分配器模块无法分配出足量的内存,则会返回一个分配失败的返回值给主分配器模块。
具体地,内存释放的步骤为:业务逻辑将需要释放的内存ID发给主分配器模块,主分配器模块在内存-进程映射表中查找得到内存ID对应的扩展进程,主分配器模块将内存ID发送给扩展进程ID所对应的次分配器模块,次分配器模块在内存-区块映射模块中查找内存ID所对应的具体区块,即地址、大小这个二元组,删除地址所对应的扩展内存地址空间的内存块,并在内存-区域映射模块中删除内存ID及其所对应的区块信息。
具体地,内存读取的步骤为:业务逻辑将需要读取的内存、偏移值、读取大小发给主分配器模块,主分配器模块在内存-进程映射表中查找得到内存ID对应的扩展进程ID,主分配器模块将内存ID、偏移值、读取大小发送给扩展进程ID所对应的次分配器模块,次分配器模块在内存-区块映射模块中查找内存ID所对应的具体区块,即地址、大小这个二元组,次分配器模块将读取扩展进程中实际地址为 地址+偏移值 大小为读取大小的内存块返回给主分配器模块,主分配器模块将所读取的内存传回给业务逻辑,完成读取。
具体地,内存写入的步骤为:业务逻辑将需要写入的内存ID、偏移值、写入数据发给主分配器模块,主分配器模块在内存-进程映射表中查找得到内存ID对应的扩展进程ID,主分配器模块将内存ID、偏移值、写入数据发送给扩展进程ID所对应的次分配器模块,次分配器模块在内存-区块映射模块中查找内存ID所对应的具体区块,即地址、大小这个二元组,次分配器模块将写入数据写入到扩展进程中实际地址为地址+偏移值的内存,完成写入。
本发明的有益效果是:本发明采用的一种扩展进程中内存地址控制的方法,主进程通过主分配器模块创建多个扩展进程,并由扩展进程中的次分配器模块分配实际的内存。所有内存不通过内存地址标识,而是通过一个全局唯一的内存ID标识。其中内存ID、扩展进程、扩展进程内的内存区块三者之间的关系则通过内存-进程映射模块和内存-区域映射模块来维护。如此一来,虽然32位环境下每个进程仍然只有4GB的地址空间。但是由于可以动态的增长多个进程,且内存ID不像内存地址一样受到4GB地址空间的约束。因此可以不受限制的最大化物理内存的使用。
本发明在无需升级机器硬件和系统的前提下,仅通过改进软件即可充分的利用电脑的物理内存。且本方法通过扩展进程方式实现,使得单个进程所使用的物理内存总量没有上限。即便是在64位系统中,运用此方法的系统仍然可以正常运行。即通过此方法扩展内存不会产生兼容性问题。同时此方法的系统也能扩展64位系统的内存最大使用量。
附图说明
下面结合附图和实例对本发明作进一步说明。
图1是本发明中主进程和扩展进程的示意图;
图2是本发明内存-进程映射模块的示意图;
图3是本发明内存-区域映射模块的示意图;
图4是本发明内存分配的流程图;
图5是本发明内存释放过程的流程图;
图6是本发明内存读取过程的流程图;
图7是本发明内存写入过程的流程图。
具体实施方式
参照图1-图3,本发明的一种扩展进程中内存地址控制的方法,包括主进程和由主进程创建的一个或以上的扩展进程,所述主进程包括原程序业务组件和第一扩展内存地址空间组件,所述第一扩展内存地址空间组件包括内存-进程映射模块和主分配器模块,所述扩展进程包括第二扩展内存地址空间组件和所扩展的内存地址空间,所述第二扩展内存地址空间组件包括内存-区块映射模块和次分配器模块,所述扩展进程通过扩展进程ID号唯一进行识别,内存地址空间内的内存通过内存ID号进行识别,每一段独立的内存对应一个独立的内存ID号,所述主分配器模块根据内存-进程映射模块维护内存ID与扩展进程ID的关系,所述次分配器模块通过内存-区块映射模块维护内存ID及其对应的内存区块的关系。
参照图2所示,主进程中的内存-进程映射模块中维护了一个内存ID到扩展进程ID的映射表。其输入为内存ID,其输出为扩展进程的ID。
参照图3所示,扩展进程中的内存-区块映射模块中维护了一个内存ID到区块的映射表。其输入为内存ID,其输出为区块信息。一个区块信息由地址、大小这样一个二元组组成,所述区块为内存ID对应的内存在本进程中地址空间的位置。
具体地,主进程中的主分配器模块以管道方式与扩展进程中的次分配器模块通讯,主分配器模块和次分配器模块配合完成内存分配、内存释放、内存读取、内存写入4个不同功能的操作。
参照图4所示,所述内存分配的过程如下:
A1)业务逻辑将分配的内存大小需求发送给主分配器模块。
B1)主分配器模块将需求发送给第一个扩展进程的次分配器模块
C1)是否有这个扩展进程。如果没有这个扩展进程则主分配器模块创建一个新的扩展进程。并分配一个新的ID给这个扩展进程。
D1)次分配器模块收到分配需求后,在本进程中的扩展的内存地址空间中尝试分配内存。
E1)如果次分配器模块成功分配了内存,则给这个内存一个全局唯一的ID值(即内存ID)。并将内存ID以及分配成功后得到的{地址,大小},记录到内存-区块映射模块中。 如果次分配器模块无法在本进程中分配所需内存,则返回失败。
F1)如果主分配器模块接收到分配失败的返回值,则尝试在下一个扩展进程中进行内存分配。并返回到步骤c)。否则将得到的内存ID扩展进程ID的对应关系记录到内存-进程映射表中。
G1)最后主分配器模块将内存ID返回给业务逻辑。
例如,如业务逻辑需要100MB的内存。这个时候业务逻辑将这个100MB数值发送给主分配器模块,此时主分配器模块将100MB这个请求先发送给扩展进程ID=1的进程的次分配器模块。若此时进程ID=1的次分配器模块可以在此进程中分配出一个100MB的内存,则他会给这个内存分配一个全局唯一的ID值,并将此值返回给主分配器。主分配器最终将这个内存ID返回给业务逻辑。
参照图5所示,内存释放的过程如下:
A2)业务逻辑将需要释放的内存ID发给主分配器模块。
B2)主分配器模块在内存-进程映射表中查找得到内存ID对应的扩展进程ID。
C2)主分配器模块将内存ID发送给扩展进程ID所对应的次分配器模块。
D2)次分配器模块在内存-区块映射模块中查找内存ID所对应的具体区块,即{地址,大小}这个二元组。
E2)删除地址所对应的扩展的内存地址空间中的内存块。
F2)在内存-区域映射模块中删除内存ID及其所对应的区块信息。
G2)主分配器模块删除内存-进程映射模块内存ID对应的信息。
参照图6所示,内存读取的过程如下:
A3)业务逻辑将需要读取的{内存ID,偏移值,读取大小}发给主分配器模块。
B3)主分配器模块在内存-进程映射表中查找得到内存ID对应的扩展进程ID。
C3)主分配器模块将{内存ID,偏移值,读取大小}发送给扩展进程ID所对应的次分配器模块。
D3)次分配器模块在内存-区块映射模块中查找内存ID所对应的具体区块,即{地址,大小}这个二元组。
E3)次分配器模块将读取扩展进程中实际地址为 地址+偏移值 大小为读取大小的内存块返回给主分配器模块。
F3)主分配器模块将所读取的内存传回给业务逻辑,完成读取。
参照图7所示,内存写入的过程如下:
A4)业务逻辑将需要写入的{内存ID,偏移值,写入数据}发给主分配器模块。
B4)主分配器模块在内存-进程映射表中查找得到内存ID对应的扩展进程ID。
C4)主分配器模块将{内存ID,偏移值,写入数据}发送给扩展进程ID所对应的次分配器模块。
D4)次分配器模块在内存-区块映射模块中查找内存ID所对应的具体区块,即{地址,大小}这个二元组。
E4)次分配器模块将写入数据写入到扩展进程中实际地址为 地址+偏移值的内存,完成写入。
以下通过一个实施例对整个过程进行描述,架设一个系统启动后,原程序业务组件会先后做如下几个操作:1.分配一块100K的内存。2.将100K数据写入到内存中。3.读取100K中偏移值为50K,大小为50K的内存。4.释放这块内存。
内存分配的过程如下(可参考图4所示):
1.业务组件中的业务逻辑会向同进程中的主分配器模块申请100K的内存。
2.主分配器模块会将这个请求转发给第一个扩展进程。(即ID=1的扩展进程)
3.由于是第一次请求。系统中并没有任何扩展进程,因此主分配器模块会建立一个新的扩展进程。并将设置此扩展进程的ID=1。
4.ID=1的扩展进程收到这个请求后。在本进程的“扩展内存地址空间”中尝试分配内存。(即用普通方法分配一块内存)
5.由于是第一次分配,且100K是一个比较小的内存,扩展进程肯定可以分配得出来。因此内存会分配成功了。设这时候分配成功后得到的内存地址是500。
6. 次分配器为这个内存设置一个系统中全局唯一的ID值。由于系统中暂时没有其他的内存块,我们假设这次分配的ID值=1。
7.次分配器将{1,500,100k}这么一组数据记录到id=1的扩展进程中的“内存-区块映射表中”。(三元组的意义是{内存ID,地址,大小})
8.次分配器将“内存ID=1”这个信息返回给主分配器。即主分配器拿到了一个内存ID。
9.主分配器将{1,1}这么一组数据记录到“内存-进程映射表”中。(二元组对应{内存ID,扩展进程ID})。
10.最后主分配器将“内存ID”返回给业务逻辑。业务逻辑拿到这个ID后即可在后续过程中对内存中的信息进行读写或释放操作。分配过程完成。
内存写入的过程如下(可参考图7所示):
1.设此时业务逻辑需要将100K的某段数据写入到内存中。
2.业务逻辑将{1, 0, “具体写入的信息..长度是100K”}这个请求发给主分配器模块。(这个三元组中的信息对应{内存ID,偏移值,写入数据})。
3.主分配器模块在“内存-进程映射表”中查找内存ID=1的扩展进程ID。得到扩展进程ID=1.
4.主分配器通过管道将{1, 0, “具体写入的信息..长度是100K”}这个信息发给ID=1的扩展进程的次分配器。
5.次分配器得到这个消息后,在“内存-区块映射表”中查找内存ID=1所对应的区块信息。得到{500,100K}这么一个二元组。(即 地址= 500, 大小= 100K)。
6.次分配器将需要写入的内容“具体写入的信息..长度是100K”,写入到地址为500,大小为100K的内存区块中。
7.写入过程结束。
内存读取的过程如下(可参考图6所示):
1.设此时业务逻辑需要读取刚刚写入的100K中偏移值为50K,大小为50K的内存。
2.业务逻辑将{1,50K,50K}这个读取请求发送给“主分配器模块”。({内存ID,偏移值,读取大小})
3.“主分配器模块”在“内存-进程映射表”中搜索ID=1的内存。得到扩展进程ID=1这样一个结果。
4.“主分配器模块”通过管道将{1,50K,50K}发送给ID=1的扩展进程的次分配器。
5.扩展进程中的“次分配器模块”在“内存区域映射模块”中查找内存ID=1的内存的具体区域信息。得到{500,100K}这么一个信息。(即内存存储在扩展进程中 地址=500 大小=100K 的位置中)
6.将读取扩展进程中以500+50K为地址。50K为大小的这么一个区块。(即读取扩展进程中实际地址为 “地址+偏移值” 大小为“读取大小”的内存块)
7.“次分配器模块”将读取到的内容,通过管道主进程的“主分配器模块”。
8.“主分配器模块”将传回的内容传给业务逻辑。完成读取。
内存释放的过程如下(可参考图5所示):
1.当业务逻辑不再需要使用ID=1的这块内存时,其可以触发内存释放过程。
2.将所需要释放的内存ID=1发送给“主分配器模块”。
3.“主分配器模块”在“内存-进程映射表”中查找ID=1的内存块对应的扩展进程ID。得到扩展进程ID=1。
4.“主分配器模块”将内存ID=1发送给ID=1的扩展进程的“次分配器模块”。
5.扩展进程中的“次分配器模块”在“内存区域映射模块”中查找内存ID=1的内存的具体区域信息。得到{500,100K}这么一个信息。
6.“次分配器模块”释放地址=500, 大小= 100K的这个内存块。
7.“次分配器模块”删除“内存-区域映射模块”内存ID=1对应的信息。
8.“主分配器模块”删除“内存-进程映射模块”内存ID=1对应的信息。
以上所述,只是本发明的较佳实施例而已,本发明并不局限于上述实施方式,只要其以相同的手段达到本发明的技术效果,都应属于本发明的保护范围。

Claims (8)

1.一种扩展进程中内存地址控制的方法,其特征在于:包括主进程和由主进程创建的一个或以上的扩展进程,所述主进程包括原程序业务组件和第一扩展内存地址空间组件,所述第一扩展内存地址空间组件包括内存-进程映射模块和主分配器模块,所述扩展进程包括第二扩展内存地址空间组件和所扩展的内存地址空间,所述第二扩展内存地址空间组件包括内存-区块映射模块和次分配器模块,所述扩展进程通过扩展进程ID号唯一进行识别,内存地址空间内的内存通过内存ID号进行识别,每一段独立的内存对应一个独立的内存ID号,所述主分配器模块根据内存-进程映射模块维护内存ID与扩展进程ID的关系,所述次分配器模块通过内存-区块映射模块维护内存ID及其对应的内存区块的关系。
2.根据权利要求1所述的一种扩展进程中内存地址控制的方法,其特征在于:主进程中的内存-进程映射模块中维护了一个内存ID到扩展进程ID的映射表,其输入为内存ID,其输出为扩展进程的ID。
3.根据权利要求2所述的一种扩展进程中内存地址控制的方法,其特征在于:扩展进程中的内存-区块映射模块中维护了一个内存ID到区块的映射表,其输入为内存ID,其输出为区块信息,一个区块信息由地址、大小这样一个二元组组成,所述区块为内存ID对应的内存在本进程中地址空间的位置。
4.根据权利要求3所述的一种扩展进程中内存地址控制的方法,其特征在于:主进程中的主分配器模块以管道方式与扩展进程中的次分配器模块通讯,主分配器模块和次分配器模块配合完成内存分配、内存释放、内存读取、内存写入4个不同功能的操作。
5.根据权利要求4所述的一种扩展进程中内存地址控制的方法,其特征在于:内存分配的步骤为,主分配器模块接受业务逻辑发送过来的内存分配请求,并将请求的内存大小逐一发给各个扩展进程中的次分配器模块,若扩展进程可以分配出内存,则主分配器模块将内存ID,扩展进程ID的对应关系记录到内存-进程映射表中,若所有扩展进程都无法分配出内存,则主分配器模块将启动一个全新的扩展进程,并将分配请求传给这个全新的扩展进程的次分配器;接到主分配器发送过来的内存分配请求后:扩展进程中的次分配器模块如果可以分配出足量的内存,则会给这个内存块分配一个系统中的全局ID值,同时将内存ID、地址、大小记录到本扩展进程的内存-区块映射模块中,最后将内存ID传回给主分配器模块,若扩展进程中的次分配器模块无法分配出足量的内存,则会返回一个分配失败的返回值给主分配器模块。
6.根据权利要求4所述的一种扩展进程中内存地址控制的方法,其特征在于:内存释放的步骤为:业务逻辑将需要释放的内存ID发给主分配器模块,主分配器模块在内存-进程映射表中查找得到内存ID对应的扩展进程,主分配器模块将内存ID发送给扩展进程ID所对应的次分配器模块,次分配器模块在内存-区块映射模块中查找内存ID所对应的具体区块,即地址、大小这个二元组,删除地址所对应的扩展内存地址空间的内存块,并在内存-区域映射模块中删除内存ID及其所对应的区块信息。
7.根据权利要求4所述的一种扩展进程中内存地址控制的方法,其特征在于:内存读取的步骤为:业务逻辑将需要读取的内存、偏移值、读取大小发给主分配器模块,主分配器模块在内存-进程映射表中查找得到内存ID对应的扩展进程ID,主分配器模块将内存ID、偏移值、读取大小发送给扩展进程ID所对应的次分配器模块,次分配器模块在内存-区块映射模块中查找内存ID所对应的具体区块,即地址、大小这个二元组,次分配器模块将读取扩展进程中实际地址为 地址+偏移值 大小为读取大小的内存块返回给主分配器模块,主分配器模块将所读取的内存传回给业务逻辑,完成读取。
8.根据权利要求4所述的一种扩展进程中内存地址控制的方法,其特征在于:内存写入的步骤为:业务逻辑将需要写入的内存ID、偏移值、写入数据发给主分配器模块,主分配器模块在内存-进程映射表中查找得到内存ID对应的扩展进程ID,主分配器模块将内存ID、偏移值、写入数据发送给扩展进程ID所对应的次分配器模块,次分配器模块在内存-区块映射模块中查找内存ID所对应的具体区块,即地址、大小这个二元组,次分配器模块将写入数据写入到扩展进程中实际地址为地址+偏移值的内存,完成写入。
CN201410830319.7A 2014-12-25 2014-12-25 一种扩展进程中内存地址控制的方法 Active CN104571953B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201410830319.7A CN104571953B (zh) 2014-12-25 2014-12-25 一种扩展进程中内存地址控制的方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201410830319.7A CN104571953B (zh) 2014-12-25 2014-12-25 一种扩展进程中内存地址控制的方法

Publications (2)

Publication Number Publication Date
CN104571953A true CN104571953A (zh) 2015-04-29
CN104571953B CN104571953B (zh) 2017-10-17

Family

ID=53088138

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201410830319.7A Active CN104571953B (zh) 2014-12-25 2014-12-25 一种扩展进程中内存地址控制的方法

Country Status (1)

Country Link
CN (1) CN104571953B (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112100089A (zh) * 2020-07-30 2020-12-18 北京智行者科技有限公司 内存管理方法

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102455943A (zh) * 2010-10-19 2012-05-16 上海聚力传媒技术有限公司 一种基于内存池来进行数据共享的方法和计算机设备
CN102662775A (zh) * 2012-03-29 2012-09-12 奇智软件(北京)有限公司 一种进程通信方法和装置
CN102779076A (zh) * 2012-06-29 2012-11-14 奇智软件(北京)有限公司 一种浏览器中进程间通信的方法和装置
US20130297853A1 (en) * 2012-05-04 2013-11-07 International Business Machines Corporation Selective write-once-memory encoding in a flash based disk cache memory
CN103425592A (zh) * 2013-08-05 2013-12-04 大唐移动通信设备有限公司 一种多进程系统中的内存管理方法及装置
CN104123265A (zh) * 2013-04-26 2014-10-29 华为技术有限公司 一种众核间通信方法及系统
US20140344510A1 (en) * 2011-10-07 2014-11-20 Hitachi, Ltd. Storage system

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102455943A (zh) * 2010-10-19 2012-05-16 上海聚力传媒技术有限公司 一种基于内存池来进行数据共享的方法和计算机设备
US20140344510A1 (en) * 2011-10-07 2014-11-20 Hitachi, Ltd. Storage system
CN102662775A (zh) * 2012-03-29 2012-09-12 奇智软件(北京)有限公司 一种进程通信方法和装置
US20130297853A1 (en) * 2012-05-04 2013-11-07 International Business Machines Corporation Selective write-once-memory encoding in a flash based disk cache memory
CN102779076A (zh) * 2012-06-29 2012-11-14 奇智软件(北京)有限公司 一种浏览器中进程间通信的方法和装置
CN104123265A (zh) * 2013-04-26 2014-10-29 华为技术有限公司 一种众核间通信方法及系统
CN103425592A (zh) * 2013-08-05 2013-12-04 大唐移动通信设备有限公司 一种多进程系统中的内存管理方法及装置

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112100089A (zh) * 2020-07-30 2020-12-18 北京智行者科技有限公司 内存管理方法
CN112100089B (zh) * 2020-07-30 2023-08-01 重庆兰德适普信息科技有限公司 内存管理方法

Also Published As

Publication number Publication date
CN104571953B (zh) 2017-10-17

Similar Documents

Publication Publication Date Title
US20230145212A1 (en) Switch Device for Interfacing Multiple Hosts to a Solid State Drive
US20210004355A1 (en) Distributed storage system, distributed storage system control method, and storage medium
CN101221536B (zh) 嵌入式系统的内存管理方法及装置
CN102449607B (zh) 具有多个闪存封装的存储系统
CN104423894B (zh) 数据储存装置以及快闪存储器控制方法
US10503424B2 (en) Storage system
CN104572242A (zh) 一种扩展虚拟机磁盘空间的方法、装置及虚拟机系统
WO2015162758A1 (ja) ストレージシステム
JP2016510440A (ja) 複合型ストレージシステム及び記憶制御方法
CN109144406B (zh) 分布式存储系统中元数据存储方法、系统及存储介质
US11296905B2 (en) Management component transport protocol (MCTP) support for multiple bus segment groups
CN107239526A (zh) 文件系统实现方法、碎片整理方法、操作位置定位方法
WO2018138813A1 (ja) 計算機システム
CN102184145B (zh) 重启数据不丢失方法及装置
KR101579941B1 (ko) 가상머신 i/o 관리 방법 및 장치
CN104317734A (zh) 一种适用于slab的内存分配方法及装置
US8566541B2 (en) Storage system storing electronic modules applied to electronic objects common to several computers, and storage control method for the same
CN104461706A (zh) 一种将共享全局变量共享的方法和多处理装置
CN105589704A (zh) 一种加速虚拟机启动的方法及系统
TWI520152B (zh) 資料儲存裝置與快閃記憶體控制方法
CN107430546B (zh) 一种文件更新方法及存储设备
CN104571953A (zh) 一种扩展进程中内存地址控制的方法
CN105068896A (zh) 基于raid备份的数据处理方法及装置
CN104360956A (zh) 一种数据拷贝方法及装置
US10789209B2 (en) Method and apparatus to enable finer-grained, scalable allocation of storage in a data storage system

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
CP03 Change of name, title or address
CP03 Change of name, title or address

Address after: 519000 Room 102, 202, 302 and 402, No. 325, Qiandao Ring Road, Tangjiawan Town, high tech Zone, Zhuhai City, Guangdong Province, Room 102 and 202, No. 327 and Room 302, No. 329

Patentee after: Zhuhai Jinshan Digital Network Technology Co.,Ltd.

Patentee after: CHENGDU XISHANJU INTERACTIVE ENTERTAINMENT TECHNOLOGY Co.,Ltd.

Address before: 519000 Jinshan software building, 8 Lanshan lane, Jida Jingshan Hill Road, Zhuhai, Guangdong

Patentee before: ZHUHAI KINGSOFT ONLINE GAME TECHNOLOGY Co.,Ltd.

Patentee before: CHENGDU XISHANJU INTERACTIVE ENTERTAINMENT TECHNOLOGY Co.,Ltd.