Compartilhar via


Manifesto do aplicativo

Plataformas afetadas

clientes – Windows 7
servidores – Windows Server 2008 R2

Impacto do recurso

de gravidade – Baixa
de Frequência – Baixa

Descrição

O Windows 7 apresenta uma nova seção no manifesto do aplicativo chamada "Compatibilidade". Esta seção ajuda o Windows a determinar as versões do Windows que um aplicativo foi projetado para ser direcionado e permite que o Windows forneça o comportamento que o aplicativo espera com base na versão do Windows direcionada ao aplicativo.

A seção Compatibilidade permite que o Windows forneça um novo comportamento ao novo software criado pelo desenvolvedor, mantendo a compatibilidade com o software existente. Esta seção também ajuda o Windows a oferecer maior compatibilidade em versões futuras do Windows. Por exemplo, um aplicativo declarando suporte apenas para o Windows 7 na seção Compatibilidade continuará recebendo o comportamento do Windows 7 na versão futura do Windows.

Manifestação de alteração

Aplicativos sem uma seção de compatibilidade em seu manifesto receberão o comportamento do Windows Vista por padrão no Windows 7 e em versões futuras do Windows. Observe que o Windows XP e o Windows Vista ignoram esta seção de manifesto e isso não tem impacto sobre eles.

Os seguintes componentes do Windows fornecem um comportamento divergente com base na seção de compatibilidade no Windows 7:

do Pool de Threads Padrão do RPC

  • Windows 7: Para melhorar a escalabilidade e reduzir as contagens de threads, o RPC mudou para o pool de threads NT (pool padrão). Para o Windows Vista, o RPC usou um pool de threads privado.
    • Para binários compilados para Win7, o pool padrão é usado
    • Se I_RpcMgmtEnableDedicatedThreadPool for chamado antes que qualquer API RPC seja chamada, o pool de threads privado será usado (comportamento do Vista)
    • Se I_RpcMgmtEnableDedicatedThreadPool for chamado após uma chamada RPC, o pool padrão será usado, I_RpcMgmtEnableDedicatedThreadPool retornará o erro 1764 e a operação solicitada não terá suporte
  • Windows Vista (padrão): Para binários compilados para o Windows Vista e abaixo, o pool privado é usado.

de Bloqueio do DirectDraw

  • Windows 7: Aplicativos manifestados para Windows 7 não podem chamar a API de Bloqueio no DDRAW para bloquear o buffer de vídeo da Área de Trabalho principal. Isso resultará em erro e ponteiro nulo para o primário será retornado. Esse comportamento é imposto mesmo se a Composição do Gerenciador de Janelas da Área de Trabalho não estiver ativada. Os aplicativos compatíveis com o Windows 7 não devem bloquear o buffer de vídeo primário a ser renderizado.
  • Windows Vista (padrão): Aplicativos poderão adquirir um bloqueio no buffer de vídeo primário, pois os aplicativos herdados dependem desse comportamento. A execução do aplicativo desativa o Gerenciador de Janelas da Área de Trabalho.

DirectDraw Bit Block Transfer (Blt) para Primary sem de Janela de Recorte

  • Windows 7: Aplicativos manifestados para Windows 7 são impedidos de executar blts para o buffer de vídeo da Área de Trabalho principal sem uma janela de recorte. Isso resultará em erro e a área Blt não será renderizada. O Windows impõe esse comportamento mesmo se você não ativar a Composição do Gerenciador de Janelas da Área de Trabalho. Os aplicativos compatíveis com o Windows 7 devem ser Blt em uma janela de recorte.
  • Windows Vista (padrão): Aplicativos devem ser capazes de usar o Blt para o primário sem uma janela de recorte, pois os aplicativos herdados dependem desse comportamento. A execução desse aplicativo desativa o Gerenciador de Janelas da Área de Trabalho.

da API GetOverlappedResult

  • Windows 7: Resolve uma condição de corrida em que um aplicativo multithread usando GetOverlappedResult pode retornar sem redefinir o evento na estrutura sobreposta, fazendo com que a próxima chamada para essa função retorne prematuramente.
  • Windows Vista (padrão): Fornece o comportamento com a condição de corrida na qual os aplicativos podem ter uma dependência. Os aplicativos que desejam evitar essa corrida antes do comportamento do Windows 7 devem aguardar o evento sobreposto e, quando sinalizados, chamar GetOverlappedResult com bWait == FALSE.

do PCA (Assistente de Compatibilidade do Programa)

  • Windows 7: a seção Aplicativos com Compatibilidade não obterá a mitigação de PCA.
  • Windows Vista (padrão): Aplicativos que não instalam corretamente ou falham durante o runtime em algumas circunstâncias específicas obterão a mitigação de PCA. Para obter mais detalhes, consulte a seção de referência.

Aproveitando recursos de recursos

Atualize o manifesto do aplicativo com as informações de compatibilidade mais recentes para o suporte ao sistema operacional. A seção descreve as adições ao manifesto:

  • Namespace: Compatibility.v1 (xmlns="urn:schemas-microsoft-com:compatibility.v1">)

  • Nome da Seção: Compatibilidade (nova seção)

  • SupportedOS: GUID do sistema operacional com suporte – os GUIDs que são mapeados para os sistemas operacionais com suporte são:

    • {e2011457-1546-43c5-a5fe-008deee3d3f0} para Windows Vista: esse é o valor padrão para o contexto de alternância.
    • {35138b9a-5d96-4fbd-8e2d-a2440225f93a} para Windows 7: aplicativos que definem esse valor no manifesto do aplicativo obtêm o comportamento do Windows 7.

    Nota

    A Microsoft gerará e postará GUIDs para versões futuras do Windows, conforme necessário.

     

Veja a seguir um exemplo de um manifesto atualizado.

Nota

O atributo e os nomes de marca no manifesto do aplicativo diferenciam maiúsculas de minúsculas.

 

<?xml version="1.0" encoding="UTF-8" standalone="yes"?> 
  <assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0"> 
    <compatibility xmlns="urn:schemas-microsoft-com:compatibility.v1"> 
      <application> 
        <!--The ID below indicates application support for Windows Vista --> 
          <supportedOS Id="{e2011457-1546-43c5-a5fe-008deee3d3f0}"/> 
        <!--The ID below indicates application support for Windows 7 --> 
          <supportedOS Id="{35138b9a-5d96-4fbd-8e2d-a2440225f93a}"/> 
      </application> 
    </compatibility>
  </assembly>

O valor de adicionar GUIDs para ambos os sistemas operacionais no exemplo acima é fornecer suporte de nível inferior. Aplicativos que dão suporte a ambas as plataformas não precisariam de manifestos separados para cada plataforma.

Teste de compatibilidade, desempenho, confiabilidade e usabilidade

  1. Teste o aplicativo com a nova seção de compatibilidade e SupportedOS ID ={35138b9a-5d96-4fbd-8e2d-a2440225f93a} para garantir que o aplicativo funcione corretamente usando o comportamento mais recente do Windows 7
  2. Teste o aplicativo com a nova seção de compatibilidade e SupportedOS ID ={e2011457-1546-43c5-a5fe-008deee3d3f0} (ou sem esta seção inteiramente) para garantir que o aplicativo funcione corretamente usando os comportamentos do Windows Vista no Windows 7

Problemas conhecidos

Incompatibilidade de contexto Um aplicativo é executado em um contexto do Windows Vista em vez de em um contexto do Windows 7 em um computador que executa uma edição x64 do Windows 7 ou do Windows Server 2008 R2.

Solução Atualizações estão disponíveis para corrigir isso para todas as versões baseadas em x64 com suporte do Windows 7 e windows Server 2008 R2, bem como para todas as versões baseadas em Itanium com suporte do Windows Server 2008 R2. Vá para a página suporte da Microsoft para 978637 de KB: um aplicativo é executado em um contexto do Windows Vista em vez de em um contexto do Windows 7 em um computador que está executando uma edição x64 do Windows 7 ou do Windows Server 2008 R2 para obter detalhes adicionais e baixar a versão correta para seu sistema.

diagnóstico de despejo de memória bloqueado

Solution Ir para a página suporte da Microsoft para 976038 de KB: exceções geradas de um aplicativo executado em uma versão de 64 bits do Windows são ignoradas para obter detalhes adicionais.