Спасибо, это действительно помогает мне двигаться в правильном направлении, однако мне нужно передать список в общую память. В этом случае это будет что-то вроде этого списка: [['57', '78', '23', '40']], который я устанавливаю как BBOX. Там нет c_type для списка есть?

я есть скрипт с именем jobrunner.py, который вызывает методы класса в main.py. Смотри ниже...

# jobrunner.py
from multiprocessing import Process
import main
from main import BBOX

def _a(arg):
    f = main.a()
    print f.run()

def _b(arg):
    p = main.b()
    print p.run()

if __name__ == '__main__':
    world = '-180,180,-90,90'
    BBOX.append(world.split(','))

    p1 = Process(target=_a, args=("1",))
    p2 = Process(target=_b, args=("1",))

    p1.start()
    p2.start()

    p1.join()
    p2.join()

Процессы _a и _b вызываются без каких-либо проблем в OSX и Ubuntu, но когда я пытаюсь запустить то же самое в Windows (та же версия python и все), он не может сказать, что индекс находится вне диапазона. Это наводит меня на мысль, что «глобальная» переменная BBOX не устанавливается и не передается между модулями на платформе Windows. Кто-нибудь еще видел что-то подобное и знает, как это исправить?

Адам

ОБНОВИТЬ: Я понял это, хотя это может быть полный взлом ... Смотрите ниже!

# jobrunner.py
from multiprocessing import Process
import main
from main import BBOX

def _a(arg):
    BBOX.append(arg) #This is the key
    f = main.a()
    print f.run()

def _b(arg):
    BBOX.append(arg) #This is the key
    p = main.b()
    print p.run()

if __name__ == '__main__':
    world = '-180,180,-90,90'
    BBOX.append(world.split(','))

    p1 = Process(target=_a, args=(BBOX[0],))
    p2 = Process(target=_b, args=(BBOX[0],))

    p1.start()
    p2.start()

    p1.join()
    p2.join()

Ответы на вопрос(1)

Ваш ответ на вопрос