UFB MCTA026 Operating Systems Lecture 10: Process Synchronization
38 Questions
0 Views

Choose a study mode

Play Quiz
Study Flashcards
Spaced Repetition
Chat to lesson

Podcast

Play an AI-generated podcast conversation about this lesson

Questions and Answers

O que é uma seção crítica em um processo de computação?

Uma seção crítica é uma parte do código que precisa ser executada de forma exclusiva por um processo, sem interferência de outros processos.

Por que é importante garantir que dois processos não executem suas seções críticas ao mesmo tempo?

É importante para evitar conflitos e garantir a consistência dos dados dentro da seção crítica de cada processo.

O que pode acontecer se dois ou mais processos estiverem lendo ou escrevendo em um dado compartilhado e o resultado final depender exatamente de quem está executando?

Condição de corrida (race condition)

O que é necessário para resolver o problema da Seção Crítica em um sistema computacional?

<p>É necessário declarar uma seção do código como crítica e controlar o acesso a essa seção, satisfazendo requisitos como exclusão mútua.</p> Signup and view all the answers

Qual é a estrutura geral de um processo em relação à Seção Crítica?

<p>A estrutura geral de um processo envolve uma Seção de Entrada (código que precede a seção crítica), a própria Seção Crítica e uma Seção de Saída (código após a seção crítica).</p> Signup and view all the answers

O que é exclusão mútua em relação a processos compartilhando variáveis ou arquivos?

<p>Assegurar que somente um processo pode acessar o dado compartilhado por vez.</p> Signup and view all the answers

O que é uma região crítica em um processo?

<p>Parte do código onde há acesso a dados compartilhados.</p> Signup and view all the answers

Explique o conceito de Exclusão Mútua em relação à Seção Crítica.

<p>Exclusão Mútua significa que se um processo estiver executando em sua seção crítica, nenhum outro processo pode executar sua respectiva seção crítica ao mesmo tempo.</p> Signup and view all the answers

Por que é necessário garantir a exclusão mútua ao lidar com dados compartilhados?

<p>Para impedir que outros processos acessem o dado simultaneamente.</p> Signup and view all the answers

Por que é necessário um protocolo de cooperação entre os processos em relação à Seção Crítica?

<p>É necessário para que cada processo solicite permissão para entrar em sua região crítica, evitando conflitos e garantindo a exclusão mútua.</p> Signup and view all the answers

Como a condição de corrida pode afetar um programa?

<p>Pode levar a comportamentos inesperados e difíceis de reproduzir.</p> Signup and view all the answers

O que é importante considerar no projeto de sistemas operacionais em relação à exclusão mútua?

<p>Escolher operações primitivas adequadas para garantir a exclusão mútua.</p> Signup and view all the answers

O que é um processo cooperativo?

<p>Processo cooperativo é aquele que pode afetar ou ser afetado por outros processos em execução.</p> Signup and view all the answers

Dê um exemplo de problema que pode ocorrer com o acesso concorrente a dados compartilhados.

<p>Dois processos em um sistema de reserva de passagens aéreas tentando reservar o último assento para clientes distintos.</p> Signup and view all the answers

O que é o Problema do Produtor-Consumidor?

<p>O Problema do Produtor-Consumidor envolve processos que compartilham um buffer, onde o produtor insere itens e o consumidor remove.</p> Signup and view all the answers

Explique o que acontece no Problema do Produtor-Consumidor se o buffer estiver cheio.

<p>Se o buffer estiver cheio, o produtor não fará nada, pois o código contém um loop while que aguarda até que haja espaço disponível.</p> Signup and view all the answers

Qual é a função do método 'insert' no código do Produtor?

<p>A função do método 'insert' é adicionar um item ao buffer compartilhado, desde que haja espaço disponível.</p> Signup and view all the answers

Por que é importante manipular a variável 'count' de forma concorrente no Problema do Produtor-Consumidor?

<p>É importante manipular a variável 'count' de forma concorrente para garantir consistência na contagem de itens no buffer compartilhado.</p> Signup and view all the answers

O que é a seção crítica em um processo?

<p>É a parte do código onde o processo acessa e modifica recursos compartilhados.</p> Signup and view all the answers

Quais são os dois requisitos fundamentais para garantir a exclusão mútua?

<p>Progresso e Espera Limitada.</p> Signup and view all the answers

Como o suporte de hardware pode ser utilizado para resolver o problema da seção crítica?

<p>Desabilitando interrupções enquanto uma variável compartilhada está sendo modificada.</p> Signup and view all the answers

Por que não é prudente dar o poder aos processos de desligar as interrupções?

<p>Porque se o processo não as reabilitar, o funcionamento do sistema pode ficar comprometido.</p> Signup and view all the answers

Quando as interrupções são desabilitadas em um sistema?

<p>Cada processo desabilita todas as interrupções ao entrar em sua seção crítica e as reabilita ao sair.</p> Signup and view all the answers

Quais são algumas soluções de software para exclusão mútua?

<p>Variável trava (lock), Chaveamento obrigatório, Solução de Peterson, Semáforos e Monitores.</p> Signup and view all the answers

Como funciona a Variável de Trava (lock) para exclusão mútua?

<p>É uma variável compartilhada que indica se a trava está liberada (0) ou ocupada (1).</p> Signup and view all the answers

Qual é a importância da instrução Atômica no contexto da seção crítica?

<p>A instrução Atômica garante que certas operações sejam realizadas sem interrupções, mantendo a consistência dos recursos compartilhados.</p> Signup and view all the answers

O que significa Progresso no contexto da exclusão mútua?

<p>Significa que a seleção do processo para a seção crítica não pode ser adiada indefinidamente.</p> Signup and view all the answers

Por que é importante ter um limite no número de vezes que outros processos podem entrar em suas seções críticas?

<p>Para evitar a starvation, garantindo que nenhum processo espere indefinidamente para entrar na sua região crítica.</p> Signup and view all the answers

Qual é o problema da forma original de controle de acesso à seção crítica?

<p>Condições de corrida</p> Signup and view all the answers

O que é uma trava giratória (spin lock) e qual é o problema associado a ela?

<p>É uma variável de trava que usa espera ociosa. O problema associado é a espera ocupada (busy waiting), onde um processo fica testando continuamente a mudança do valor da variável, consumindo ciclos de CPU.</p> Signup and view all the answers

Como a Solução de Peterson evita o problema da espera ocupada (busy waiting) presente na trava giratória?

<p>A Solução de Peterson utiliza um array compartilhado 'interested' e a variável 'turn' para controlar quem entra na região crítica. Isso possibilita a exclusão mútua entre dois processos sem a necessidade de espera ocupada.</p> Signup and view all the answers

O que são semáforos e como são usados para implementar exclusão mútua?

<p>Os semáforos são mecanismos para implementar exclusão mútua e sincronização de processos. São utilizados com operações 'acquire' e 'release' para controlar o acesso a regiões críticas.</p> Signup and view all the answers

O que um semáforo binário (mutex) indica e como é utilizado para proteger uma região crítica?

<p>Um semáforo binário possui apenas dois valores possíveis: 0 ou 1, indicando se a seção crítica está disponível (1) ou em uso (0). É utilizado com as operações 'acquire' e 'release' para proteger o acesso a uma região crítica.</p> Signup and view all the answers

Como o semáforo é inicializado para garantir a exclusão mútua?

<p>O semáforo é inicializado em 1, indicando que a seção crítica está disponível para acesso. Isso garante que no início apenas um processo poderá acessar a região crítica.</p> Signup and view all the answers

Quais operações são realizadas no 'acquire' e no 'release' ao utilizar semáforos?

<p>No 'acquire', é testada a possibilidade de acessar a seção crítica e o semáforo é decrementado para impedir outros processos. No 'release', o semáforo é incrementado para liberar a região crítica.</p> Signup and view all the answers

O que significa a expressão 'Exclusão mútua' no contexto de semáforos?

<p>Exclusão mútua refere-se à capacidade de apenas um processo acessar uma região crítica por vez, evitando condições de corrida e garantindo a integridade dos dados compartilhados.</p> Signup and view all the answers

Por que os semáforos são considerados essenciais para a sincronização de processos?

<p>Os semáforos permitem coordenar a execução de processos concorrentes, proteger regiões críticas e evitar condições de corrida, garantindo a correta sincronização das operações.</p> Signup and view all the answers

Quais são as vantagens de utilizar semáforos na implementação de exclusão mútua em sistemas concorrentes?

<p>As vantagens incluem a capacidade de controlar o acesso a regiões críticas, prevenir condições de corrida, garantir a exclusão mútua entre processos e facilitar a sincronização de operações concorrentes.</p> Signup and view all the answers

More Like This

Use Quizgecko on...
Browser
Browser