0

如果我在播放歌曲后尝试调用 sp_session_logout,则会出现分段错误。关于段错误我不能说太多,因为我没有符号,

使用以下代码,每次注销后都会发生段错误 https://gist.github.com/ivankelly/5564318

#0  0x00007ffff7ac5746 in ?? () from /home/ivan/Apps/lib/libspotify.so.12
#1  0x00007ffff7a38289 in ?? () from /home/ivan/Apps/lib/libspotify.so.12
#2  0x00007ffff7a38535 in ?? () from /home/ivan/Apps/lib/libspotify.so.12
#3  0x00007ffff7a39b5a in ?? () from /home/ivan/Apps/lib/libspotify.so.12
#4  0x00007ffff7a39c86 in ?? () from /home/ivan/Apps/lib/libspotify.so.12
#5  0x00007ffff79fbc8b in ?? () from /home/ivan/Apps/lib/libspotify.so.12
#6  0x00007ffff7ad05b3 in sp_session_process_events () from /home/ivan/Apps/lib/libspotify.so.12
#7  0x0000000000401986 in main (argc=3, argv=0x7fffffffe6f8) at /home/ivan/src/spotify_test/test_spotify.c:137

这是在带有 libspotify 12.1.51 (x86_64) 的 debian sid 上。

4

1 回答 1

3

您在 libspotify 回调中调用注销,特别是与音乐交付相关的回调。音乐传递回调发生在它们自己的线程上,而 libspotify不是这样的线程安全的——您必须在“主”线程(特别是您调用的线程sp_session_create)上调用所有 API。

您的崩溃很可能通过在test_spotify_end_of_track触发回调时不调用 logout 来修复,或者通过在主线程发生时编组到主线程并在那里调用 logout 来解决。

于 2013-05-12T21:46:04.340 回答