在异步模式下使用ReadFile测试readbytes是否等于toread字节
test if readbytes is equal to toread bytes using ReadFile in asynchronous mode
我有一个错误场景,我试图读取比文件中实际存在的字节更多的字节。在同步的情况下,它会失败,并报告适当的错误,因为我们调用waitFrObject并等待io完成,然后测试readbytes是否>=ToReadbytes。但在异步的情况下,我们开始读取,忽略ReadFile返回的IO peding状态标志(这是预期的),并继续我们的操作。因此,在异步情况下实际上并没有捕捉到错误。现在,如果我检查等待IO完成,以检查readbytes>=ToreadBytes,那么它将不再是异步的,因为我们正在等待。那么我该如何应对这种情况呢?(注意-读取比实际存在的字节更多的字节是使错误可再现的方法之一)
我正在使用windown的ReadFile函数进行读取。
假设您有其他线程正在等待由读取完成触发的事件,然后该线程将继续使用数据。只需在等待之后添加检查,然后再使用数据。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- GL_SHADERSTORAGE_BUFFER位置是否与其他着色器位置冲突
- 子目录是否继承属性,例如add_definitions,include_directories和父Cmakelist.t
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- C/C++预处理器是否可以检测一些编译器选项
- 在异步模式下使用ReadFile测试readbytes是否等于toread字节