Universidade Tecnolgica Federal do Paran UTFPR Campus Curitiba
Universidade Tecnológica Federal do Paraná UTFPR – Campus Curitiba Orientação a Objetos - Programação em C++ Grupo de Slides 18 – Parte B: Introdução à Multithreading: execução concorrente de tarefas. Exemplos usando a ‘biblioteca’ pthread que é de acordo com POSIX. Prof. Jean Marcelo SIMÃO Aluno monitor em 2010: Vagner Vengue 1
POSIX Threads (Pthreads) Obs. : Material inicial elaborado por Murilo S. Holtman no 2 o Semestre de 2007. O Holtman era então aluno da disciplina em questão e estagiário em projeto do Professor da disciplina. Em 2010, o material foi melhorado e atualizado pelo monitor Vagner Vengue 2
POSIX Threads (Pthreads) • Uma padronização desenvolvida pelo comitê POSIX (Portable Operating System Interface) para tornar os programas que utilizam threads portáveis entre várias plataformas. • Inclui suporte à criação e controle de threads e a alguns objetos de sincronização básicos. 3
Elementos Básico de threading na ‘biblioteca’ Pthreads pthread_create e pthread_exit • pthread_create() cria uma nova thread, que pode (ou não) começar a executar imediatamente após a chamada ter sido concluída. int pthread_create ( pthread_t *thread, const pthread_attr_t *attr, void *(*start_routine)(void*), void *arg ); • pthread_exit() é chamada no contexto de uma thread criada por pthread_create() e faz com que essa thread seja finalizada. void pthread_exit( void *value_ptr ); 4
Exemplos de implementação de threads (utilizando Pthreads) 5
Exemplo 01 #include <iostream> int main() using namespace std; { #include <pthread. h> cout << "Digite ENTER para iniciar e parar a thread. . . " << endl; bool thread_ligada = true; cin. get(); // aguarda um ENTER do usuário; thread_ligada = true; pthread_t minha_thread; // inicia uma nova thread, passando como parâmetro a thread e a função que se deseja executar; // função passada como parâmetro para nova // thread; pthread_create(&minha_thread, NULL, escreve. Algo, NULL); void* escreve. Algo(void *p) { while ( thread_ligada ) // cout << "Digite ENTER para finalizar. . . " << endl; { cout << "Executando thread. . . " << endl; cin. get(); // aguarda um ENTER do usuário; } // informa a thread que ela deve parar; // termina a thread; thread_ligada = false; pthread_exit(&minha_thread); } return 0; } 6
Exemplo 01 7
Elementos Básico de threading na ‘biblioteca’ Pthreads join e detach • Uma thread pode aguardar pela finalização de outra thread através de pthread_join(). int pthread_join( pthread_t thread, void **value_ptr ); • pthread_detach() avisa à implementação subjacente que a thread especificada deve ser liberada assim que terminar. int pthread_detach ( pthread_t *thread ); 8
Exemplo 02 (Região Crítica) #include <iostream> int main() using namespace std; { #include <pthread. h> cout << "Digite ENTER para iniciar as threads. . . " << endl; pthread_t thread_1; cin. get(); // aguarda um ENTER do usuário; pthread_t thread_2; // inicia as duas threads, passando como parâmetro a thread e a função que cada uma deve executar; // função passada para a thread_1; void* tarefa_1(void *p) { pthread_create(&thread_1, NULL, //------------- REGIÃO CRÍTICA tarefa_1, NULL); for (char* s = "123456"; *s != '