0

我想从 snd_mixer_selem_get_id 函数返回 char 数组:

char* alsa_get_channel_name( void )
{
    int err;
    snd_mixer_selem_id_t *sid;
    snd_mixer_elem_t *elem;

    if ((err = snd_mixer_open (&handle, 0)) < 0) {
            fprintf(stderr, "mixer: open error: %s\n", snd_strerror(err));
    }
    if ((err = snd_mixer_attach (handle, card)) < 0) {
            fprintf(stderr, "mixer: attach error: %s\n", snd_strerror(err));
    }
    if ((err = snd_mixer_selem_register (handle, NULL, NULL)) < 0) {
            fprintf(stderr, "mixer: register error: %s\n", snd_strerror(err));
    }
    if ((err = snd_mixer_load (handle)) < 0) {
            fprintf(stderr, "mixer: load error: %s\n", snd_strerror(err));
    }

    snd_mixer_selem_id_alloca(&sid);

    for (elem = snd_mixer_first_elem(handle); elem; elem = snd_mixer_elem_next(elem)) {
            if ((!snd_mixer_selem_is_active(elem))
                    continue;

            snd_mixer_selem_get_id(elem, sid);
            const char *name = snd_mixer_selem_id_get_name(sid);
            if (name)
                sprintf(name, sizeof(name), "%s", snd_mixer_selem_get_name(elem));
    }
    snd_mixer_close(handle);

    return name;
}

我不知道怎么写 sprintf(name, sizeof(name), "%s", snd_mixer_selem_get_name(elem)); 返回频道名称。

谢谢

4

1 回答 1

1

您的呼叫sprintf()指定错误。检查man sprintf,该sprintf()函数将指针作为第一个参数,第二个参数应该是格式说明符。也许你的意思是使用snprintf()

  • name是 a const char *,意味着它是一个指向 的指针const char,所以你不能写入它。
  • nameis a const char *,表示它是一个指针sizeof(name)将评估为指向字符的指针的大小,而不是strlen(name) + 1您似乎假设的大小。
  • name是从 . 返回的指针snd_mister_selem_id_get_name()。你甚至可以写进去吗?您似乎试图用“混合器简单元素标识符的名称部分”覆盖“混合器简单元素标识符”(然后返回它)。但是,一开始您的问题是“我想从 snd_mixer_selem_get_id 函数返回 char 数组”。

从 snd_mixer_selem_get_id 函数返回“char 数组”的最简单方法是只做return snd_mixer_selem_get_name(elem)而不是尝试将sprintf()其放入某些东西......如果确实有理由需要返回字符串的副本,则可以returnstrdup(snd_mixer_selem_get_name( elem)) , and remember that the caller will be responsible for callingfree()` 在返回值上。

但是,由于您的问题相当不清楚(并且 ALSA 文档几乎与您的问题一样不清楚),我建议您重写您的问题,准确解释您的最终目标是什么,然后再试一次。

于 2013-07-26T20:38:19.293 回答