Memoria compartilhada

Definição - o que significa memória compartilhada?

Memória compartilhada para software é um tipo de memória que pode ser compartilhada por vários aplicativos ou processos com a intenção de fornecer comunicação entre aplicativos ou evitar cópias de dados redundantes. Este é um meio eficiente de compartilhar ou transmitir dados porque elimina a necessidade de usar outro processo como entrada / saída (E / S). Um aplicativo salva os dados na memória compartilhada, enquanto outro aplicativo pode usá-lo quando encontrado.

No contexto dos processadores, a memória compartilhada é uma parte da memória de acesso aleatório (RAM) que pode ser acessada por todos os processadores em um sistema multiprocessador.

Definirtec explica memória compartilhada

A memória compartilhada para software é uma maneira de diferentes programas se comunicarem e transmitirem dados sem mais sobrecarga dos processos de comunicação. Com a memória compartilhada, um programa grava na memória compartilhada todos os dados que outro programa precisa receber.

Por exemplo, se o Programa A deseja fornecer uma lista ao Programa B, ele salva os dados na memória compartilhada e os marca com um semáforo ou outro sistema de sinalização para indicar que está pronto para ser lido pelo Programa B.

Quando o Programa B encontra o arquivo, ele verifica o semáforo para ver se tem permissão para tocar nesse arquivo. Se permitido, ele faz o que precisa ser feito com o arquivo, coloca-o na memória compartilhada ou o atualiza. Ele também atualiza o semáforo, para que o Programa A saiba que deve pegar o arquivo.

Em termos de hardware, especificamente microprocessadores, a memória compartilhada é um grande bloco de RAM usado por vários processadores. É fácil de programar porque todos os processadores compartilham a mesma visualização de dados, facilitando a comunicação mais rápida. No entanto, isso pode ficar complicado porque os processadores armazenam em cache a memória para acesso mais rápido, o que pode levar a problemas como coerência do cache.