Pergunta

Estou escrevendo um pequeno projeto de teste e preciso passar e objeto de tipo quelista por valor para um thread de thread pool. É um Threadpool de Boost e estou usando o Bind para passar o Args para o thread.

Por alguma razão, não consigo passar meu item para o tópico Threadpool por valor ...

Alguém pode ajudar o que estou fazendo de errado?

void ConsumerScheduler()
{
    int count = 0;
    typedef boost::intrusive::list<QueuList> List;
    while (true)
    {
        WaitForSingleObject(hConsumer, 2000); // Wait for hConsomuer to become > 0
        {
            //lock Queue
            QueuList *item = NULL;
            boost::mutex::scoped_lock lock(mtx);
            {//Scope of lock
                if (lst->size() == 0)
                {
                    printf("List is emtpy"); 
                    continue;
                }
                else
                {
                    List::iterator iter(lst->begin());
                    item = &*iter;
                    lst->pop_front();  //Item is removed from list, so pointer is no longer available!!!
                    printf("Popped item off list.  List current size: %d\n",lst->size());
                    count++;
                }
            }
            //Pass to threadpool
            tpp.schedule(boost::bind(taskfunc,*item)); //it will not accept *item or item in this bind function to pass it by value
            total--;
            if (total == 0)
            {
                printf("Total is now zero!\nCount is %d\n", count);
            }
            if (count == 5)
                break;

            ReleaseSemaphore(hProducer,total , NULL);  // Release the hProducer semaphore, possibly waking producer
        }
    }
}

//Thread pool thread function
void taskfunc(QueuList list)
{
    boost::mutex::scoped_lock lock(mtx);
    {
        std::string name= list.GetName();
        printf("Name gotten: %s",name);
    }

}

O motivo pelo qual quero passar pelo valor é que cada threadpool Thread tenha sua própria cópia do objeto à medida que o ponteiro é removido da lista pela primeira função, isso causará um erro se eu passar por referência.

Foi útil?

Solução

Você pode resolver isso usando boost::shared_ptr<QueueList> na fila e na programação do Threadpool. Isso melhor expressa a mão dos dados compartilhados que você deseja, na ausência de unique_ptr em alguns STLs.

Outras dicas

O erro ocorre no tempo de execução ou no tempo de compilação?

Eu crio meu próprio código e não tenho Erros de compilação.

Não uso o Boost, mas, se você tiver erro no tempo de execução, acho que o erro está no bloqueio do escopo. A trava com escopo não deveria estar dentro dos colchetes?

EDIT: Eu não tenho privilégios para comentar, então postei como resposta

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top