C++ 公共组件-IOC库
参考网址:https://blog.youkuaiyun.com/alpha_love/article/details/75208889
IOC机制简介
IOC机制可以让对象之间的关系在外面组装,外界可以根据需求灵活地配置这种机制的对象创建策略,从而获得想要的目标对象,这种机制被称为控制反转(Inversion of Control,IoC)。
控制反转就是应用本身不负责依赖对象的创建和维护,而交给一个外部容器来负责。这样控制权就由应用转移到了外部IoC容器,即实现了所谓的控制反转。IoC用来降低对象之间直接依赖产生的耦合性。
具体可以参考此网址:https://blog.youkuaiyun.com/alpha_love/article/details/75208889
IOC的简单实现
github项目地址
Any.hpp(C++17之前使用)
#pragma once
#include <memory>
#include <typeindex>
#include <exception>
#include <iostream>
struct Any
{
Any(void) : m_tpIndex(std::type_index(typeid(void))) {}
Any(const Any& that) : m_ptr(that.Clone()), m_tpIndex(that.m_tpIndex) {}
Any(Any && that) : m_ptr(std::move(that.m_ptr)), m_tpIndex(that.m_tpIndex) {}
//创建智能指针时,对于一般的类型,通过std::decay来移除引用和cv符,从而获取原始类型
template<typename U, class = typename std::enable_if<!std::is_same<typename std::decay<U>::type, Any>::value, U>::type> Any(U && value) : m_ptr(new Derived < typename std::decay<U>::type>(std::forward<U>(value))),
m_tpIndex(std::type_index(typeid(typename std::decay<U>::type))){}
bool IsNull() const { return !bool(m_ptr); }
template<class U> bool Is() const
{
return m_tpIndex == std::type_index(typeid(U));
}
//将Any转换为实际的类型
template<class U>
U& AnyCast()
{
if (!Is<U>())
{
std::cout << "can not cast " << typeid(U).name() << " to " << m_tpIndex.name() << std::endl;
throw std::logic_error{"bad cast"};
}
auto derived = dynamic_cast<Derived<U>*> (m_ptr.get());
return derived->m_value;
}
Any& operator=(const Any& a)
{
if (m_ptr == a.m_ptr)
return *th

本文介绍了一种C++中的IOC(控制反转)机制实现,通过使用模板元编程和智能指针,创建了一个能够管理对象依赖关系的IOC容器。该容器支持C++11和C++17标准,能够根据不同需求注册和解析不同类型的对象实例。
最低0.47元/天 解锁文章
1054

被折叠的 条评论
为什么被折叠?



