繁体   English   中英

C++ 调试断言错误

[英]C++ Debug Assertion Error

因此,我一直在玩弄 c++ 并决定编写一个程序,该程序涉及以二进制模式打开和写入文件。 我对 c++ 的 iostream 功能不太熟悉(我主要做基于 API 的编程),但我阅读了一些关于该主题的技术指南并编写了一些代码。 该代码旨在打开一个文件,将其数据读取到缓冲区,然后将该缓冲区转换为另一种格式并将其写入另一个文件。 问题是它不断抛出“调试断言”错误,这显然是围绕着 null 指针的无效使用。 但是,当我查看代码时,我无法理解它。 我可能只是误用了 iostream 库或犯了一个简单的逻辑错误。 我需要有单独的 SetMemBlock function 因为我计划使用相同的基础来格式化各种功能上的不同 output。 这只是我的原型。 无论如何,这是我的快速 n' 脏 class 设置:

const DebugMode = true;

class A
{
public:
    bool FileFunction( const char *, const char * );

protected:
    bool SetMemBlock( char *, std::fstream &, std::streamoff & );

private:
    std::fstream SrcFileStream;
    std::fstream DestFileStream;
};

bool A::SetMemBlock( char* MemBlock, std::fstream & FileStream, std::streamoff & Size )
{
    std::streamoff TempOff = 0;
    //This is meant to check for a non-empty buffer and to see if the stream is valid.
    if( MemBlock != 0 || !FileStream.is_open() )
        return false;

    TempOff = FileStream.tellg();
    FileStream.seekg(0, std::ios::end);
    Size = FileStream.tellg();

    MemBlock = new( std::nothrow ) char[ (int) Size ];

    if( MemBlock == 0 )
        return false;

    FileStream.seekg(0, std::ios::beg);
    FileStream.read( MemBlock, (int) Size );

    if( !FileStream )
        return false;

    FileStream.seekg(TempOff);
    return true;
}

bool A::FileFunction( const char * SrcFile, const char * DestFile )
{
    char * MemBlock = 0;
    std::streamoff Size = 0;

    SrcFileStream.open( SrcFile, std::ios::binary | std::ios::in );
    DestFileStream.open( DestFile, std::ios::binary | std::ios::out );

    if( !SrcFileStream.is_open() || !DestFileStream.is_open() )
        return false;

    if( DebugMode )
    {
        std::cout<<"Files opened succesfully...\nNow writing memory block..."<<std::endl;
    }

    if( !SetMemBlock( MemBlock, SrcFileStream, Size ) )
    {
        std::cout<<"An error occured when reading to memory block!"<<std::endl;
        return false;
    }

    if( DebugMode )
    {
        std::cout<<"Memory block written..."<<std::endl;
    }

    DestFileStream.seekp( std::ios::beg );
    DestFileStream.write( MemBlock, Size );

    SrcFileStream.close();
    DestFileStream.close();
    delete[] MemBlock;
    return true;

}

您按值将MemBlock传递给SetMemBlock 因此 function 只是设置了本地副本的值,这对调用 function 没有影响; 因此,调用 function 中的MemBlock的值仍然是垃圾。 将它用作指针可能会导致断言(如果幸运的话)或彻底崩溃(如果不是)。您希望通过引用传递该参数。

如果您不知道这些术语的含义,请参考 Google“按值传递”和“按引用传递”。 你真的需要了解其中的区别!

通过引用传递 MemBlock:

bool A::SetMemBlock( char*& MemBlock, std::fstream & FileStream, std::streamoff & Size )

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM