VirtualProtect导致程序crash的问题。

VirtualProtect函数用于改变内存页面的存取属性 :

#define PAGE_NOACCESS          0x01     
#define PAGE_READONLY          0x02     
#define PAGE_READWRITE         0x04     
#define PAGE_WRITECOPY         0x08     
#define PAGE_EXECUTE           0x10     
#define PAGE_EXECUTE_READ      0x20     
#define PAGE_EXECUTE_READWRITE 0x40     
#define PAGE_EXECUTE_WRITECOPY 0x80     
#define PAGE_GUARD            0x100     
#define PAGE_NOCACHE          0x200     
#define PAGE_WRITECOMBINE     0x400


应用这个函数本来是用于内存池越界诊断的,但是很不幸的,内存池挂掉了。


这里写了一段测试code,VS2005编译,这段代码会crash:

	BYTE* pTest = new BYTE[1024];
	DWORD dwOldState = 0;
	VirtualProtect(pTest,1,PAGE_READONLY,&dwOldState);

	BYTE* p=new BYTE[1];
	p[0]= 0xff;

代码crash在:
BYTE* p=new BYTE[1];

原因:

VirtualProtect的粒度是一张内存页面,而windows的页面大小为4K,所以

VirtualProtect(pTest,1,PAGE_READONLY,&dwOldState);
会使得pTest所在内存的页面被修改为readonly,而pTest和p两者内存地址比较靠近,在同一张页面内,所以对p的写入会导致crash错误。


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值