从X读取无效数据:可读大小为Y字节,但可能读取Z字节

Bul*_*aza 4 c++ windows gdi+ visual-studio

我更新了Visual Studio 2019版本16.1.3,现在在基于库的函数中收到警告GDI+以获取编码器:

inline int get_encoder(const WCHAR* format, CLSID* p_clsid)
{
    UINT image_encoders_count = 0;
    UINT image_encoder_array_size = 0;

    GetImageEncodersSize(&image_encoders_count, &image_encoder_array_size);
    if (image_encoder_array_size == 0)
    {
        return -1; // Failure
    }

    const auto p_image_codec_info = static_cast<ImageCodecInfo*>(malloc(image_encoder_array_size));
    if (p_image_codec_info == nullptr)
    {
        return -1; // Failure
    }

    GetImageEncoders(image_encoders_count, image_encoder_array_size, p_image_codec_info);

    for (UINT image_encoder_index = 0; image_encoder_index < image_encoders_count; image_encoder_index++)
    {
        // TODO: Fix the warning "Reading invalid data from 'p_image_codec_info':  the readable size is 'image_encoder_array_size' bytes, but '208' bytes may be read."
        const auto image_codec_info = p_image_codec_info[image_encoder_index];
        const auto mime_type = image_codec_info.MimeType;
        const auto comparison_result = wcscmp(mime_type, format);
        if (comparison_result == 0)
        {
            *p_clsid = image_codec_info.Clsid;
            free(p_image_codec_info);
            return image_encoder_index; // Success
        }
    }

    free(p_image_codec_info);
    return -1; // Failure
}
Run Code Online (Sandbox Code Playgroud)

Visual Studio产生以下警告:

Reading invalid data from 'p_image_codec_info':  the readable size is 'image_encoder_array_size' bytes, but '208' bytes may be read.
Run Code Online (Sandbox Code Playgroud)

代码可以运行,但是如何修复这个警告呢?我逐步调试了代​​码,但我没有发现索引或分配的大小有问题p_image_codec_info。该警告的文档位于此处

Bul*_*aza 5

正如 所评论的Evg,这似乎是一个Visual Studio/ Resharper C++static 分析器错误,因为代码是正确的。