Re seu último Q - a versão curta: A mensagem de erro é sobre o espaço de endereço virtual "comprometido". Se você olhar para o gráfico Commit Charge no seu segundo instantâneo de tela, verá que está de fato no limite ou muito próximo dele.
A quantidade de RAM "livre", "disponível" ou "em uso" não importa. Em particular, a falta de RAM "disponível" não é absolutamente a razão para a mensagem "pouca memória" ou "falta de memória".
O limite de confirmação é igual ao total de RAM + tamanho do arquivo de paginação. Quando a memória comprometida é alocada, ela é imediatamente cobrada para "commit charge", mesmo que ela não tenha sido usada ainda ... significando que nenhum espaço RAM ou PF é usado imediatamente. O espaço físico (seja na RAM ou no arquivo de paginação) é usado apenas quando a memória é realmente referenciada. A partir de então, deve haver algum lugar para estar, até que o programa o liberte, ou todo o processo termine.
Exemplo: suponha que você não tenha um arquivo de paginação, portanto seu limite de confirmação é de 16 GB (seu tamanho de RAM). Agora, suponha que 8 processos tentem cada um com VirtualAlloc (MEM_COMMIT) 1 GB. Resultado: a carga de confirmação é aumentada em 8 GB. Não há impacto imediato na RAM, no entanto! É como se você comprasse um bloco de papel na papelaria, mas na verdade não comprou nenhum papel. Toda vez que você precisa de uma nova folha, porém, uma magicamente aparece. Até você usar todo o bloco (o tamanho da região alocada).
Suponha agora que cada um desses processos realmente acessa 100 MB de seu 1 GB. A RAM usada seria de apenas 800 MB.
Mas como cada um deles pode referenciar todo o seu 1 GB, o sistema operacional precisa garantir 8 GB de RAM + espaço no arquivo de paginação ... bem, apenas RAM no caso de nenhum arquivo de paginação. .. é mantido disponível apenas no caso de isso acontecer. Voltando à papelaria, eles precisam manter papel suficiente em estoque para dar a todos o mesmo número de folhas que compraram anteriormente.
Consequentemente, o sistema operacional precisa parar de permitir que o VirtualAlloc (MEM_COMMIT) seja bem-sucedido quando o valor atual confirmado atingir o limite.
Por quê? Porque o processo é esperado para verificar o resultado do VirtualAlloc para ver se ele foi bem-sucedido. Depois de fazer isso e descobrir que a alocação foi bem-sucedida, o processo tem todo o direito de esperar que suas referências subsequentes a toda a região confirmada sejam bem-sucedidas.
Se o Windows permitisse que a taxa de confirmação excedesse a quantidade de espaço disponível para realizar esse espaço, essa expectativa nem sempre poderia ser atendida.
Uma solução rápida é aumentar o tamanho padrão (= inicial) do seu arquivo de paginação. A partir da explicação acima, você deve ser capaz de ver por que isso evitará a mensagem de erro mesmo que nada jamais possa ser gravado nesse arquivo . Novamente, o sistema operacional está garantindo que o espaço para toda a carga de commit esteja disponível caso precise dele . Quando os processos alocam a memória comprometida, eles estão apenas dizendo "ei, SO, eu poderia precisar disso". Isso não significa que eles realmente vão usá-lo, e isso certamente não significa que eles realmente o usaram ainda.
Para mais, veja minha resposta aqui .
Agora .... por que você está usando muito commit quando seus processos não parecem se encaixar é outra questão. Para começar a ver isso, mostre a guia Desempenho do Gerenciador de Tarefas, seção Memória.