gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-11-01 09:56:32 25 4
gpt4 key购买 nike

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

我们尽力确保对 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com