1

我正在尝试为我正在构建的应用程序流式传输音频,但我遇到了我正在使用的库的障碍。这个库是 libSndFile。每当我调用此函数时,该库总是有一个 SEGFAULT sf_open_fd(int fd, int mode, SF_INFO *info, int close_desc);,而不是sf_open(const char *path, int mode, SF_INFO *info)因为我需要让 libSndFile 解码内存缓冲区中的数据。我无法理解sf_virtual_open()文档,所以我改用它。我可以使用 fileno() 获得一个有效的文件描述符(它通常返回 14)并且我的 FILE 流是有效的,所以它就是这个函数。我不知道它可能在哪里 SEGFAULTing 或在什么地方。有没有更好的方法让 libSndFile 解码内存缓冲区,或者我没有使用正确的方法?

这是问题代码(我添加了一些注释让它更有意义)

memset(&/*SF_INFO*/mInfo, 0, sizeof(SF_INFO));

/* FILE* */mpFileStream = tmpfile();

fwrite(/* void* */aBuffer, /*int*/aSize, 1, mpFileStream);

int iDescriptor = fileno(mpFileStream);

if(iDescriptor == -1)
{
    return /*enum EError*/EError_Unknown;
}

/* SNDFILE* */mFile = sf_open_fd(iDescriptor, SFM_READ, mInfo, SF_TRUE);

return mFile != NULL ? /*enum EError*/EError_None : /*enum EError*/EError_Unknown;

我真的更喜欢不写入磁盘,但我必须获得一个有效的文件描述符和流。

注意:我正在使用 g++ 4.6.3 在 Xubuntu 12.04 上进行编译。

4

1 回答 1

4

可能在第一行:

memset(&/*SF_INFO*/mInfo, 0, sizeof(SF_INFO));

您稍后使用 mInfo 作为指针参数调用 sf_open_fd(),所以我猜测 mInfo 实际上是 SF_INFO* 而不是 SF_INFO。memset() 允许任何指针类型,因此您不会收到编译错误。

顺便说一句,您不需要写入磁盘 - tmpfile() 返回一个打开的文件,该文件应该与 fileno() 一起使用。

编辑:实际上,当您说您不知道 SEGFAULT 发生在哪里时,我可能误解了您的问题。我在 libsndfile 文档中发现的一件事是,如果您的程序链接到与库不同的运行时,则无法使用 sf_open_fd()。这可能是问题所在。

于 2012-11-19T17:36:04.597 回答