c++ - 是否可以忽略 UnMapViewOFFile() 的错误 487 (ERROR_INVALID_ADDRESS)?

标签 c++ windows double-free

下午好,我们正在尝试构建一个供 Windows 和 Linux 32 位应用程序使用的内存映射文件缓存程序的原型(prototype)。每次运行原型(prototype)时,当我们尝试调用 UnMapViewOfFile 取消映射缓存内存映射文件区域时,都会收到错误 487(错误地址无效)。我们认为发生这种情况是因为我们尝试取消映射先前未映射的区域。我们想知道是否可以忽略此错误消息。

我们尽力确保对 MapViewOfFile 的每次调用都与 UnMapViewOfFile 匹配,如下所示,每次调用 MapViewOfFile 时,我们都使用以下代码:

std::deque<Range> ranges_type;

std::multimap<char *,Range> mmultimap;

MapPtr = (char*)::MapViewOfFile(hMapping,
                                FILE_MAP_WRITE | FILE_MAP_READ,
                                0, baseoff,
                                mappedlength);
if (MapPtr == 0){
    DWORD lasterr = GetLastError();
    ErrorMessage(lasterr);
}

ranges_type.insert(RangeDeque::value_type(
                       PreviousNCopy,
                       PreviousN,
                       adjustedptr + n,
                       MapPtr,
                       TimeStamp,
                       mappedlength));

mmultimap.insert(RangeMultiMap::value_type(
                     MapPtr,
                     Range(PreviousNCopy,
                           PreviousN,
                           adjustedptr + n,
                           MapPtr,
                           TimeStamp,
                           mappedlength)));

每次我们取消映射内存映射文件区域时,我们都会使用以下摘录:

typedef std::multimap<char *,Range>::const_iterator I;
numerased = 0;
std::pair<I,I> b = mmultimap.equal_range(TmpPrevMapPtr);
for (I i=b.first; i != b.second; ++i){ 
    std::dequeue<Range>::iterator iter;
    iter = std::lower_bound(ranges_type.begin(),
                            ranges_type.end(),
                            i->second);
    if (iter != ranges_type.end() && !(i->second < *iter)){
        ranges_type.erase(iter);
        numerased++;
    }
}

erasecount = mmultimap.erase(TmpPrevMapPtr);
retval = UnmapViewOfFile(TmpPrevMapPtr);
if (retval == 0){
    DWORD lasterr = GetLastError();
    ErrorMessage(lasterr);
}

类 Range 看起来像这样:

class Range {
public:
    explicit Range(int item){
        mLow = item;
        mHigh = item;
        mPtr  = 0;
        mMapPtr = 0;
        mStamp = 0;
        mMappedLength = 0;
    }
    Range(int low, int high, char* ptr = 0,char* mapptr = 0, int stamp = 0, int currMappedLength = 0){
        mLow = low;
        mHigh = high;
        mPtr  = ptr;
        mMapPtr = mapptr;
        mStamp = stamp;
        mMappedLength = currMappedLength;
    }

    Range(const Range& r):

    bool operator==(const Range& rhs) const{
        return (mLow <= rhs.mLow && mHigh >= rhs.mHigh);
    }
    bool operator<(const Range& rhs) const{
        return mHigh < rhs.mHigh;      
    } 

public:
    int mLow;   
    int mHigh; 
    char* mPtr;
    char* mMapPtr;
    int mStamp;
    int mMappedLength;
}; // class Range 

感谢您阅读这篇文章。

最佳答案

we trying a unmap a previouslu unmapped region

这是一个错误,就这样。您可以通过修复错误来“忽略”该错误。

或者,只需使用 if 测试忽略它即可。 Win32 函数告诉您有一个错误需要修复,但如果您想忽略它告诉您的内容,当然没有人会阻止您这样做。

关于c++ - 是否可以忽略 UnMapViewOFFile() 的错误 487 (ERROR_INVALID_ADDRESS)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6389529/

相关文章:

ios - Swift malloc_error_break 因双重释放而崩溃

c++ - 使用 Flatbuffer Union 导致双重释放或损坏错误

c++ - 在容器中删除 std::map 元素的有效方法

c++ - 最深类继承中的构造函数参数太多?

c++ - Win32API : How to determine if EN_CHANGE was because of user action, 不是软件 Action ?

C++::如何使用 sqlite3 insertquery 连接变量

windows - 有没有办法缩短 connect_ex() 的超时时间?

windows - 创建新进程后是否需要使用 CloseHandle?

c++ - 需要帮助将 Win32 C++ 移植到 Unix

c - 奇怪的双重自由行为