雪傲天1 2023-05-21 20:14 采纳率: 96.2%
浏览 17
已结题

为什么会报这个错误呢

为什么报了这个错误

这是我的client文件、
#include <stdio.h>
#include <windows.h>
#pragma comment(lib, "ws2_32.lib")
int  SendtoServ(const char* mypath)
{
#if 1
    WORD wVersionRequested;
    WSADATA wsaData;
    int err;
    char sendBuff[1000]{};
    wVersionRequested = MAKEWORD(2, 2);
    // 初始化套接字库
    err = WSAStartup(wVersionRequested, &wsaData);
    if (err != 0)
    {
        return err;
    }
    if (LOBYTE(wsaData.wVersion) != 2 || HIBYTE(wsaData.wVersion) != 2)
    {
        WSACleanup();
        system("pause");
        return -1;
    }
#endif
    printf("fun sentoserv\n");
    SOCKET sockClie = socket(AF_INET, SOCK_STREAM, 0);
    if (INVALID_SOCKET == sockClie)
    {
        printf("socket errorNum = %d\n", GetLastError());
        system("pause");
        return -1;
    }
    //配置要连接的服务器
    SOCKADDR_IN addrSrv;
    addrSrv.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");
    addrSrv.sin_family = AF_INET;
    addrSrv.sin_port = htons(6000);
    //连接服务器
    if (SOCKET_ERROR == connect(sockClie, (SOCKADDR*)&addrSrv, sizeof(SOCKADDR )))
    {
        printf("connect errorNum = %d\n", GetLastError());
        system("pause");
        return -1;
    }
    //读取文件内容
    FILE* fp = fopen(mypath, "rb");
    int len = fread(sendBuff, 1, 1000, fp);
    fclose(fp);
    // 发数据 
    int iLen = send(sockClie, (char*)sendBuff, 1000, 0);
    if (iLen<0)
    {
        printf("send error:%d", GetLastError());
        system("pause");
        return -1;
    }
    //关闭socket
    closesocket(sockClie);
    WSACleanup();
    return 0;
}
int  getFile(const char* filepath)
{
    //WIN32_FIND_DATA是一个结构体,可用来表示文件
    WIN32_FIND_DATA FindFileData;
    //文件、键盘、鼠标等都是通过句柄来标识
    HANDLE hListFile;
    //首先找到第一个文件,调用API findfirstfile,
    //MAX_PATH系统定义的一个宏,表示260
    char szFilePath[MAX_PATH]{};
    //strcpy字符串复制函数,strcat截断函数
    strcpy( szFilePath,filepath );
    strcat(szFilePath, "\\*");
    hListFile=FindFirstFile(szFilePath, &FindFileData);

    //循环遍历所有文件,如果FindNextFile返回值为0,即找不到下个文件,退出循环
    do 
    {
        char mypath[MAX_PATH]{};
        strcpy(mypath, filepath);
        strcat(mypath, FindFileData.cFileName);
        if (strstr(mypath,".txt"))
        {
            SendtoServ(mypath);
            printf("mypath==%s\n", mypath);
        }
    } while (FindNextFile(hListFile, &FindFileData));

    return 0;
}
int main()
{
    //定义一个函数,用来遍历未见
    getFile("C:\\Users\\zozoz\\Desktop\\woshizhu");
    system("pause");
    return 0;
}
这是我的server文件
#include <stdio.h>
#include <windows.h>
#pragma comment(lib, "ws2_32.lib")
#define  MAX_SIZE  100000
//写一个错误函数,打印错误码的控制台函数,打印后,直接退出
void errorhanding(const char* msg)
{
    fputs(msg, stderr);//stderr和getlasterror差不多,都是错误码
    fputc('\n', stderr);
    system("pause");
    exit(1);

}
int main()
{
#if 1
    WORD wVersionRequested;
    WSADATA wsaData;
    int err;
    char MSG[MAX_SIZE]{0};
    wVersionRequested = MAKEWORD(2, 2);
    // 初始化套接字库
    err = WSAStartup(wVersionRequested, &wsaData);
    if (err != 0)
    {
        errorhanding("WSAStartup error");
        system("pause");
    }
    if (LOBYTE(wsaData.wVersion) != 2 || HIBYTE(wsaData.wVersion) != 2)
    {
        printf("LOBYTE error:  %d\n", GetLastError());
        WSACleanup();
        errorhanding("LOBYTE error");
        system("pause");
        return -1;
    }
#endif
    SOCKET servsock =socket(PF_INET, SOCK_STREAM, 0);
    if (INVALID_SOCKET== servsock)
    {
        errorhanding("servsock error");
    }


    SOCKADDR_IN addrSrv;
    addrSrv.sin_addr.S_un.S_addr = htonl(INADDR_ANY);
    addrSrv.sin_family = AF_INET;
    addrSrv.sin_port = htons(6000);
    // 3 分配电话号码
    // 绑定套接字到本地 IP 地址,端口号 6000
    if (SOCKET_ERROR == bind(servsock, (SOCKADDR*)&addrSrv, sizeof(SOCKADDR )))
    {
        errorhanding("bind  error");
    }
    // 4、监听 listen
    if (SOCKET_ERROR == listen(servsock, 5))
    {
        errorhanding("listen  error");
    }
    // 5、拿起话筒,准备通话
    SOCKADDR_IN addrCli;
    int len = sizeof(SOCKADDR_IN);
    int strlen{};
    SOCKET cliesock;
    for (int i=0;i<1000;i++)
    {
        cliesock = accept(servsock, (SOCKADDR*)&addrCli, &len);
        if (SOCKET_ERROR == cliesock)
        {
            errorhanding("accept  error");
        }
        memset(MSG, 0, MAX_SIZE);
        while ((strlen=recv(cliesock,MSG,MAX_SIZE,0))!=0)
        {
            printf("Server msg=%s\n", MSG);
        }
        closesocket(cliesock);
    }
    closesocket(servsock);
    WSACleanup();
    return 0;
}

报错内容: Microsoft Visual C++ Runtime Library
Debug Assertion Failed!
Program: C:\Users\zozoz\source\repos\文件窃取\Debug\steal-client.exeFile: minkernel\crtsjucrt\srclappcrt\stdio\fread.cpp
Line: 48
Expression: stream != nullptr
For information on how your program can cause an assertionfailure, see the visual C++ documentation on asserts.
(Press Retry to debug the application)

报错不是通过VS报错的,而是直接弹出了一个警告框,具体内容已经写在代码最后了,望解答

img

  • 写回答

2条回答 默认 最新

  • 技术宅program 2023-05-21 20:35
    关注

    以下答案由GPT-4.5Plus大模型(语音)与博主A努力中.......共同编写:

    这个错误是因为你的代码在调用fread函数时,stream参数为nullptr导致的断言失败。

    在你的代码中,调用fread的地方是:

    cpp
    FILE* fp = fopen(mypath, "rb"); 
    int len = fread(sendBuff, 1, 1000, fp);
    fclose(fp);
    
    

    然而,如果mypath为空字符串或错误路径,fopen函数将失败,fp将为nullptr。此时调用fread(fp)就会导致断言失败。

    解决方案是:

    1. 在调用fopen前检查mypath是否为空或错误,避免fp为nullptr的情况出现。

    2. 在调用fread前也检查fp是否为nullptr,如果是则跳过fread调用。

    修改后的代码可以是:

    cpp
    if (mypath[0] != '\0') {
        FILE* fp = fopen(mypath, "rb");
        if (fp != nullptr) {
            int len = fread(sendBuff, 1, 1000, fp);
            fclose(fp);
        }
    }
    或者
    cpp
    FILE* fp = fopen(mypath, "rb");
    if (fp != nullptr) {
        int len = fread(sendBuff, 1, 1000, fp);
        fclose(fp); 
    }
    
    

    这样就可以避免在fp为nullptr的情况下调用fread导致的断言失败错误了。

    希望这个解释和解决方案能帮助你解决Visual C++的断言失败错误。C/C++程序在调用各个API时都需要确保参数的有效性,否则容易导致意外的错误和崩溃。要养成检查参数的好习惯,在调用任何API前先判断参数是否满足要求,这可以极大提高程序的健壮性。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 5月29日
  • 已采纳回答 5月21日
  • 创建了问题 5月21日