Процесс завершен с кодом выхода -1073741819 (0xC0000005) (Cython, TeamSpeak3)

Моя цель на данный момент - создать службу менеджера Team Speak (которая переключает пользователей по каналам и другим): Итак, я создал упаковщик библиотеки TS3 SDK (обернутый Cython для Python): https://mega.nz/#!pQdFjIwD! 1vg8DPsFtYR4icVqWXzvpdbAQ47-n-aPz2niRkTU4fY (основной модуль: http://pastebin.com/PywhH4bf) В этой оболочке я использовал тестовое соединение в модуле. Чтобы протестировать этот модуль, просто импортируйте его.

И я получил сообщение в консоли Python (после вызова ts3client_startConnection): Process finished with exit code -1073741819 (0xC0000005) (нарушение доступа)

Также, как я вижу, обратные вызовы TS3 вызываются из неосновного потока.

С этим журналом:

2016-08-16 10:14:20.862577|INFO    |              |   |TeamSpeak 3 Client 3.0.3 (2015-03-30 11:30:36) SDK
2016-08-16 10:14:20.863574|INFO    |              |   |SystemInformation: Windows 9 8664 {6} {3} {9600}  (9600) x64 (AMD or Intel) Binary: 32bit
2016-08-16 10:14:20.863574|INFO    |              |   |Using hardware aes
2016-08-16 10:14:20.876587|DEBUG   |Direct Sound  |   |setting timer resolution to 1ms
2016-08-16 10:14:20.892602|ERROR   |SoundBckndIntf|   |Could not load "ts3soundbackend_isSupported" from backend dynamic library
spawn connection handler
mode
Default capture mode: b'Windows Audio Session'

('Default capture device: %s %s\n', b'\xd0\x9c\xd0\xb8\xd0\xba\xd1\x80\xd0\xbe\xd1\x84\xd0\xbe\xd0\xbd (\xd0\xa3\xd1\x81\xd1\x82\xd1\x80\xd0\xbe\xd0\xb9\xd1\x81\xd1\x82\xd0\xb2\xd0\xbe \xd1\x81 \xd0\xbf\xd0\xbe\xd0\xb4\xd0\xb4\xd0\xb5\xd1\x80\xd0\xb6\xd0\xba\xd0\xbe\xd0\xb9 High Definition Audio)', b'{0.0.1.00000000}.{c28d826f-9cd5-414b-a018-bbfc0cbc1298}')
2016-08-16 10:14:20.905616|DEBUG   |Windows Audio Session|   |WAS::openDevice-enter
2016-08-16 10:14:20.912622|DEBUG   |Windows Audio Session|   |WAS Buffer size: 896
2016-08-16 10:14:20.912622|DEBUG   |Windows Audio Session|   |WAS::openDevice-leave
2016-08-16 10:14:20.912622|INFO    |PreProSpeex   |1  |Speex version: speex-1.2beta3
2016-08-16 10:14:20.912622|DEBUG   |Windows Audio Session|   |WAS::startDevice-enter
2016-08-16 10:14:20.913622|DEBUG   |Windows Audio Session|   |WAS::startDevice-leave
Default playback mode: b'Windows Audio Session'

('Default playback device: %s %s\n', b'\xd0\x94\xd0\xb8\xd0\xbd\xd0\xb0\xd0\xbc\xd0\xb8\xd0\xba\xd0\xb8 (\xd0\xa3\xd1\x81\xd1\x82\xd1\x80\xd0\xbe\xd0\xb9\xd1\x81\xd1\x82\xd0\xb2\xd0\xbe \xd1\x81 \xd0\xbf\xd0\xbe\xd0\xb4\xd0\xb4\xd0\xb5\xd1\x80\xd0\xb6\xd0\xba\xd0\xbe\xd0\xb9 High Definition Audio)', b'{0.0.0.00000000}.{cb324415-bf79-473b-9a59-69a1ca4bfe56}')
2016-08-16 10:14:20.913622|DEBUG   |Windows Audio Session|   |WAS::openDevice-enter
2016-08-16 10:14:20.918627|DEBUG   |Windows Audio Session|   |WAS Buffer size: 896
2016-08-16 10:14:20.918627|DEBUG   |Windows Audio Session|   |WAS::openDevice-leave
2016-08-16 10:14:20.918627|DEBUG   |Windows Audio Session|   |WAS::startDevice-enter
2016-08-16 10:14:20.918627|DEBUG   |Windows Audio Session|   |WAS::startDevice-leave
creating identity
Using identity: b'295V/MObSjZ2wIe+dMWhUoLET/UpS6ENHlhWSVdYYSZ5UnQTU3dneUFQLAF/FDVRBXkaFVFeAH10V1cDQn0Gd3BVYgFgXwV4IgxjOVB2DCwtET9TfgcaA31GE1MBZFxLBXtgDHd9WHFka0NJUUQweGprQnp2cjNrSkxBMXJaazRWeDJMTkRUOUlXcVVyZ0p0WnpDU0lDOVlRPT0='

Client lib initialized and running

Connect status changed: 1 1 0

2016-08-16 10:14:20.926635|DEVELOP |PktHandler    |   |Puzzle solve time: 7
Connect status changed: 1 2 0

Connect status changed: 1 3 0

Connect status changed: 1 4 0

Также я получил не повторяемые случайные ошибки:

Fatal Python error: GC object already tracked

а также

Fatal Python error: PyThreadState_Get: no current thread

1 ответ

Решение

Из-за отсутствия поддающегося проверке примера, это немного догадки.

Если эти функции-обработчики вызываются из потока, созданного библиотекой C (ts3client_*), GIL не был правильно получен к моменту вызова функций python.

Добавление with gil лайк

cdef void onConnectStatusChang‌​eEvent(uint64 serverConnectionHand‌​lerID,
                                     int newStatus, 
                                     unsigned int errorNumber) with gil:

может помочь

Там также нет кода в конце __main__()Возможно, было бы лучше, если бы основной поток хотя бы не работал.

if (error != ERROR_ok):
    print("Error connecting to server: %d\n"% error)

print("Client lib initialized and running\n")

Следующие строки могут быть добавлены после вызова печати для быстрого теста

import time
while True:
    time.sleep(1.0)
Другие вопросы по тегам