如何解决C2280'winrt :: hstring :: hstringstd :: nullptr_t':尝试引用已删除的函数
在cppcx中,我有这段代码:
auto frame = ref new Frame();
frame->Navigate(TypeName(CppCxInternalRefClass::typeid),ref new AnotherCppCxInternalRefClass(a,b,c,...));
我正试图将其转换为cppwinrt:
Frame frame;
frame.Navigate(
utils::from_cx<winrt::TypeName>(TypeName(CppCxInternalRefClass::typeid)),utils::from_cx<winrt::Windows::UI::Xaml::FrameworkElement>(
ref new AnotherCppCxInternalRefClass(a,...)));
但是我遇到一个错误:
错误C2280'winrt :: hstring :: hstring(std :: nullptr_t)':尝试执行以下操作: 引用已删除的功能
这是我收到错误的函数和行:
template <typename T>
T from_cx(Platform::Object ^ from) {
===>T to{nullptr};
winrt::guid iid = winrt::guid_of<T>();
winrt::check_hresult(reinterpret_cast<::IUnknown*>(from)->QueryInterface(
reinterpret_cast<GUID&>(iid),reinterpret_cast<void**>(winrt::put_abi(to))));
return to;
就像C ++ / CX一样,我们只需执行此代码正在执行的ClassName:typeId,就可以获取类的typeid。因此,有一个TypeName构造函数将其作为参数。但是在cppwinrt中更改为结构后,它期望两个结构变量都使用初始化程序。我不确定如何处理此问题,尤其是在此代码中的ref类上,由于目前缺乏对idl的支持,我的代码库尚未准备好移植到cppwinrt。因此,我决定只使用cppcx代码,但使用辅助函数对其进行转换,但是在转换时会遇到此错误。
但是,如果我将方法更改为这样的话:
auto cppCxFrame = utils::to_cx<Frame>(frame);
cppCxFrame->Navigate(TypeName(CppCxInternalRefClass::typeid),...));
它构建良好。
解决方法
如果您可以通过winmd获得C ++ / CX类的投影,那么这将很容易。假设您无法执行此操作,则需要从C ++ / CX TypeName
转换为C ++ / WinRT TypeName
。基本的from_cx
不会这样做,因为TypeName
是一个结构,而不是运行时类,但是添加from_cx
的重载来处理TypeName
结构是很简单的,并且hstring
所在的位置。
winrt::hstring from_cx(Platform::String^ const& from)
{
winrt::hstring to;
const HSTRING& fromHstring = reinterpret_cast<HSTRING>(from);
winrt::copy_from_abi(to,fromHstring);
return to;
}
winrt::Windows::UI::Xaml::Interop::TypeName from_cx(::Windows::UI::Interop::TypeName const& from)
{
return {
static_cast<winrt::Windows::UI::Xaml::Interop::TypeKind>(from.Kind),from_cx(from.Name)
};
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。