fplength = readfile(&fpBuff, fplength); int CMFCcomtooltryDlg::readfile(unsigned char** fpBuff, unsigned long fplength) { CFile fp; //打开文件 unsigned long m_nFileLength; m_eFilePath.GetWindowTextW(m_strSendFilePathName); if (!(fp.Open((LPCTSTR)m_strSendFilePathName, CFile::modeRead))) { MessageBox(_T("Open file failed!")); return 1; } //定位文件指针至文件尾 fp.SeekToEnd(); //获取长度,分配大小 fplength = fp.GetLength(); m_nFileLength = fplength; *fpBuff = new unsigned char[fplength]; //定位文件指针至文件头 fp.SeekToBegin(); if (fp.Read(*fpBuff, fplength) < 1) { fp.Close(); return 2; } else { fp.Close(); return fplength; } }
时间: 2024-04-18 16:32:13 浏览: 23
根据提供的代码,`readfile` 函数打开并读取文件的内容,并将其存储在 `Buff` 指向的内存中。函数返回文件的长度,或者在发生错误时返回相应的错误代码。
首先,函数从界面上获取文件路径,并尝试以只读方式打开文件。如果打开失败,会弹出一个消息框提示打开文件失败,并返回值 1。
然后,函数将文件指针定位到文件末尾,并获取文件的长度。接下来,根据文件长度动态分配了一个大小为 `fplength` 的无符号字符数组,并将其赋值给 `*fpBuff`。
接着,函数将文件指针定位到文件开头,并使用 `fp.Read` 函数从文件中读取数据到 `*fpBuff` 中。如果读取失败,会关闭文件并返回值 2。
最后,如果读取成功,函数关闭文件并返回文件的长度 `fplength`。
需要注意的是,在调用 `readfile` 函数之前,确保 `fpBuff` 和 `fplength` 的初始值是正确的,并且已经包含了正确的文件路径。
如果你在执行代码时遇到了问题,请提供更多的错误信息或者问题描述,以便我们能够更好地帮助你解决问题。
相关问题
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); }
这段代码是一个示例,它涉及文件的读取和发送。首先,它定义了一些变量,包括一个指向无符号字符的指针 `fpBuff`,一个表示文件长度的无符号长整型变量 `fplength`,以及一些临时数组和字符串。
在 `readfile` 函数中,文件被打开并读取,将文件内容存储在 `fpBuff` 中,并更新文件长度 `fplength`。
接下来,在 `SendFile` 函数中,根据文件长度计算发送次数和剩余长度。然后,通过循环将每次发送的数据复制到 `temp` 数组中,并将其转换为字符串添加到 `Sendstr` 中。然后,通过 `com.Send(Sendstr)` 发送数据,并通过 `Sleep(Sleep_time)` 等待一段时间。
最后,剩余的字节被复制到 `Lasttemp` 数组中,并将其转换为字符串添加到 `Sendstr` 中。然后,通过 `com.Send(Sendstr)` 发送最后的数据。
需要注意的是,在代码的最后,使用 `delete fpBuff;` 删除了动态分配的内存。
请注意,这只是代码的一部分,并不能完整执行。你可能需要提供更多的信息来解决问题。
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 时发生访问冲突。
根据你提供的信息,代码中可能出现了访问冲突的问题。异常代码 0xC0000005 表示发生了内存访问冲突,导致程序崩溃。
出现这种情况的原因可能是以下几点:
1. `readfile` 函数中的文件读取出错,导致 `fpBuff` 指针为NULL或者指向无效的内存地址。在调用 `memcpy` 函数时,会发生访问冲突。
2. 程序中使用的数组 `temp` 和 `Lasttemp` 的大小为 `Max_num`,但是在循环中,你使用了一个相同的变量 `i` 来遍历数组元素。这会导致 `i` 的值在内层循环中被覆盖,可能导致访问冲突。
解决这个问题,你可以按照以下步骤进行调试:
1. 确保 `readfile` 函数正确打开和读取文件,并且将正确的数据存储到 `fpBuff` 指针指向的内存中。
2. 检查循环变量是否正确使用。在内层循环中使用一个不同的变量来遍历数组元素,而不是使用外层循环的变量 `i`。
3. 确保发送数据时的字符串长度不会超过 `Sendstr` 的最大长度,以避免访问冲突。
4. 使用调试器逐步执行代码,并观察在哪个位置发生了访问冲突。这可以帮助你更准确地定位问题所在。
请尝试以上方法,并在遇到进一步问题时提供更多相关代码和错误信息,以便我们能够帮助你解决问题。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)