使用c++封装com的IEnum接口

本文介绍了如何使用C++封装COM的IEnum接口,将COM枚举器转换为C++的迭代器,简化DirectShow开发中的枚举操作。通过定义一个forward_iterator,重载必要的操作符,实现了一个模板化的com_enum_iterator类,使得可以使用STL的for_each等算法进行遍历。
摘要由CSDN通过智能技术生成

使用c++封装comIEnum接口

 

最近在做DirectShow的一些开发,其中总要用到连接filter之类的操作,而filter是通过com中的枚举器得到的。在c++中使用枚举器十分不方便,可以看下一段代码:

      

HRESULT hr = pGraph->EnumFilters(&pEnum);

if (FAILED(hr)) return result;

 

while(pEnum->Next(1, &pFilter, &cFetched) == S_OK)

{

     FILTER_INFO FilterInfo;

     hr = pFilter->QueryFilterInfo(&FilterInfo);

     if (FAILED(hr))

     {

         MessageBox(NULL, TEXT("Could not get the filter info"),

              TEXT("Error"), MB_OK | MB_ICONERROR);

         continue;  // Maybe the next one will work.

     }

}

pEnum->Release();

 

如果每天都要写这样的代码,真的要晕倒,想想c++中不时有iterator吗,而且我也经常用iterator,我用iterator可比Ienum要熟得多。在c++中,想做什么可都是你自己的事,那就做一个iterator adapter吧,然后我就不用写循环了,用for_each就可以搞定了。

先分析一下,IEnum中主要方法是Next、Reset,这样看来应该是个forward_iterator,不过大多数stl算法已经足够了。好吧,先写一个,不过还是要看看书,找了TCPL看看,forward iterator要实现 =*p , -> , *p= , ++ , == != 这些操作符。如下代码:

struct graph_filter_iterator :

    public std::iterator<std::forward_iterator_tag,

                        IBaseFilter*,

                        ptrdiff_t,

                        IBaseFilter*,

                        IBaseFilter*>

{

public:

    explicit graph_filter_iterator()

    {}

 

    explicit graph_filter_iterator(IEnumFilters* penum)

    {

        pEnum = penum;

        reset();

    }

 

    IBaseFilter* operator*() const

    {

        return pFilter.p;

    }

 

    IBaseFilter* operator->()const

    {

        return pFilter.p;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MyBatis Plus是一个优秀的基于MyBatis的ORM框架,它提供了很多便捷的功能来简化数据库操作。在MyBatis Plus中,IEnum接口是一个枚举接口,用于定义枚举类型的数据库映射。 通常,在数据库中使用数字或字符串存储枚举类型的值是很常见的。但是,直接使用数字或字符串来表示枚举类型存在一些问题,比如可读性差、易出错等。为了解决这些问题,MyBatis Plus引入了IEnum接口。 定义一个实现了IEnum接口的枚举类,可以为每个枚举值提供一个自定义的数据库映射值。这样,在数据库中存储的就是我们自定义的值,而不是枚举常量的名称。同时,MyBatis Plus会根据数据库中存储的值来自动映射回对应的枚举常量。 使用IEnum接口有以下几个步骤: 1. 定义一个枚举类,并实现IEnum接口。 2. 在每个枚举值上使用@EnumValue注解指定对应的数据库映射值。 3. 在实体类的对应字段上使用@TableField注解,并设置typeHandler属性为EnumTypeHandler。 下面是一个示例代码: ```java public enum Gender implements IEnum<Integer> { MALE(0, "男"), FEMALE(1, "女"); private final Integer value; private final String desc; Gender(Integer value, String desc) { this.value = value; this.desc = desc; } @Override public Integer getValue() { return this.value; } } public class User { private Long id; private String name; @TableField(typeHandler = EnumTypeHandler.class) private Gender gender; // getters and setters } ``` 在上面的代码中,枚举类型Gender实现了IEnum接口,并为每个枚举值指定了对应的数据库映射值。在User实体类中,使用@TableField注解将gender字段标记为枚举类型,并指定了EnumTypeHandler作为类型处理器。 通过上述配置,MyBatis Plus会根据数据库中存储的值自动映射为对应的枚举常量。比如,当查询到gender字段的值为0时,会将其映射为Gender.MALE。 相关问题: 1. 如果我想要自定义枚举字段的映射逻辑,该怎么做? 2. MyBatis Plus中支持哪些类型的字段映射? 3. 如何在查询条件中使用枚举类型的字段? 4. 是否可以使用字符串作为枚举类型的映射值,而不是数字? 5. 如果一个枚举类型在不同的表中有不同的映射值,应该如何处理?
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值