3

这是对 dan (dan^spotify on IRC) 提议查看我的测试用例的回应,但我将其发布在这里,以防有人遇到类似问题。

我遇到了 libspotify 的问题,在这两种情况下应用程序崩溃(内存访问冲突):

  • 在调用 sp_session_logout() 函数后调用的第一个 sp_session_process_events(由通知主线程回调触发)使应用程序崩溃
  • 跳过注销并调用 sp_session_release() 会使应用程序崩溃

我已经从会话回调中应用了足够的同步,否则我在单个线程上操作。

我制作了一个小测试用例,它执行以下操作:

  • 创建会话
  • 登录
  • 等待 10 秒
  • 尝试注销,然后崩溃(调用 sp_session_process_events() 时)
  • 如果它成功注销(它不是),将调用 sp_session_release()

我为测试用例做了一个要点。可以在这里找到:https ://gist.github.com/4496396

测试用例是使用 Qt 制作的(这是我在项目中使用的),所以你需要 Qt 5 来​​编译它。我也只考虑 Windows 和 Linux 编写它(没有 Mac)。假设您安装了 Qt 5 和 Qt Creator,说明如下:

  • 下载要点
  • 将 libspotify 文件夹复制到与 .pro 文件相同的文件夹中
  • 将您的 appkey.c 文件复制到同一文件夹中
  • 编辑 main.cpp 以使用您的用户名和密码登录
  • 编辑 sessiontest.cpp 中的第 38-39 行,并根据自己的喜好设置缓存和设置路径
  • 打开 .pro 文件并从 Qt Creator 运行

如果有人能告诉我我做错了什么,我将不胜感激,因为我花了很多时间尝试任何我能想到的事情或只是盯着它看,我担心我对自己的错误视而不见目前为止。

我已经在 Windows 7 和 Linux Ubuntu 12.10 上对其进行了测试,我发现了一些行为差异:

  • 在 Windows 上,无论设置和缓存路径如何,测试用例都会崩溃。
  • 在 Linux 上,如果将设置和缓存设置为“”(空字符串),则注销并释放会话可以正常工作。
  • 在 Linux 上,如果路径是其他任何内容,则第一次运行(当文件夹不存在时)注销并按应有的方式释放会话,但在下一次运行时(当文件夹已经存在时),它会以完全相同的方式崩溃在 Windows 上可以。

另外,我可以报告 sp_session_flush_caches() 不会导致崩溃。

编辑:另外,IRC 上的 hugo___ 很友好地为我在 OSX 上进行了测试。尽管连续多次运行该应用程序,但他没有报告任何崩溃。

4

4 回答 4

1

我注意到,如果您在调用 sp_session_release 时正在播放曲目,则会在 sp_session_release 上崩溃。

于 2014-04-03T07:25:54.863 回答
1

虽然您很可能正在查看 libspotify 中的错误,但我想指出一个可能多余的调用sp_session_process_events(),来自我从查看您的代码中收集的内容。

void SessionTest::processSpotifyEvents()
{
  if (m_session == 0)
  {
    qDebug() << "Process: No session.";
    return;
  }
  int interval = 0;
  sp_session_process_events(m_session, &interval);
  qDebug() << interval;
  m_timerId = startTimer(interval);
}

似乎这段代码将获取该interval值并在其上启动一个计时器以触发对event(). 但是,这段代码也会startTimer在间隔为 0 时调用,这完全没有必要,或者更确切地说,意味着应用程序可以继续做其他事情,直到它得到notify_main_thread回调。上的文档startTimer说“如果间隔为0,则每次没有更多窗口系统事件要处理时,计时器事件就会发生一次。”。我不确定这到底是什么意思,但它似乎可以产生至少一个对sp_session_process_events().

http://qt-project.org/doc/qt-4.8/qobject.html#startTimer

于 2013-01-10T12:08:18.300 回答
0

在您的“登录”libspotify 回调中添加以下调用似乎可以修复此崩溃,如此 SO 帖子中所述:

sp_session_playlistcontainer(session);

于 2014-11-30T11:05:02.977 回答
0

我今天一直在追这个问题。登录/注销在 Mac 上工作得很好,但正如你在 Windows 上描述的那样,这个问题是 100% 可重复的。

offline_status_updated通过为and注册空回调credentials_blob_updated,崩溃消失了。这是一个非常不令人满意的修复,我想知道是否有任何libspotify开发人员想对此发表评论。

在我的应用中注册的回调是:

  • logged_in
  • logged_out
  • notify_main_thread
  • log_message
  • offline_status_updated
  • credentials_blob_updated

我应该明确指出,我没有您提供的代码上尝试此操作。知道添加这两个额外的回调是否适合您会很有趣。请注意,我提供的功能完全没有任何作用。当您创建会话时,他们只需要在那里并进行注册。

于 2014-05-06T06:41:29.930 回答