unsigned char* fpBuff = NULL; unsigned long fplength = 0; unsigned char temp[Max_num] = { 0 }; unsigned char Lasttemp[Max_num] = { 0 }; std::string Sendstr; //打开文件,读取文件 fplength = readfile(&fpBuff, fplength); //发送文件 SendFile(&fpBuff, fplength, temp, Lasttemp, Sendstr); delete fpBuff; void CMFCcomtooltryDlg::SendFile(unsigned char** fpBuff, unsigned long fplength, unsigned char temp[], unsigned char Lasttemp[], std::string Sendstr) { int i = 0; int n = 0; //发送次数 余数 S32 sendnum = fplength / Max_num; unsigned long lastlength = fplength % Max_num; //循环发送 for (i = 0; i < sendnum; i++) { //每次取1024 memcpy(temp, (fpBuff + n), Max_num); n += Max_num; //unsigned char 转 string for (i = 0; i < Max_num; i++) { Sendstr += static_cast<char>(temp[i]); } com.Send(Sendstr); Sleep(Sleep_time); //置空 Sendstr = ""; } //取最后的字节 memcpy(Lasttemp, (fpBuff + n), lastlength); //unsigned char 转 string for (i = 0; i < lastlength; i++) { Sendstr += static_cast<char>(Lasttemp[i]); } com.Send(Sendstr); } 0x00007FF9FA03148C (vcruntime140d.dll)处(位于 MFCcomtool try.exe 中)引发的异常: 0xC0000005: 读取位置 0x0000009448530558 时发生访问冲突。
时间: 2024-04-18 10:32:07 浏览: 144
QString含汉字时,完美转char*和unsigned char*
根据你提供的信息,代码中可能出现了访问冲突的问题。异常代码 0xC0000005 表示发生了内存访问冲突,导致程序崩溃。
出现这种情况的原因可能是以下几点:
1. `readfile` 函数中的文件读取出错,导致 `fpBuff` 指针为NULL或者指向无效的内存地址。在调用 `memcpy` 函数时,会发生访问冲突。
2. 程序中使用的数组 `temp` 和 `Lasttemp` 的大小为 `Max_num`,但是在循环中,你使用了一个相同的变量 `i` 来遍历数组元素。这会导致 `i` 的值在内层循环中被覆盖,可能导致访问冲突。
解决这个问题,你可以按照以下步骤进行调试:
1. 确保 `readfile` 函数正确打开和读取文件,并且将正确的数据存储到 `fpBuff` 指针指向的内存中。
2. 检查循环变量是否正确使用。在内层循环中使用一个不同的变量来遍历数组元素,而不是使用外层循环的变量 `i`。
3. 确保发送数据时的字符串长度不会超过 `Sendstr` 的最大长度,以避免访问冲突。
4. 使用调试器逐步执行代码,并观察在哪个位置发生了访问冲突。这可以帮助你更准确地定位问题所在。
请尝试以上方法,并在遇到进一步问题时提供更多相关代码和错误信息,以便我们能够帮助你解决问题。
阅读全文