Compartilhar via


Modelo de função winrt::try_capture (C++/WinRT)

Um modelo de função que chama uma função ou método especificado (chamando automaticamente winrt::check_hresult nele), captura o ponteiro de interface que é saída da função ou método e retorna-o como o parâmetro typename T de modelo se T deriva de Windows::Foundation::IUnknown, caso contrário, retorna um winrt::com_ptr. Retorna um com_ptr vazio se não for bem-sucedido.

Consulte também a função winrt::com_ptr::try_capture.

Syntax

template <typename T, typename F, typename...Args>
impl::com_ref<T> try_capture(F function, Args&& ...args);

template <typename T, typename O, typename M, typename...Args>
impl::com_ref<T> try_capture(O* p, M method, Args&& ...args);

template <typename T, typename O, typename M, typename...Args>
impl::com_ref<T> try_capture(com_ptr<O> const& object, M method, Args&& ...args);

Parâmetros de modelo

typename T O tipo do ponteiro de interface que é saída da função ou método.

typename F Um tipo de objeto de função, como uma função gratuita, ou std::function.

typename O Um tipo de interface.

typename M Um tipo de método.

typename Args Zero ou mais tipos de argumento.

Parâmetros

function Um objeto de função do tipo F.

p Um ponteiro para um objeto do tipo O.

object Um winrt::com_ptr do tipo O.

method Um método (implementado por O) do tipo M.

args Zero ou mais argumentos do tipo Args.

Valor retornado

Retorna T se T deriva de Windows::Foundation::IUnknown, caso contrário, retorna winrt::com_ptr. Retorna um com_ptr vazio se não for bem-sucedido.

Comentários

  • A try_capture(F function, Args&&...args) sobrecarga invoca o objeto de função.
  • A try_capture(O* p, M method, Args&& ...args) sobrecarga invoca o método no ponteiro.
  • A try_capture(winrt::com_ptr<O> const& object, M method, Args&&...args) sobrecarga invoca o método no objeto.

Todas as sobrecargas passam (para a invocação) quaisquer argumentos adicionais que você fornecer. Todas as sobrecargas também passam pelos dois argumentos adicionais que essas invocações exigem, especificamente, uma REFIID (a ID do destino do winrt::com_ptr) e um void** (o endereço de um ponteiro para o destino do winrt::com_ptr).

Requisitos

SDK mínimo com suporte: Windows SDK versão 10.0.17134.0 (Windows 10, versão 1803)

Namespace: winrt

Cabeçalho: %WindowsSdkDir%IncludeWindowsTargetPlatformVersion<>\cppwinrt\winrt\base.h (incluído por padrão)

Confira também