术语 | virtualallocex |
释义 | VirtualAllocEx 语法: C++ LPVOID WINAPI VirtualAllocEx( __in HANDLE hProcess, __in_opt LPVOID lpAddress, __in SIZE_T dwSize, __in DWORD flAllocationType, __in DWORD flProtect ); VirtualAllocEx函数 Reserves or commits a region of memory within the virtual address space of a specified process.该函数初始化内存分配为零,除非MEM_RESET使用。 要指定的物理内存NUMA节点,见VirtualAllocExNuma。 参数 hProcess [in] 句柄的进程。函数分配在这一进程的虚拟地址空间的内存。 句柄必须有PROCESS_VM_OPERATION访问权。有关更多信息,请参见过程的安全性和访问权限。 lpAddress [中,可选] 指针,指定所需的起点区域的网页地址,您想分配。 如果您是保留内存,功能轮到这个地址的分配粒度最近的倍数。 如果您犯的内存已经预留,该函数发到这个地址最近的页面边界。要确定在主机上的页面大小和粒度的分配,使用的GetSystemInfo函数。 如果lpAddress为NULL,则函数确定如何分配该地区。 dwSize [in] 该内存区域的大小分配,以字节为单位。 如果lpAddress为NULL,则函数轮dwSize到下一个页面边界。 如果lpAddress不是NULL,该函数分配的所有页面中包含由lpAddress到lpAddress的一个或更多的字节+ dwSize。这意味着,例如,一个2字节范围跨越1页边界导致函数分配两个网页。 flAllocationType [in] 内存分配的类型。此参数必须包含下列值之一。 ValueMeaning MEM_COMMIT 0x1000Allocates物理存储在内存中,或在指定保留在磁盘上的内存页分页文件。该函数初始化内存为0。 为了保留和提交一步,调用MEM_COMMIT VirtualAllocEx | MEM_RESERVE页。 函数失败如果您尝试提交一个尚未被预留页面。由此产生的错误代码是ERROR_INVALID_ADDRESS。 企图犯下一个已经承诺不会导致函数失败页面。这意味着您可以提交首先确定每一页的页当前状态的承诺。 MEM_RESERVE 0x2000Reserves没有分配任何实际的物理存储在内存或磁盘上的分页文件的进程的虚拟地址空间范围。 您提交保留通过调用MEM_COMMIT VirtualAllocEx再次网页。为了保留和提交一步,调用MEM_COMMIT VirtualAllocEx | MEM_RESERVE页。 其他的内存分配功能,如malloc和LocalAlloc,不能使用保留的内存,直到它已被释放。 MEM_RESET 0x80000Indicates的数据由lpAddress和dwSize指定的内存范围已不再感兴趣。该网页不应该读出或写入页面文件。但是,内存块将再次使用以后,因此不应该decommitted。此值不能用于任何其他值。 使用此值不保证范围与MEM_RESET将包含零操作。如果您想范围包含零,承诺解除的内存,然后再次作出它。 当您使用MEM_RESET的VirtualAllocEx函数忽略了fProtect价值。但是,您仍然必须设置fProtect为有效保护的价值,如PAGE_NOACCESS。 VirtualAllocEx返回一个错误如果您使用MEM_RESET和范围的内存映射到一个文件中。甲共同的看法是唯一可以接受的,如果它映射到一个页面文件。 此参数还可以指定下列值所示。 ValueMeaning MEM_LARGE_PAGES 0x20000000Allocates使用大内存页支持。 大小和对齐方式必须是大页的最低倍数。要获得此值,使用GetLargePageMinimum功能。 Windows XP/2000操作系统:这个标志是不支持。 MEM_PHYSICAL 0x400000Reserves一个地址范围,可用于映射地址窗口扩展(AWE)的网页。 此值必须与MEM_RESERVE,没有其他值。 MEM_TOP_DOWN 0x100000Allocates在尽可能高的内存地址。 flProtect [in] 对于该地区的页面内存保护分配。如果网页被承诺,您可以指定任何内存保护常量之一。 返回值 如果函数成功,返回值是分配的页面地区基址。 如果函数失败,返回值为NULL。为了获得更多错误信息,调用GetLastError。 备注 每一页都有一个关联的页面的状态。该VirtualAllocEx函数可以执行以下操作: 凯明地区保留的网页 储备区域自由页 同时保留和提交的免费网页地区 VirtualAllocEx不能保留保留网页。它可以提交一个已经承诺页面。这意味着您可以提交的页面范围,不论他们是否已经承诺,而功能也不会失败。 您可以使用VirtualAllocEx保留的网页块,然后作出进一步要求VirtualAllocEx实施从预留屏蔽个人网页。这使得一个进程,消耗体能储备不存储其虚拟地址空间范围,直到需要它。 如果lpAddress参数不是NULL,则函数使用lpAddress和dwSize参数来计算的页面区域分配。在整个的页面范围现状必须符合由参数指定的flAllocationType分配类型。否则,函数失败并没有的网页分配。这种兼容性要求,并不排除犯已经承诺页,见前面的列表。 若要执行动态生成的代码,使用VirtualAllocEx分配内存和VirtualProtectEx职能,授予PAGE_EXECUTE访问。 该VirtualAllocEx函数可用于保留在一个特定进程的虚拟地址空间的地址窗口扩展(AWE)的内存区域。这种内存区域可以被用来映射到的虚拟内存不足的应用程序所需的物理页。在MEM_PHYSICAL和MEM_RESERVE值必须设置在AllocationType参数。该MEM_COMMIT值不能被设置。该网页的保护必须设置为PAGE_READWRITE。 该VirtualFreeEx函数可以承诺解除一个坚定的网页,发布页面的存储,也可以同时承诺解除和释放一个坚定的页面。它也可以释放保留的网页,使其成为一个自由页面。 要求: 最低支持:client-Windows 2000专业版 最低支持server-Windows 2000服务器 HeaderWinbase.h(头文件:winuser.h) LibraryKernel32.lib DLLKernel32.dll 参见 内存管理功能 ReadProcessMemory的 虚拟内存函数 VirtualAllocExNuma VirtualFreeEx VirtualLock VirtualProtect VirtualQuery WriteProcessMemory的 如果有任何问题和意见,请发送给微软(wsddocfb@microsoft.com) 生成日期:2009年8月27日 ==英文原文==VirtualAllocEx Function Reserves or commits a region of memory within the virtual address space of a specified process. The function initializes the memory it allocates to zero, unless MEM_RESET is used. To specify the NUMA node for the physical memory, see VirtualAllocExNuma . Syntax C++ LPVOID WINAPI VirtualAllocEx( __in HANDLE hProcess, __in_opt LPVOID lpAddress, __in SIZE_T dwSize, __in DWORD flAllocationType, __in DWORD flProtect ); Parameters hProcess [in] The handle to a process. The function allocates memory within the virtual address space of this process. The handle must have the PROCESS_VM_OPERATION access right. For more information, see Process Security and Access Rights . lpAddress [in, optional] The pointer that specifies a desired starting address for the region of pages that you want to allocate. If you are reserving memory, the function rounds this address down to the nearest multiple of the allocation granularity. If you are committing memory that is already reserved, the function rounds this address down to the nearest page boundary. To determine the size of a page and the allocation granularity on the host computer, use the GetSystemInfo function. If lpAddress is NULL, the function determines where to allocate the region. dwSize [in] The size of the region of memory to allocate, in bytes. If lpAddress is NULL, the function rounds dwSize up to the next page boundary. If lpAddress is not NULL, the function allocates all pages that contain one or more bytes in the range from lpAddress to lpAddress+dwSize. This means, for example, that a 2-byte range that straddles a page boundary causes the function to allocate both pages. flAllocationType [in] The type of memory allocation. This parameter must contain one of the following values. ValueMeaning MEM_COMMIT 0x1000Allocates physical storage in memory or in the paging file on disk for the specified reserved memory pages. The function initializes the memory to zero. To reserve and commit pages in one step, call VirtualAllocEx with MEM_COMMIT | MEM_RESERVE. The function fails if you attempt to commit a page that has not been reserved. The resulting error code is ERROR_INVALID_ADDRESS. An attempt to commit a page that is already committed does not cause the function to fail. This means that you can commit pages without first determining the current commitment state of each page. MEM_RESERVE 0x2000Reserves a range of the process's virtual address space without allocating any actual physical storage in memory or in the paging file on disk. You commit reserved pages by calling VirtualAllocEx again with MEM_COMMIT. To reserve and commit pages in one step, call VirtualAllocEx with MEM_COMMIT |MEM_RESERVE. Other memory allocation functions, such as malloc and LocalAlloc , cannot use reserved memory until it has been released. MEM_RESET 0x80000Indicates that data in the memory range specified by lpAddress and dwSize is no longer of interest. The pages should not be read from or written to the paging file. However, the memory block will be used again later, so it should not be decommitted. This value cannot be used with any other value. Using this value does not guarantee that the range operated on with MEM_RESET will contain zeroes. If you want the range to contain zeroes, decommit the memory and then recommit it. When you use MEM_RESET, the VirtualAllocEx function ignores the value of fProtect. However, you must still set fProtect to a valid protection value, such as PAGE_NOACCESS. VirtualAllocEx returns an error if you use MEM_RESET and the range of memory is mapped to a file. A shared view is only acceptable if it is mapped to a paging file. This parameter can also specify the following values as indicated. ValueMeaning MEM_LARGE_PAGES 0x20000000Allocates memory using large page support . The size and alignment must be a multiple of the large-page minimum. To obtain this value, use the GetLargePageMinimum function. Windows XP/2000: This flag is not supported. MEM_PHYSICAL 0x400000Reserves an address range that can be used to map Address Windowing Extensions (AWE) pages. This value must be used with MEM_RESERVE and no other values. MEM_TOP_DOWN 0x100000Allocates memory at the highest possible address. flProtect [in] The memory protection for the region of pages to be allocated. If the pages are being committed, you can specify any one of the memory protection constants . Return Value If the function succeeds, the return value is the base address of the allocated region of pages. If the function fails, the return value is NULL. To get extended error information, call GetLastError . Remarks Each page has an associated page state . The VirtualAllocEx function can perform the following operations: Commit a region of reserved pages Reserve a region of free pages Simultaneously reserve and commit a region of free pages VirtualAllocEx cannot reserve a reserved page. It can commit a page that is already committed. This means you can commit a range of pages, regardless of whether they have already been committed, and the function will not fail. You can use VirtualAllocEx to reserve a block of pages and then make additional calls to VirtualAllocEx to commit individual pages from the reserved block. This enables a process to reserve a range of its virtual address space without consuming physical storage until it is needed. If the lpAddress parameter is not NULL, the function uses the lpAddress and dwSize parameters to compute the region of pages to be allocated. The current state of the entire range of pages must be compatible with the type of allocation specified by the flAllocationType parameter. Otherwise, the function fails and none of the pages is allocated. This compatibility requirement does not preclude committing an already committed page; see the preceding list. To execute dynamically generated code, use VirtualAllocEx to allocate memory and the VirtualProtectEx function to grant PAGE_EXECUTE access. The VirtualAllocEx function can be used to reserve an Address Windowing Extensions (AWE) region of memory within the virtual address space of a specified process. This region of memory can then be used to map physical pages into and out of virtual memory as required by the application. The MEM_PHYSICAL and MEM_RESERVE values must be set in the AllocationType parameter. The MEM_COMMIT value must not be set. The page protection must be set to PAGE_READWRITE. The VirtualFreeEx function can decommit a committed page, releasing the page's storage, or it can simultaneously decommit and release a committed page. It can also release a reserved page, making it a free page. Requirements Minimum supported clientWindows 2000 Professional Minimum supported serverWindows 2000 Server HeaderWinbase.h (include Windows.h) LibraryKernel32.lib DLLKernel32.dll See Also Memory Management Functions ReadProcessMemory Virtual Memory Functions VirtualAllocExNuma VirtualFreeEx VirtualLock VirtualProtect VirtualQuery WriteProcessMemory Send comments about this topic to Microsoft Build date: 8/27/2009 ==原始网址==http://msdn.microsoft.com/en-us/library/aa366890(VS.85).aspx\n |
随便看 |
|
windows api函数参考手册包含2258条windows api函数文档,详细介绍nodejs、java、rust调用windows api的方法技巧,是学习windows api编程的入门中文文档。