#include <WINDOWS.H>
#include <IOSTREAM>
#include <SHLWAPI.H>
#include <IOMANIP>
#pragma comment(lib, "Shlwapi.lib")
// 以可读方式对用户显示保护的辅助方法。
// 保护标记表示允许应用程序对内存进行访问的类型
// 以及操作系统强制访问的类型
inline bool TestSet(DWORD dwTarget, DWORD dwMask)
{
return ((dwTarget &dwMask) == dwMask) ;
}
# define SHOWMASK(dwTarget, type) \
if (TestSet(dwTarget, PAGE_##type) ) \
{std :: cout << ", " << #type; }
void ShowProtection(DWORD dwTarget)
{
SHOWMASK(dwTarget, READONLY) ;
SHOWMASK(dwTarget, GUARD) ;
SHOWMASK(dwTarget, NOCACHE) ;
SHOWMASK(dwTarget, READWRITE) ;
SHOWMASK(dwTarget, WRITECOPY) ;
SHOWMASK(dwTarget, EXECUTE) ;
SHOWMASK(dwTarget, EXECUTE_READ) ;
SHOWMASK(dwTarget, EXECUTE_READWRITE) ;
SHOWMASK(dwTarget, EXECUTE_WRITECOPY) ;
SHOWMASK(dwTarget, NOACCESS) ;
}
// 遍历整个虚拟内存并对用户显示其属性的工作程序的方法
void WalkVM(HANDLE hProcess)
{
// 首先,获得系统信息
SYSTEM_INFO si;
:: ZeroMemory(&si, sizeof(si) ) ;
:: GetSystemInfo(&si) ;
// 分配要存放信息的缓冲区
MEMORY_BASIC_INFORMATION mbi;
:: ZeroMemory(&mbi, sizeof(mbi) ) ;
// 循环整个应用程序地址空间
LPCVOID pBlock = (LPVOID) si.lpMinimumApplicationAddress;
while (pBlock < si.lpMaximumApplicationAddress)
{
// 获得下一个虚拟内存块的信息
if (:: VirtualQueryEx(
hProcess, // 相关的进程
pBlock, // 开始位置
&mbi, // 缓冲区
sizeof(mbi))==sizeof(mbi) ) // 大小的确认
{
// 计算块的结尾及其大小
LPCVOID pEnd = (PBYTE) pBlock + mbi.RegionSize;
TCHAR szSize[MAX_PATH];
:: StrFormatByteSize(mbi.RegionSize, szSize, MAX_PATH) ;
// 显示块地址和大小
std :: cout.fill ('0') ;
std :: cout
<< std :: hex << std :: setw(8) << (DWORD) pBlock
<< "-"
<< std :: hex << std :: setw(8) << (DWORD) pEnd
<< (:: strlen(szSize)==7? " (" : " (") << szSize
<< ") " ;
// 显示块的状态
switch(mbi.State)
{
case MEM_COMMIT :
std :: cout << "Committed" ;
break;
case MEM_FREE :
std :: cout << "Free" ;
break;
case MEM_RESERVE :
std :: cout << "Reserved" ;
break;
}
// 显示保护
if(mbi.Protect==0 && mbi.State!=MEM_FREE) //???????---什么意思
{
mbi.Protect=PAGE_READONLY; //???????---什么意思
}
ShowProtection(mbi.Protect);
// 显示类型
switch(mbi.Type){
case MEM_IMAGE :
std :: cout << ", Image" ;
break;
case MEM_MAPPED:
std :: cout << ", Mapped";
break;
case MEM_PRIVATE :
std :: cout << ", Private" ;
break;
}
// 检验可执行的影像
TCHAR szFilename [MAX_PATH] ;
if (:: GetModuleFileName (
(HMODULE) pBlock, // 实际虚拟内存的模块句柄
szFilename, //完全指定的文件名称
MAX_PATH)>0) //实际使用的缓冲区大小
{
// 除去路径并显示
:: PathStripPath(szFilename) ;
std :: cout << ", Module: " << szFilename;
}
std :: cout << std :: endl;
// 移动块指针以获得下一下个块
pBlock = pEnd;
}
}
}
void main()
{
// 遍历当前进程的虚拟内存
::WalkVM(::GetCurrentProcess());
}
if(mbi.Protect==0 && mbi.State!=MEM_FREE) //???????---什么意思
{
mbi.Protect=PAGE_READONLY; //???????---什么意思
}
#include <IOSTREAM>
#include <SHLWAPI.H>
#include <IOMANIP>
#pragma comment(lib, "Shlwapi.lib")
// 以可读方式对用户显示保护的辅助方法。
// 保护标记表示允许应用程序对内存进行访问的类型
// 以及操作系统强制访问的类型
inline bool TestSet(DWORD dwTarget, DWORD dwMask)
{
return ((dwTarget &dwMask) == dwMask) ;
}
# define SHOWMASK(dwTarget, type) \
if (TestSet(dwTarget, PAGE_##type) ) \
{std :: cout << ", " << #type; }
void ShowProtection(DWORD dwTarget)
{
SHOWMASK(dwTarget, READONLY) ;
SHOWMASK(dwTarget, GUARD) ;
SHOWMASK(dwTarget, NOCACHE) ;
SHOWMASK(dwTarget, READWRITE) ;
SHOWMASK(dwTarget, WRITECOPY) ;
SHOWMASK(dwTarget, EXECUTE) ;
SHOWMASK(dwTarget, EXECUTE_READ) ;
SHOWMASK(dwTarget, EXECUTE_READWRITE) ;
SHOWMASK(dwTarget, EXECUTE_WRITECOPY) ;
SHOWMASK(dwTarget, NOACCESS) ;
}
// 遍历整个虚拟内存并对用户显示其属性的工作程序的方法
void WalkVM(HANDLE hProcess)
{
// 首先,获得系统信息
SYSTEM_INFO si;
:: ZeroMemory(&si, sizeof(si) ) ;
:: GetSystemInfo(&si) ;
// 分配要存放信息的缓冲区
MEMORY_BASIC_INFORMATION mbi;
:: ZeroMemory(&mbi, sizeof(mbi) ) ;
// 循环整个应用程序地址空间
LPCVOID pBlock = (LPVOID) si.lpMinimumApplicationAddress;
while (pBlock < si.lpMaximumApplicationAddress)
{
// 获得下一个虚拟内存块的信息
if (:: VirtualQueryEx(
hProcess, // 相关的进程
pBlock, // 开始位置
&mbi, // 缓冲区
sizeof(mbi))==sizeof(mbi) ) // 大小的确认
{
// 计算块的结尾及其大小
LPCVOID pEnd = (PBYTE) pBlock + mbi.RegionSize;
TCHAR szSize[MAX_PATH];
:: StrFormatByteSize(mbi.RegionSize, szSize, MAX_PATH) ;
// 显示块地址和大小
std :: cout.fill ('0') ;
std :: cout
<< std :: hex << std :: setw(8) << (DWORD) pBlock
<< "-"
<< std :: hex << std :: setw(8) << (DWORD) pEnd
<< (:: strlen(szSize)==7? " (" : " (") << szSize
<< ") " ;
// 显示块的状态
switch(mbi.State)
{
case MEM_COMMIT :
std :: cout << "Committed" ;
break;
case MEM_FREE :
std :: cout << "Free" ;
break;
case MEM_RESERVE :
std :: cout << "Reserved" ;
break;
}
// 显示保护
if(mbi.Protect==0 && mbi.State!=MEM_FREE) //???????---什么意思
{
mbi.Protect=PAGE_READONLY; //???????---什么意思
}
ShowProtection(mbi.Protect);
// 显示类型
switch(mbi.Type){
case MEM_IMAGE :
std :: cout << ", Image" ;
break;
case MEM_MAPPED:
std :: cout << ", Mapped";
break;
case MEM_PRIVATE :
std :: cout << ", Private" ;
break;
}
// 检验可执行的影像
TCHAR szFilename [MAX_PATH] ;
if (:: GetModuleFileName (
(HMODULE) pBlock, // 实际虚拟内存的模块句柄
szFilename, //完全指定的文件名称
MAX_PATH)>0) //实际使用的缓冲区大小
{
// 除去路径并显示
:: PathStripPath(szFilename) ;
std :: cout << ", Module: " << szFilename;
}
std :: cout << std :: endl;
// 移动块指针以获得下一下个块
pBlock = pEnd;
}
}
}
void main()
{
// 遍历当前进程的虚拟内存
::WalkVM(::GetCurrentProcess());
}
if(mbi.Protect==0 && mbi.State!=MEM_FREE) //???????---什么意思
{
mbi.Protect=PAGE_READONLY; //???????---什么意思
}
解决方案 »
- 两个网卡直连和通过多层交换机直连有什么区别?
- 使用CMapStringToString发生内存泄露?
- 请教:请各位大哥帮我看看下面几个类的问题,谢谢!
- 线程中如何使用定时器?
- 怎么样修改文件名和属性?
- 这下很是不爽阿,我VC6语法高亮突然没了
- 如何用C++(不是MFC!!!!!!!!!!!!!)实现向word里插入图片??(急)
- 请大家来帮忙看看ADO数据绑定时出现的错误,支支招吧?
- 如何操作才能在VC6中使用GDI+?
- 怎样把CScrollView的垂直滚动条放在窗口的左边
- 用api函数调用,如何创建一个"标签式"的子窗口?
- x86系统的堆空间的生长方向是固定的,那么VirtualAlloc岂不是破坏了这种生长方向?
{
mbi.Protect=PAGE_READONLY;//把内存页设置为只读属性
}