Exceções em runtime em aplicativos do .NET Native
É importante testar os builds de versão do seu aplicativo da Plataforma Universal do Windows nas respectivas plataformas de destino, porque as configurações de depuração e de lançamento são completamente diferentes. Por padrão, a configuração de depuração usa o runtime do .Net Core para compilar seu aplicativo, mas a configuração de lançamento usa .NET Native para compilar seu aplicativo em código nativo.
Importante
Para obter informações sobre como lidar com as exceções MissingMetadataException, MissingInteropDataException e MissingRuntimeArtifactException que você pode encontrar ao testar as versões de lançamento do seu aplicativo, consulte "Etapa 4: resolver manualmente metadados ausentes: no tópico Introdução, bem como Reflexão e .NET Native e Referência do arquivo de configuração (rd.xml) de diretivas de tempo de execução.
Builds de depuração e de versão
Quando o build de depuração é executado no runtime do .Net Core, ele não foi compilado para código nativo. Isso torna todos os serviços normalmente fornecidos pelo runtime disponíveis para seu aplicativo.
Por outro lado, o build de versão é compilado em código nativo para suas plataformas de destino, remove a maioria das dependências de bibliotecas e runtimes externos e otimiza muito o código para obter o máximo de desempenho.
Quando você depura builds de versão que são compilados usando o .NET Native:
Você usa o mecanismo de depuração do .NET Native, que é diferente das ferramentas de depuração normais do .NET.
O tamanho de seu executável é reduzido tanto quanto possível. Uma das maneiras pelas quais o .NET Native reduz o tamanho de um executável é cortando significativamente as mensagens de exceção de runtime, um tópico discutido em maiores detalhes na seção Mensagens de exceção de runtime.
Seu código é altamente otimizado. Isso significa que inlining é usado sempre que possível. (O embutimento move o código de rotinas externas para a rotina de chamada.) O fato de o .NET Native fornecer um runtime especializado e implementar o embutimento agressivo afeta a pilha de chamadas exibida durante a depuração. Para obter mais informações, consulte a seção Pilha de chamadas de runtime.
Observação
Você pode controlar se os builds de depuração e de versão são compilados com a cadeia de ferramentas do .NET Native, marcando ou desmarcando a caixa Compilar com cadeia de ferramentas do .NET Native. No entanto, a Microsoft Store sempre compilará a versão de produção do seu aplicativo com a cadeia de ferramentas do .NET Native.
Mensagens de exceção de runtime
Para minimizar o tamanho do executável do aplicativo, o .NET Native não inclui o texto completo das mensagens de exceção. Como resultado, exceções de runtime geradas em builds de versão podem não exibir o texto completo das mensagens de exceção. Em vez disso, o texto pode conter uma subcadeia de caracteres junto com um link para mais informações. Por exemplo, as informações de exceção podem aparecer como:
Exception thrown: '$16_System.AggregateException' in Unknown Module.
Additional information: AggregateException_ctor_DefaultMessage
If there is a handler for this exception, the program may be safely continued.
Se você precisar que a mensagem de exceção completa, execute o build de depuração em vez disso. Por exemplo, as informações de exceção anteriores do build de versão podem aparecer da seguinte maneira no build de depuração:
Exception thrown: 'System.AggregateException' in NativeApp.exe.
Additional information: Value does not fall within the expected range.
Pilha de chamadas de runtime
Devido ao inlining e outras otimizações, a pilha de chamadas exibida por um aplicativo compilado pela cadeia de ferramentas do .NET Native pode não lhe ajudar a identificar claramente o caminho para uma exceção de runtime.
Para obter a pilha completa, execute o build de depuração em vez disso.