【发布时间】:2018-01-07 21:27:48
【问题描述】:
这是我从微读取数据的功能,但是为什么当我通过调用new分配缓冲区时,应用程序崩溃,如果我使用malloc,它可以
void AlsaMicrophoneWrapper::readThreadFunction()
{
int bufSize = m_bitsPerFrame * m_frames;
// char *buf = new char(bufSize);//crash
char *buf = (char *)malloc(bufSize);
if (NULL == buf)
{
printf("Snd_ReadThread allocate mem error\n");
return;
}
snd_pcm_sframes_t retFrame;
ssize_t returnCode;
while (true)
{
retFrame = snd_pcm_readi(m_pcmHandle, buf, m_frames);
if (-EPIPE == retFrame)
{
snd_pcm_prepare(m_pcmHandle);
}
else if (retFrame > 0)
{
returnCode = m_writer->write(buf, retFrame);
if (returnCode <= 0)
{
printf("Failed to write to stream.\n");
}
}
}
free (buf);
return;
}
【问题讨论】:
-
它必须是:
char *buf = new char[bufSize];而不是(bufSize)。如果你使用 new,也要使用 delete。