zeromemory(SecureZeroMemory和ZeroMemory的区别「建议收藏」)

发布时间:2025-12-10 19:42:32 浏览次数:2

SecureZeroMemory和ZeroMemory的区别「建议收藏」-zeroMemory初始化数组

SecureZeroMemory和ZeroMemory的区别「建议收藏」ThisfunctionisdefinedastheRtlSecureZeroMemoryfunction(seeWinBase.h).TheimplementationofRtlSecureZeroMemoryisprovidedinlineandcanbeusedonanyversionofWindows(seeWinNT.h.)_securezeromemory

This function is defined as the RtlSecureZeroMemory function (see WinBase.h). The implementation of RtlSecureZeroMemory is provided inline and can be used on any version of Windows (see WinNT.h.)

Use this function instead of ZeroMemory when you want to ensure that your data will be overwritten promptly, as some C++ compilers can optimize a call toZeroMemory by removing it entirely.

Many programming languages include syntax for initializing complex variables to zero. There can be differences between the results of these operations and theSecureZeroMemory function. UseSecureZeroMemory to clear a block of memory in any programming language.

The following code fragment shows an instance where it is good to useSecureZeroMemory instead ofZeroMemory.

C++

WCHAR szPassword[MAX_PATH];// Retrieve the passwordif (GetPasswordFromUser(szPassword, MAX_PATH))       UsePassword(szPassword);// Clear the password from memorySecureZeroMemory(szPassword, sizeof(szPassword));

希望我今天分享的这篇文章可以帮到您。

If ZeroMemory were called in this example instead of SecureZeroMemory, the compiler could optimize the call because theszPassword buffer is not read from before it goes out of scope. The password would remain on the application stack where it could be captured in a crash dump or probed by a malicious application.

ZeroMerory调用操作可能被编译器优化掉,导致保存敏感信息的堆栈不能被清空而被恶意软件利用或dump到

需要做网站?需要网络推广?欢迎咨询客户经理 13272073477