__bridge强制转换为C ++和Objective-C ++

时间:2018-08-21 17:58:00

标签: c++ objective-c objective-c-blocks objective-c++

我正在尝试在一个块周围编写一个模板化的C ++包装器,并且不完全理解__bridge在以下代码中的影响:

#if defined(__OBJC__)
#define SAFE_BLOCK_COPY(...) ((__bridge __typeof(__VA_ARGS__))Block_copy((__bridge const void *)(__VA_ARGS__)))
#else
#define SAFE_BLOCK_COPY(Arg) Block_copy(Arg)
#endif

template <typename ReturnType, typename... Args>
struct CppBlock<ReturnType(Args...)>
{
    typedef ReturnType (^BlockType)(Args...);

    BlockType block;

    CppBlock(BlockType inBlock) {
        block = SAFE_BLOCK_COPY(inBlock);
    }

    ~CppBlock() {
        Block_release(block);
    }

    ReturnType operator()(Args&&... args) const {
        return block(std::forward<Args>(args)...);
    }
}

我创建了SAFE_BLOCK_COPY宏,因此可以在C ++和Objective-C ++中使用该类,因为__bridge无法直接在C ++中使用。

我的问题是:

为Objective-C ++编译时在此宏中添加__bridge有什么影响?据我了解,(__bridge T)本质上等同于static_cast<T>,因为没有所有权转移,因此无论从C ++还是从Objective-C调用,生成的代码都应该相同。

班上有什么问题吗?它将在Objective-C和C ++的单个项目中使用。

1 个答案:

答案 0 :(得分:0)

如果Objective-C使用的是ARC(我认为您是因为我认为桥强制转换仅在ARC中使用),那么Objective-C对象指针类型(包括块指针类型)的内存管理将由ARC和您不应明确地在它们上调用Block_copyBlock_release

您可能应该执行以下操作:

#if defined(__OBJC__)
#define SAFE_BLOCK_COPY(Arg) (Arg)
#else
#define SAFE_BLOCK_COPY(Arg) Block_copy(Arg)
#endif

#if defined(__OBJC__)
#define SAFE_BLOCK_RELEASE(Arg)
#else
#define SAFE_BLOCK_RELEASE(Arg) Block_release(Arg)
#endif