- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为什么在析构函数中对 IWICImagingFactory 对象调用继承的 IUnknown::Release() 函数会导致“CXX0030:错误:无法计算表达式”显示在对象的虚函数表 (__vfptr) 中的每个条目?
这是引用我之前发布的一个问题,但后来我意识到问题只发生在析构函数中。虚函数表在我检查过的其他任何地方都有效。但是,在析构函数中,所有条目都显示为 CXX0030 错误,并且尝试调用继承的 IUknown::Release() 失败。
编辑:这里有一些代码来演示:
HRESULT DemoApp::CreateDeviceIndependentResources()
{
HRESULT hr;
hr = D2D1CreateFactory(D2D1_FACTORY_TYPE_SINGLE_THREADED, &mpDirect2DFactory);
if (SUCCEEDED(hr))
{
hr = CoCreateInstance(
CLSID_WICImagingFactory,
NULL,
CLSCTX_INPROC_SERVER,
IID_PPV_ARGS(&mpWICFactory)
);
}
//CoCreateInstance returns S_OK.
//Other unrelated code here.
}
HRESULT DemoApp::CreateDeviceResources()
{
HRESULT hr;
//Other unrelated code here for creating device-dependant resources.
//mpBackgroundBitmap is a ID2D1Bitmap*.
if(SUCCEEDED(hr))
{
hr = LoadBitmapFromFile(
mpRenderTarget,
mpWICFactory,
L".\\background.png",
0,
0,
&mpBackgroundBitmap);
}
}
//The below LoadBitmapFromFile() code is taken directly from an MSDN sample.
//I didn't write it.
HRESULT DemoApp::LoadBitmapFromFile(
ID2D1RenderTarget *pRenderTarget,
IWICImagingFactory *pIWICFactory,
PCWSTR uri,
UINT destinationWidth,
UINT destinationHeight,
ID2D1Bitmap **ppBitmap
)
{
IWICBitmapDecoder *pDecoder = NULL;
IWICBitmapFrameDecode *pSource = NULL;
IWICStream *pStream = NULL;
IWICFormatConverter *pConverter = NULL;
IWICBitmapScaler *pScaler = NULL;
HRESULT hr = pIWICFactory->CreateDecoderFromFilename(
uri,
NULL,
GENERIC_READ,
WICDecodeMetadataCacheOnLoad,
&pDecoder
);
if (SUCCEEDED(hr))
{
// Create the initial frame.
hr = pDecoder->GetFrame(0, &pSource);
}
if (SUCCEEDED(hr))
{
// Convert the image format to 32bppPBGRA
// (DXGI_FORMAT_B8G8R8A8_UNORM + D2D1_ALPHA_MODE_PREMULTIPLIED).
hr = pIWICFactory->CreateFormatConverter(&pConverter);
}
if (SUCCEEDED(hr))
{
// If a new width or height was specified, create an
// IWICBitmapScaler and use it to resize the image.
if (destinationWidth != 0 || destinationHeight != 0)
{
UINT originalWidth, originalHeight;
hr = pSource->GetSize(&originalWidth, &originalHeight);
if (SUCCEEDED(hr))
{
if (destinationWidth == 0)
{
FLOAT scalar = static_cast<FLOAT>(destinationHeight) / static_cast<FLOAT>(originalHeight);
destinationWidth = static_cast<UINT>(scalar * static_cast<FLOAT>(originalWidth));
}
else if (destinationHeight == 0)
{
FLOAT scalar = static_cast<FLOAT>(destinationWidth) / static_cast<FLOAT>(originalWidth);
destinationHeight = static_cast<UINT>(scalar * static_cast<FLOAT>(originalHeight));
}
hr = pIWICFactory->CreateBitmapScaler(&pScaler);
if (SUCCEEDED(hr))
{
hr = pScaler->Initialize(
pSource,
destinationWidth,
destinationHeight,
WICBitmapInterpolationModeCubic
);
}
if (SUCCEEDED(hr))
{
hr = pConverter->Initialize(
pScaler,
GUID_WICPixelFormat32bppPBGRA,
WICBitmapDitherTypeNone,
NULL,
0.f,
WICBitmapPaletteTypeMedianCut
);
}
}
}
else // Don't scale the image.
{
hr = pConverter->Initialize(
pSource,
GUID_WICPixelFormat32bppPBGRA,
WICBitmapDitherTypeNone,
NULL,
0.f,
WICBitmapPaletteTypeMedianCut
);
}
}
if (SUCCEEDED(hr))
{
// Create a Direct2D bitmap from the WIC bitmap.
hr = pRenderTarget->CreateBitmapFromWicBitmap(
pConverter,
NULL,
ppBitmap
);
}
SafeRelease(&pDecoder);
SafeRelease(&pSource);
SafeRelease(&pStream);
SafeRelease(&pConverter);
SafeRelease(&pScaler);
return hr;
}
//Now I call SafeRelease() in my destructor and the virtual function table entires are showing the error.
DemoApp::~DemoApp()
{
SafeRelease(&mpDirect2DFactory);
SafeRelease(&mpWICFactory); //here is the problem apparently
SafeRelease(&mpDWriteFactory);
SafeRelease(&mpRenderTarget);
SafeRelease(&mpBackgroundBitmap);
}
//SafeRelease is defined as:
template<class Interface>
inline void SafeRelease(Interface** ppInterfaceToRelease)
{
if(*ppInterfaceToRelease != NULL)
{
(*ppInterfaceToRelease)->Release();
(*ppInterfaceToRelease) = NULL;
}
}
问题是当我在 WICFactory 对象上调用 SafeRelease() 时,我得到:DemoApp.exe 中 0x0024e135 处的第一次机会异常:0xC0000005:访问冲突读取位置 0x6d5c28f0。DemoApp.exe 中 0x0024e135 处的未处理异常:0xC0000005:访问冲突读取位置 0x6d5c28f0。
最佳答案
我最近也在为这个问题苦苦挣扎。问题在于,IWICImagingFactory
的创建和释放分别取决于之前和之后调用的 CoInitialize
/CoUninitialize
。在您的应用程序中,很可能在析构函数中释放 IWICImagingFactory
之前调用了 CoUninitialize()
,这会导致崩溃。请注意,ID2D1RenderTarget
等似乎不受影响,在调用 CoUninitialize()
后仍可释放。
从 RunMessageLoop()
或任何地方删除对 CoUninitialize()
的调用,并将其放在析构函数中的释放调用之后,崩溃应该就会消失。
关于c++ - 在析构函数中调用 Inherited IUnknown::Release(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7632066/
为什么 Visual Studio 编译器满意 void fn(int *&i) { ; } 和 void fn(IUnknown *const &p) { ; } 但不是 void
如果我有 IUnknown *ptr , 我需要调用Release()在我通过ptr->QueryInterface()获得的每个界面上, 另外调用ptr->Release()当我完成 ptr ? 我
使用接口(interface)时的大量示例,例如 IUnknown ,在本例中为 IDocHostUIHandler但这并不重要 - 使用与此类似的代码: class TDocHostUIHandl
我正在尝试使用带有 ATL 的 COM 聚合来实现共享逻辑。我定义了一个基类,称为CameraBase ,这只能通过聚合获得。为此,我添加了 aggregateable注释为 coclass -声明。
我需要将一个未知类型的变量转换为另一个类型type(SpaceClaim::Api::V10::Session^) 我正在使用 c/cli,我找不到任何解决方案 修复这个 prb 的代码是: gcr
我正在尝试创建一个实现 IUnknown 接口(interface)的类。我在头文件中有以下代码: #pragma once #include "stdafx.h" #include "Unknwn.
这是实现 IUnknown COM 的Release 方法的标准(不是推荐)方法界面(直接取自MSDN): ULONG CMyMAPIObject::Release() { // Decrem
我有相同代码的两个变体: {$APPTYPE CONSOLE} uses System.SysUtils; type IMyObject1 = interface ['{4411181
当我使用类型库导入程序将特定于 .net dll 的 tlb 文件导入 Delphi 时,接受 .net 特定类型参数的方法被 IUnknown 替换。当我想从我的 Delphi 客户端应用程序调用这
我是 COM 新手。为什么接口(interface)方法 QueryInterface AddRef 和 Release 被声明为具有 __stdcall 而不是任何其他调用(__cdlecl、__t
为什么在析构函数中对 IWICImagingFactory 对象调用继承的 IUnknown::Release() 函数会导致“CXX0030:错误:无法计算表达式”显示在对象的虚函数表 (__vfp
ATL END_COM_MAP宏定义如下: #define END_COM_MAP() \ __if_exists(_GetAttrEntries) {{NULL, (DWORD_PTR)_G
如何在运行时检查 void* 是否为 IUnknown*? IUnknown *unk = dynamic_cast(item); 不工作(编译错误)。 最佳答案 您无法在运行时明确地确定这一点。您无
我在 VB6 中有一个属性,我正试图将其转换为 C#。具体如下: Public Property Get NewEnum() As IUnknown 'this property allows
我一直在寻找如何实现 IUnknown 的示例在 C# 中,但还没有找到任何合适的引用或解决方案。 是否应该像...一样简单 public interface IUnknown { UInt3
我正在 Delphi 中创建一个 ActiveX 服务器来替换在 Delphi 中创建的 native DLL,以便可以在 .NET 中调用它。 (我是 Delphi 新手,更喜欢 C#) 原始 DL
我从类型库(硬件 SDK 的一部分)导入的 COM 接口(interface)的一些方法返回或接收 IUnknown 类型的值。例如,SDK文档指定的方法如下: bool SetInput1Selec
在标题中,包含以下代码。 inline void SafeRelease( IUnknown * & in_COM_Pointer ) { if ( NULL != in_CO
从例子中我看到 COM IUnknown::Release() 函数实现是这样的: ULONG Release() { InterlockedDecrement(&m_count);
我写了两个小的 C++ 应用程序,其中一个是嵌入了一些 ActiveX 控件的 ActiveX 容器。此容器应用程序知道引用 ActiveX 控件的 IUnknown*。 另一个应用程序是一个客户端,
我是一名优秀的程序员,十分优秀!