1

ALSAのpcm_min.cの例を次のようにコンパイルすると

gcc -Wall -lasound pcm_min.c -o pcm_min

すべてが正常ですが、実行すると、期待どおりにホワイトノイズが発生しますが、次の警告/エラーも発生します。

Short write (expected 16384, wrote 7616)

これは最後のifステートメントから来ています。

#include <alsa/asoundlib.h>

static char *device = "default";                        /* playback device */

snd_output_t *output = NULL;
unsigned char buffer[16*1024];                          /* some random data */

int main(void)
{
        int err;
        unsigned int i;
        snd_pcm_t *handle;
        snd_pcm_sframes_t frames;

        for (i = 0; i < sizeof(buffer); i++)
                buffer[i] = random() & 0xff;

        if ((err = snd_pcm_open(&handle, device, SND_PCM_STREAM_PLAYBACK, 0)) < 0) {
                printf("Playback open error: %s\n", snd_strerror(err));
                exit(EXIT_FAILURE);
        }
        if ((err = snd_pcm_set_params(handle,
                                      SND_PCM_FORMAT_U8,
                                      SND_PCM_ACCESS_RW_INTERLEAVED,
                                      1,
                                      48000,
                                      1,
                                      500000)) < 0) {   /* 0.5sec */
                printf("Playback open error: %s\n", snd_strerror(err));
                exit(EXIT_FAILURE);
        }

        for (i = 0; i < 16; i++) {
                frames = snd_pcm_writei(handle, buffer, sizeof(buffer));
                if (frames < 0)
                        frames = snd_pcm_recover(handle, frames, 0);
                if (frames < 0) {
                        printf("snd_pcm_writei failed: %s\n", snd_strerror(err));
                        break;
                }
                if (frames > 0 && frames < (long)sizeof(buffer))
                        printf("Short write (expected %li, wrote %li)\n", (long)sizeof(buffer), frames);
        }

        snd_pcm_close(handle);
        return 0;
}

誰かがこの警告/エラーが発生する理由を理解できますか?

抱擁、ルイーズ

4

2 に答える 2

3

この関数は、信号を受信した場合やアンダーランが発生した場合snd_pcm_writei()よりも返されることが少ない場合があります。sizeof(buffer)あなたの場合、バイトとフレームを混合しているようです。呼び出しの最後のパラメーターは、バッファーにあるフレームの数です。代わりにバッファ内のバイト数を渡しているため、アンダーランが発生しています。

于 2009-11-16T06:14:42.907 に答える