使用C++定义一个万能类型

Posted 小念之歌

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用C++定义一个万能类型相关的知识,希望对你有一定的参考价值。

分享一个类似于Qt中QVariant类。

目录:

1 类型定义

2 数值操作

3 万能类型包装

4 使用

 

——————————————————Begain——————————————————

 

类型定义

typedef.h 

#ifndef TYPEDEF_H
#define TYPEDEF_H
#include <stdint.h>
#include <set>

using namespace std;

enum class VariantType : uint16_t
{
    vt_empty = 0,        //!< 类型为定义
    vt_bool = 1,        //!< bool类型
    vt_i4 = 2,            //!< int32_t 类型
    vt_ui4 = 3,            //!< uint32_t 类型
    vt_i8 = 4,            //!< int64_t 类型
    vt_ui8 = 5,            //!< uint64_t 类型
    vt_r4 = 6,            //!< float 类型
    vt_r8 = 7,            //!< double 类型
    vt_bstr = 8,        //!< const char* 类型
    vt_set = 0x1000,    //!< 集合类型,该类型的值需要用过特定函数获取,不能直接通过成员变量获取
};

struct VariantValue
{
    uint16_t        m_vt;        //!< 值得类型,取值参看枚举VariantType,其中vt_set可以与其他值联合使用
    union
    {
        bool        m_bVal;
        int32_t        m_i4Val;
        uint32_t    m_ui4Val;
        int64_t        m_i8Val;
        uint64_t    m_ui8Val;
        float        m_r4Val;
        double        m_r8Val;
        char*        m_strVal;
        void*        m_pSetVal;
    };
};

template<typename T>
void VariantSetValueDelete(set<T> *pSetValue)
{
    if (pSetValue)
    {
        delete pSetValue;
        pSetValue = nullptr;
    }
}

template<typename T>
void VariantSetValueCopy(VariantValue &toValue, const set<T> *pFromValue)
{
    if (nullptr == pFromValue)
        return;

    toValue.m_pSetVal = new set<T>(*pFromValue);
}

template<typename T>
uint32_t VariantSetValueSize(set<T> *pSetValue)
{
    return pSetValue ? static_cast<uint32_t>(pSetValue->size()) : 0;
}

template<typename T>
bool VariantSetValueAt(set<T> *pSetValue, uint32_t uIndex, T &subValue)
{
    if (nullptr == pSetValue)
        return false;

    auto        it = pSetValue->begin();

    advance(it, uIndex);
    if (it == pSetValue->end())
        return false;

    subValue = *it;
    return true;
}

template<typename T>
bool VariantSetValueAdd(set<T> *pSetValue, T value)
{
    if (nullptr == pSetValue)
        return false;

    auto        it = pSetValue->find(value);

    if (it == pSetValue->end())
        return false;

    pSetValue->insert(value);
    return true;
}

template<typename T>
bool VariantSetValueRemove(set<T> *pSetValue, T value)
{
    if (nullptr == pSetValue)
        return false;

    auto        it = pSetValue->find(value);

    if (it == pSetValue->end())
        return false;

    pSetValue->erase(it);
    return true;
}


#endif // TYPEDEF_H

 

数值操作

valueopt.h

#ifndef VALUEOPT_H
#define VALUEOPT_H
#include "typedef.h"
#include <stdint.h>



void VariantValueInit(VariantValue &value);

void VariantValueClear(VariantValue &value);

void VariantValueCopy(VariantValue &toValue, const VariantValue &from);

uint32_t VariantValueSetSize(const VariantValue &valueSet);

bool VariantValueSetAt(const VariantValue &valueSet, uint32_t uIndex, VariantValue &value);

bool VariantValueSetAdd(VariantValue &valueSet, const VariantValue &value);


#endif // VALUEOPT_H

 

valueopt.cpp

#include <iostream>

#include "valueopt.h"
#include <string.h>
#include <valueopt.h>

using namespace std;



void VariantValueInit(VariantValue &value)
{
    memset(&value, 0, sizeof(value));
    value.m_vt = (uint16_t)VariantType::vt_empty;
    value.m_pSetVal = nullptr;
}

void VariantValueClear(VariantValue &value)
{
    if (value.m_vt & (uint16_t)VariantType::vt_set)
    {
        uint16_t        uType = (uint16_t)value.m_vt & 0xff;

        switch ((VariantType)uType)
        {
        case VariantType::vt_bool:
            VariantSetValueDelete(reinterpret_cast<set<bool> *>(value.m_pSetVal));
            break;
        case VariantType::vt_i4:
            VariantSetValueDelete(reinterpret_cast<set<int32_t> *>(value.m_pSetVal));
            break;
        case VariantType::vt_ui4:
            VariantSetValueDelete(reinterpret_cast<set<uint32_t> *>(value.m_pSetVal));
            break;
        case VariantType::vt_i8:
            VariantSetValueDelete(reinterpret_cast<set<int64_t> *>(value.m_pSetVal));
            break;
        case VariantType::vt_ui8:
            VariantSetValueDelete(reinterpret_cast<set<uint64_t> *>(value.m_pSetVal));
            break;
        case VariantType::vt_r4:
            VariantSetValueDelete(reinterpret_cast<set<float> *>(value.m_pSetVal));
            break;
        case VariantType::vt_r8:
            VariantSetValueDelete(reinterpret_cast<set<double> *>(value.m_pSetVal));
            break;
        case VariantType::vt_bstr:
            VariantSetValueDelete(reinterpret_cast<set<string> *>(value.m_pSetVal));
            break;
        default:
            break;
        }
    }
    else
    {
        if (((uint16_t)VariantType::vt_bstr == value.m_vt) && value.m_strVal)
            delete[]value.m_strVal;
    }

    memset(&value, 0, sizeof(value));
    value.m_vt = (uint16_t)VariantType::vt_empty;
}

void VariantValueCopy(VariantValue &toValue, const VariantValue &from)
{
    VariantValueClear(toValue);

    if (from.m_vt & (uint16_t)VariantType::vt_set)
    {
        uint16_t        uType = (uint16_t)from.m_vt & 0xff;

        switch ((VariantType)uType)
        {
        case VariantType::vt_bool:
            toValue.m_vt = from.m_vt;
            VariantSetValueCopy(toValue, reinterpret_cast<set<bool> *>(from.m_pSetVal));
            break;
        case VariantType::vt_i4:
            toValue.m_vt = from.m_vt;
            VariantSetValueCopy(toValue, reinterpret_cast<set<int32_t> *>(from.m_pSetVal));
            break;
        case VariantType::vt_ui4:
            toValue.m_vt = from.m_vt;
            VariantSetValueCopy(toValue, reinterpret_cast<set<uint32_t> *>(from.m_pSetVal));
            break;
        case VariantType::vt_i8:
            toValue.m_vt = from.m_vt;
            VariantSetValueCopy(toValue, reinterpret_cast<set<int64_t> *>(from.m_pSetVal));
            break;
        case VariantType::vt_ui8:
            toValue.m_vt = from.m_vt;
            VariantSetValueCopy(toValue, reinterpret_cast<set<uint64_t> *>(from.m_pSetVal));
            break;
        case VariantType::vt_r4:
            toValue.m_vt = from.m_vt;
            VariantSetValueCopy(toValue, reinterpret_cast<set<float> *>(from.m_pSetVal));
            break;
        case VariantType::vt_r8:
            toValue.m_vt = from.m_vt;
            VariantSetValueCopy(toValue, reinterpret_cast<set<double> *>(from.m_pSetVal));
            break;
        case VariantType::vt_bstr:
            toValue.m_vt = from.m_vt;
            VariantSetValueCopy(toValue, reinterpret_cast<set<string> *>(from.m_pSetVal));
            break;
        default:
            break;
        }
    }
    else
    {
        if ((uint16_t)VariantType::vt_bstr == from.m_vt)
        {
            toValue.m_vt = from.m_vt;
            if (nullptr != from.m_strVal)
            {
                uint32_t        uLen = strlen(from.m_strVal);

                toValue.m_strVal = new char[uLen + 1];
                memcpy(toValue.m_strVal, from.m_strVal, uLen);
                toValue.m_strVal[uLen] = \0;
            }
            else
            {
                toValue.m_strVal = nullptr;
            }
        }
        else
        {
            memcpy(&toValue, &from, sizeof(from));
        }
    }
}

uint32_t VariantValueSetSize(const VariantValue &valueSet)
{
    uint32_t            uCount = 0;

    if (valueSet.m_vt & (uint16_t)VariantType::vt_set)
    {
        uint16_t        uType = (uint16_t)valueSet.m_vt & 0xff;

        switch ((VariantType)uType)
        {
        case VariantType::vt_bool:
            uCount = VariantSetValueSize(reinterpret_cast<set<bool> *>(valueSet.m_pSetVal));
            break;
        case VariantType::vt_i4:
            uCount = VariantSetValueSize(reinterpret_cast<set<int32_t> *>(valueSet.m_pSetVal));
            break;
        case VariantType::vt_ui4:
            uCount = VariantSetValueSize(reinterpret_cast<set<uint32_t> *>(valueSet.m_pSetVal));
            break;
        case VariantType::vt_i8:
            uCount = VariantSetValueSize(reinterpret_cast<set<int64_t> *>(valueSet.m_pSetVal));
            break;
        case VariantType::vt_ui8:
            uCount = VariantSetValueSize(reinterpret_cast<set<uint64_t> *>(valueSet.m_pSetVal));
            break;
        case VariantType::vt_r4:
            uCount = VariantSetValueSize(reinterpret_cast<set<float> *>(valueSet.m_pSetVal));
            break;
        case VariantType::vt_r8:
            uCount = VariantSetValueSize(reinterpret_cast<set<double> *>(valueSet.m_pSetVal));
            break;
        case VariantType::vt_bstr:
            uCount = VariantSetValueSize(reinterpret_cast<set<string> *>(valueSet.m_pSetVal));
            break;
        default:
            break;
        }
    }
    else
    {
        uCount = 1;
    }

    return uCount;
}

bool VariantValueSetAt(const VariantValue &valueSet, uint32_t uIndex, VariantValue &value)
{
    bool                bResult = false;

    VariantValueClear(value);
    if (valueSet.m_vt & (uint16_t)VariantType::vt_set)
    {
        VariantValue        value;

        value.m_vt = (uint16_t)valueSet.m_vt & 0xff;
        switch ((VariantType)value.m_vt)
        {
        case VariantType::vt_bool:
            bResult = VariantSetValueAt(reinterpret_cast<set<bool> *>(valueSet.m_pSetVal), uIndex, value.m_bVal);
            break;
        case VariantType::vt_i4:
            bResult = VariantSetValueAt(reinterpret_cast<set<int32_t> *>(valueSet.m_pSetVal), uIndex, value.m_i4Val);
            break;
        case VariantType::vt_ui4:
            bResult = VariantSetValueAt(reinterpret_cast<set<uint32_t> *>(valueSet.m_pSetVal), uIndex, value.m_ui4Val);
            break;
        case VariantType::vt_i8:
            bResult = VariantSetValueAt(reinterpret_cast<set<int64_t> *>(valueSet.m_pSetVal), uIndex, value.m_i8Val);
            break;
        case VariantType::vt_ui8:
            bResult = VariantSetValueAt(reinterpret_cast<set<uint64_t> *>(valueSet.m_pSetVal), uIndex, value.m_ui8Val);
            break;
        case VariantType::vt_r4:
            bResult = VariantSetValueAt(reinterpret_cast<set<float> *>(valueSet.m_pSetVal), uIndex, value.m_r4Val);
            break;
        case VariantType::vt_r8:
            bResult = VariantSetValueAt(reinterpret_cast<set<double> *>(valueSet.m_pSetVal), uIndex, value.m_r8Val);
            break;
        case VariantType::vt_bstr:
        {
            string            strValue;

            bResult = VariantSetValueAt(reinterpret_cast<set<string> *>(valueSet.m_pSetVal), uIndex, strValue);
            if (bResult)
            {
                uint32_t        uLen = (uint32_t)strValue.length();

                value.m_strVal = new char[uLen + 1];
                memcpy(value.m_strVal, strValue.c_str(), uLen);
                value.m_strVal[uLen] = \0;
            }
        }
            break;
        default:
            bResult = false;
            break;
        }
    }
    else
    {
        VariantValueCopy(value, valueSet);
    }

    return bResult;
}

bool VariantValueSetAdd(VariantValue &valueSet, const VariantValue &value)
{
    bool                bResult = false;

    if (valueSet.m_vt == (uint16_t)VariantType::vt_empty)
    {
        if (value.m_vt == (uint16_t)VariantType::vt_empty)
            return false;

        valueSet.m_vt = (uint16_t)VariantType::vt_set | (uint16_t)value.m_vt;
    }

    if (valueSet.m_vt & (uint16_t)VariantType::vt_set)
    {
        uint16_t            uType = (uint16_t)valueSet.m_vt & 0xff;

        if (uType != (uint16_t)value.m_vt)
            return false;

        switch ((VariantType)uType)
        {
        case VariantType::vt_bool:
            if (nullptr == valueSet.m_pSetVal)
                valueSet.m_pSetVal = new set<bool>();
            bResult = VariantSetValueAdd(reinterpret_cast<set<bool> *>(valueSet.m_pSetVal), value.m_bVal);
            break;
        case VariantType::vt_i4:
            if (nullptr == valueSet.m_pSetVal)
                valueSet.m_pSetVal = new set<int32_t>();
            bResult = VariantSetValueAdd(reinterpret_cast<set<int32_t> *>(valueSet.m_pSetVal), value.m_i4Val);
            break;
        case VariantType::vt_ui4:
            if (nullptr == valueSet.m_pSetVal)
                valueSet.m_pSetVal = new set<uint32_t>();
            bResult = VariantSetValueAdd(reinterpret_cast<set<uint32_t> *>(valueSet.m_pSetVal), value.m_ui4Val);
            break;
        case VariantType::vt_i8:
            if (nullptr == valueSet.m_pSetVal)
                valueSet.m_pSetVal = new set<int64_t>();
            bResult = VariantSetValueAdd(reinterpret_cast<set<int64_t> *>(valueSet.m_pSetVal), value.m_i8Val);
            break;
        case VariantType::vt_ui8:
            if (nullptr == valueSet.m_pSetVal)
                valueSet.m_pSetVal = new set<uint64_t>();
            bResult = VariantSetValueAdd(reinterpret_cast<set<uint64_t> *>(valueSet.m_pSetVal), value.m_ui8Val);
            break;
        case VariantType::vt_r4:
            if (nullptr == valueSet.m_pSetVal)
                valueSet.m_pSetVal = new set<float>();
            bResult = VariantSetValueAdd(reinterpret_cast<set<float> *>(valueSet.m_pSetVal), value.m_r4Val);
            break;
        case VariantType::vt_r8:
            if (nullptr == valueSet.m_pSetVal)
                valueSet.m_pSetVal = new set<double>();
            bResult = VariantSetValueAdd(reinterpret_cast<set<double> *>(valueSet.m_pSetVal), value.m_r8Val);
            break;
        case VariantType::vt_bstr:
            if (value.m_strVal)
            {
                if (nullptr == valueSet.m_pSetVal)
                    valueSet.m_pSetVal = new set<string>();
                bResult = VariantSetValueAdd(reinterpret_cast<set<string> *>(valueSet.m_pSetVal), string(value.m_strVal));
            }
            else
            {
                bResult = false;
            }
            break;
        default:
            bResult = false;
            break;
        }
    }
    else
    {
        bResult = false;
    }

    return bResult;
}

 

 

万能类型包装

CustomVariantValue.h
#ifndef CUSTOMVARIANTVALUE_H
#define CUSTOMVARIANTVALUE_H
#include <iostream>
#include <stdint.h>
#include <set>
#include <vector>
#include <cstring>
#include <typedef.h>
#include <assert.h>
using namespace std;


class CustomVariantValue : private VariantValue
{
public:
    CustomVariantValue();
    CustomVariantValue(bool bValue);
    CustomVariantValue(int32_t nValue);
    CustomVariantValue(uint32_t uValue);
    CustomVariantValue(int64_t nValue);
    CustomVariantValue(uint64_t uValue);
    CustomVariantValue(float fValue);
    CustomVariantValue(double dValue);
    CustomVariantValue(const char *pChar);
    CustomVariantValue(const std::string &strChar);
    CustomVariantValue(const std::vector<bool> &valueVector);
    CustomVariantValue(const std::vector<int32_t> &valueVector);
    CustomVariantValue(const std::vector<uint32_t> &valueVector);
    CustomVariantValue(const std::vector<int64_t> &valueVector);
    CustomVariantValue(const std::vector<uint64_t> &valueVector);
    CustomVariantValue(const std::vector<float> &valueVector);
    CustomVariantValue(const std::vector<double> &valueVector);
    CustomVariantValue(const std::vector<std::string> &valueVector);
    CustomVariantValue(const std::set<bool> &valueSet);
    CustomVariantValue(const std::set<int32_t> &valueSet);
    CustomVariantValue(const std::set<uint32_t> &valueSet);
    CustomVariantValue(const std::set<int64_t> &valueSet);
    CustomVariantValue(const std::set<uint64_t> &valueSet);
    CustomVariantValue(const std::set<float> &valueSet);
    CustomVariantValue(const std::set<double> &valueSet);
    CustomVariantValue(const std::set<std::string> &valueSet);
    CustomVariantValue(const VariantValue &value);
    CustomVariantValue(const CustomVariantValue &other);

public:
    CustomVariantValue& operator = (bool bValue);
    CustomVariantValue& operator = (int32_t nValue);
    CustomVariantValue& operator = (uint32_t uValue);
    CustomVariantValue& operator = (int64_t nValue);
    CustomVariantValue& operator = (uint64_t uValue);
    CustomVariantValue& operator = (float fValue);
    CustomVariantValue& operator = (double dValue);
    CustomVariantValue& operator = (const char *pChar);
    CustomVariantValue& operator = (const std::string &strChar);
    CustomVariantValue& operator = (const std::vector<bool> &valueVector);
    CustomVariantValue& operator = (const std::vector<int32_t> &valueVector);
    CustomVariantValue& operator = (const std::vector<uint32_t> &valueVector);
    CustomVariantValue& operator = (const std::vector<int64_t> &valueVector);
    CustomVariantValue& operator = (const std::vector<uint64_t> &valueVector);
    CustomVariantValue& operator = (const std::vector<float> &valueVector);
    CustomVariantValue& operator = (const std::vector<double> &valueVector);
    CustomVariantValue& operator = (const std::vector<std::string> &valueVector);
    CustomVariantValue& operator = (const std::set<bool> &valueSet);
    CustomVariantValue& operator = (const std::set<int32_t> &valueSet);
    CustomVariantValue& operator = (const std::set<uint32_t> &valueSet);
    CustomVariantValue& operator = (const std::set<int64_t> &valueSet);
    CustomVariantValue& operator = (const std::set<uint64_t> &valueSet);
    CustomVariantValue& operator = (const std::set<float> &valueSet);
    CustomVariantValue& operator = (const std::set<double> &valueSet);
    CustomVariantValue& operator = (const std::set<std::string> &valueSet);
    CustomVariantValue& operator = (const VariantValue &value);
    CustomVariantValue& operator = (const CustomVariantValue &other);

    bool operator==(const VariantValue& value);
    bool operator==(const CustomVariantValue& value);

    bool operator!=(const VariantValue& value);
    bool operator!=(const CustomVariantValue& value);

    operator bool() const
    {
        assert((uint16_t)VariantType::vt_bool == m_vt);
        return m_bVal;
    }

    operator int32_t() const
    {
        assert((uint16_t)VariantType::vt_i4 == m_vt);
        return m_i4Val;
    }

    operator uint32_t() const
    {
        assert((uint16_t)VariantType::vt_ui4 == m_vt);
        return m_ui4Val;
    }

    operator int64_t() const
    {
        assert((uint16_t)VariantType::vt_i8 == m_vt);
        return m_i8Val;
    }

    operator uint64_t() const
    {
        assert((uint16_t)VariantType::vt_ui8 == m_vt);
        return m_ui4Val;
    }

    operator float() const
    {
        assert((uint16_t)VariantType::vt_r4 == m_vt);
        return m_r4Val;
    }

    operator double() const
    {
        assert((uint16_t)VariantType::vt_r8 == m_vt);
        return m_r8Val;
    }

    operator const char*() const
    {
        assert((uint16_t)VariantType::vt_bstr == m_vt);
        return m_strVal;
    }

    std::vector<bool> ToBoolArray() const;
    std::vector<int32_t> ToInt32Array() const;
    std::vector<uint32_t> ToUint32Array() const;
    std::vector<int64_t> ToInt64Array() const;
    std::vector<uint64_t> ToUint64Array() const;
    std::vector<float> ToFloatArray() const;
    std::vector<double> ToDoubleArray() const;
    std::vector<std::string> ToStringArray() const;

    std::set<bool>& ToBoolSet();
    std::set<int32_t>& ToInt32Set();
    std::set<uint32_t>& ToUint32Set();
    std::set<int64_t>& ToInt64Set();
    std::set<uint64_t>& ToUint64Set();
    std::set<float>& ToFloatSet();
    std::set<double>& ToDoubleSet();
    std::set<std::string>& ToStringSet();

private:

private:
    bool Compare(const VariantValue& value);
};

#endif // CUSTOMVARIANTVALUE_H

 

CustomVariantValue.cpp
#include "customvariantvalue.h"
#include "valueopt.h"

namespace
{
template<typename T>
bool VariantSetValueComplie(std::set<T> *pSetValue1, std::set<T> *pSetValue2)
{
    if ((nullptr == pSetValue1) && (nullptr == pSetValue2))
        return true;

    if ((nullptr == pSetValue1) || (nullptr == pSetValue2))
        return false;

    return (*pSetValue1) == (*pSetValue2);
}
}

CustomVariantValue::CustomVariantValue()
{
    VariantValueInit(*this);
}

CustomVariantValue::CustomVariantValue(bool bValue)
{
    m_vt = (uint16_t)VariantType::vt_bool;
    m_bVal = bValue;
}

CustomVariantValue::CustomVariantValue(int32_t nValue)
{
    m_vt = (uint16_t)VariantType::vt_i4;
    m_i4Val = nValue;
}

CustomVariantValue::CustomVariantValue(uint32_t uValue)
{
    m_vt = (uint16_t)VariantType::vt_ui4;
    m_ui4Val = uValue;
}

CustomVariantValue::CustomVariantValue(int64_t nValue)
{
    m_vt = (uint16_t)VariantType::vt_i8;
    m_i8Val = nValue;
}

CustomVariantValue::CustomVariantValue(uint64_t uValue)
{
    m_vt = (uint16_t)VariantType::vt_ui8;
    m_ui8Val = uValue;
}

CustomVariantValue::CustomVariantValue(float fValue)
{
    m_vt = (uint16_t)VariantType::vt_r4;
    m_r4Val = fValue;
}

CustomVariantValue::CustomVariantValue(double dValue)
{
    m_vt = (uint16_t)VariantType::vt_r8;
    m_r8Val = dValue;
}

CustomVariantValue::CustomVariantValue(const char *pChar)
{
    m_vt = (uint16_t)VariantType::vt_bstr;
    if (nullptr != pChar)
    {
        uint32_t        uLen = strlen(pChar);

        m_strVal = new char[uLen + 1];
        memcpy(m_strVal, pChar, uLen);
        m_strVal[uLen] = \0;
    }
    else
    {
        m_strVal = nullptr;
    }
}

CustomVariantValue::CustomVariantValue(const std::string &strChar)
{
    uint32_t        uLen = static_cast<uint32_t>(strChar.length());

    m_vt = (uint16_t)VariantType::vt_bstr;
    if (0 != uLen)
    {
        m_strVal = new char[uLen + 1];
        memcpy(m_strVal, strChar.c_str(), uLen);
        m_strVal[uLen] = \0;
    }
    else
    {
        m_strVal = nullptr;
    }
}

CustomVariantValue::CustomVariantValue(const std::vector<bool> &valueVector)
{
    m_vt = (uint16_t)VariantType::vt_bool | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<bool>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;
}

CustomVariantValue::CustomVariantValue(const std::vector<int32_t> &valueVector)
{
    m_vt = (uint16_t)VariantType::vt_i4 | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<int32_t>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;
}

CustomVariantValue::CustomVariantValue(const std::vector<uint32_t> &valueVector)
{
    m_vt = (uint16_t)VariantType::vt_ui4 | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<uint32_t>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;
}

CustomVariantValue::CustomVariantValue(const std::vector<int64_t> &valueVector)
{
    m_vt = (uint16_t)VariantType::vt_i8 | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<int64_t>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;
}

CustomVariantValue::CustomVariantValue(const std::vector<uint64_t> &valueVector)
{
    m_vt = (uint16_t)VariantType::vt_ui8 | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<uint64_t>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;
}

CustomVariantValue::CustomVariantValue(const std::vector<float> &valueVector)
{
    m_vt = (uint16_t)VariantType::vt_r4 | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<float>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;
}

CustomVariantValue::CustomVariantValue(const std::vector<double> &valueVector)
{
    m_vt = (uint16_t)VariantType::vt_r8 | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<double>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;
}

CustomVariantValue::CustomVariantValue(const std::vector<std::string> &valueVector)
{
    m_vt = (uint16_t)VariantType::vt_bstr | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<std::string>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;
}


CustomVariantValue::CustomVariantValue(const std::set<bool> &valueSet)
{
    m_vt = (uint16_t)VariantType::vt_bool | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<bool>(valueSet);
}

CustomVariantValue::CustomVariantValue(const std::set<int32_t> &valueSet)
{
    m_vt = (uint16_t)VariantType::vt_i4 | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<int32_t>(valueSet);
}

CustomVariantValue::CustomVariantValue(const std::set<uint32_t> &valueSet)
{
    m_vt = (uint16_t)VariantType::vt_ui4 | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<uint32_t>(valueSet);
}

CustomVariantValue::CustomVariantValue(const std::set<int64_t> &valueSet)
{
    m_vt = (uint16_t)VariantType::vt_i8 | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<int64_t>(valueSet);
}

CustomVariantValue::CustomVariantValue(const std::set<uint64_t> &valueSet)
{
    m_vt = (uint16_t)VariantType::vt_ui8 | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<uint64_t>(valueSet);
}

CustomVariantValue::CustomVariantValue(const std::set<float> &valueSet)
{
    m_vt = (uint16_t)VariantType::vt_r4 | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<float>(valueSet);
}

CustomVariantValue::CustomVariantValue(const std::set<double> &valueSet)
{
    m_vt = (uint16_t)VariantType::vt_r8 | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<double>(valueSet);
}

CustomVariantValue::CustomVariantValue(const std::set<std::string> &valueSet)
{
    m_vt = (uint16_t)VariantType::vt_bstr | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<std::string>(valueSet);
}

CustomVariantValue::CustomVariantValue(const VariantValue &value)
{
    VariantValueInit(*this);
    VariantValueCopy(*this, value);
}

CustomVariantValue::CustomVariantValue(const CustomVariantValue &other)
{
    VariantValueInit(*this);
    VariantValueCopy(*this, other);
}

CustomVariantValue& CustomVariantValue::operator = (bool bValue)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_bool;
    m_bVal = bValue;
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (int32_t nValue)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_i4;
    m_i4Val = nValue;
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (uint32_t uValue)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_ui4;
    m_ui4Val = uValue;
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (int64_t nValue)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_i8;
    m_i8Val = nValue;
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (uint64_t uValue)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_ui8;
    m_ui8Val = uValue;
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (float fValue)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_r4;
    m_r4Val = fValue;
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (double dValue)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_r8;
    m_r8Val = dValue;
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const char *pChar)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_bstr;
    if (nullptr != pChar)
    {
        uint32_t        uLen = strlen(pChar);

        m_strVal = new char[uLen + 1];
        memcpy(m_strVal, pChar, uLen);
        m_strVal[uLen] = \0;
    }
    else
    {
        m_strVal = nullptr;
    }

    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::string &strChar)
{
    VariantValueClear(*this);

    uint32_t            uLen = static_cast<uint32_t>(strChar.length());

    m_vt = (uint16_t)VariantType::vt_bstr;
    if (0 != uLen)
    {
        m_strVal = new char[uLen + 1];
        memcpy(m_strVal, strChar.c_str(), uLen);
        m_strVal[uLen] = \0;
    }
    else
    {
        m_strVal = nullptr;
    }

    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::vector<bool> &valueVector)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_bool | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<bool>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;

    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::vector<int32_t> &valueVector)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_i4 | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<int32_t>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;

    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::vector<uint32_t> &valueVector)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_ui4 | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<uint32_t>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;

    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::vector<int64_t> &valueVector)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_i8 | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<int64_t>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;

    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::vector<uint64_t> &valueVector)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_ui8 | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<uint64_t>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;

    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::vector<float> &valueVector)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_r4 | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<float>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;

    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::vector<double> &valueVector)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_r8 | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<double>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;

    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::vector<std::string> &valueVector)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_bstr | (uint16_t)VariantType::vt_set;
    auto pSetVal = new std::set<std::string>();
    for (auto value : valueVector)
        pSetVal->insert(value);
    m_pSetVal = pSetVal;

    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::set<bool> &valueSet)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_bool | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<bool>(valueSet);
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::set<int32_t> &valueSet)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_i4 | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<int32_t>(valueSet);
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::set<uint32_t> &valueSet)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_ui4 | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<uint32_t>(valueSet);
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::set<int64_t> &valueSet)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_i8 | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<int64_t>(valueSet);
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::set<uint64_t> &valueSet)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_ui8 | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<uint64_t>(valueSet);
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::set<float> &valueSet)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_r4 | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<float>(valueSet);
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::set<double> &valueSet)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_r8 | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<double>(valueSet);
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const std::set<std::string> &valueSet)
{
    VariantValueClear(*this);
    m_vt = (uint16_t)VariantType::vt_bstr | (uint16_t)VariantType::vt_set;
    m_pSetVal = new std::set<std::string>(valueSet);
    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const VariantValue &value)
{
    if (this != &value)
    {
        VariantValueClear(*this);
        VariantValueCopy(*this, value);
    }

    return *this;
}

CustomVariantValue& CustomVariantValue::operator = (const CustomVariantValue &other)
{
    if (this != &other)
    {
        VariantValueClear(*this);
        VariantValueCopy(*this, other);
    }

    return *this;
}

bool CustomVariantValue::operator==(const VariantValue& value)
{
    return Compare(value);
}

bool CustomVariantValue::operator==(const CustomVariantValue& value)
{
    return Compare(value);
}

bool CustomVariantValue::operator!=(const VariantValue& value)
{
    return !Compare(value);
}

bool CustomVariantValue::operator!=(const CustomVariantValue& value)
{
    return !Compare(value);
}

std::vector<bool> CustomVariantValue::ToBoolArray() const
{
    std::vector<bool>        arrayValue;
    std::set<bool>            *pSetVal = static_cast<std::set<bool> *>(m_pSetVal);

    if (pSetVal)
    {
        uint32_t        i = 0;

        assert(m_vt == (((uint16_t)VariantType::vt_bool) | (uint16_t)VariantType::vt_set));
        arrayValue.resize(pSetVal->size());
        for (auto subValue : *pSetVal)
            arrayValue[i++] = subValue;
    }
    else
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
    }

    return arrayValue;
}

std::vector<int32_t> CustomVariantValue::ToInt32Array() const
{
    std::vector<int32_t>        arrayValue;
    std::set<int32_t>            *pSetVal = static_cast<std::set<int32_t> *>(m_pSetVal);

    if (pSetVal)
    {
        uint32_t        i = 0;

        assert(m_vt == (((uint16_t)VariantType::vt_i4) | (uint16_t)VariantType::vt_set));
        arrayValue.resize(pSetVal->size());
        for (auto subValue : *pSetVal)
            arrayValue[i++] = subValue;
    }
    else
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
    }

    return arrayValue;
}

std::vector<uint32_t> CustomVariantValue::ToUint32Array() const
{
    std::vector<uint32_t>        arrayValue;
    std::set<uint32_t>            *pSetVal = static_cast<std::set<uint32_t> *>(m_pSetVal);

    if (pSetVal)
    {
        uint32_t        i = 0;

        assert(m_vt == (((uint16_t)VariantType::vt_ui4) | (uint16_t)VariantType::vt_set));
        arrayValue.resize(pSetVal->size());
        for (auto subValue : *pSetVal)
            arrayValue[i++] = subValue;
    }
    else
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
    }

    return arrayValue;
}

std::vector<int64_t> CustomVariantValue::ToInt64Array() const
{
    std::vector<int64_t>        arrayValue;
    std::set<int64_t>            *pSetVal = static_cast<std::set<int64_t> *>(m_pSetVal);

    if (pSetVal)
    {
        uint32_t        i = 0;

        assert(m_vt == (((uint16_t)VariantType::vt_i8) | (uint16_t)VariantType::vt_set));
        arrayValue.resize(pSetVal->size());
        for (auto subValue : *pSetVal)
            arrayValue[i++] = subValue;
    }
    else
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
    }

    return arrayValue;
}

std::vector<uint64_t> CustomVariantValue::ToUint64Array() const
{
    std::vector<uint64_t>        arrayValue;
    std::set<uint64_t>            *pSetVal = static_cast<std::set<uint64_t> *>(m_pSetVal);

    if (pSetVal)
    {
        uint32_t        i = 0;

        assert(m_vt == (((uint16_t)VariantType::vt_ui8) | (uint16_t)VariantType::vt_set));
        arrayValue.resize(pSetVal->size());
        for (auto subValue : *pSetVal)
            arrayValue[i++] = subValue;
    }
    else
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
    }

    return arrayValue;
}

std::vector<float> CustomVariantValue::ToFloatArray() const
{
    std::vector<float>        arrayValue;
    std::set<float>            *pSetVal = static_cast<std::set<float> *>(m_pSetVal);

    if (pSetVal)
    {
        uint32_t        i = 0;

        assert(m_vt == (((uint16_t)VariantType::vt_r4) | (uint16_t)VariantType::vt_set));
        arrayValue.resize(pSetVal->size());
        for (auto subValue : *pSetVal)
            arrayValue[i++] = subValue;
    }
    else
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
    }

    return arrayValue;
}

std::vector<double> CustomVariantValue::ToDoubleArray() const
{
    std::vector<double>        arrayValue;
    std::set<double>        *pSetVal = static_cast<std::set<double> *>(m_pSetVal);

    if (pSetVal)
    {
        uint32_t        i = 0;

        assert(m_vt == (((uint16_t)VariantType::vt_r8) | (uint16_t)VariantType::vt_set));
        arrayValue.resize(pSetVal->size());
        for (auto subValue : *pSetVal)
            arrayValue[i++] = subValue;
    }
    else
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
    }

    return arrayValue;
}

std::vector<std::string> CustomVariantValue::ToStringArray() const
{
    std::vector<std::string>        arrayValue;
    std::set<std::string>            *pSetVal = static_cast<std::set<std::string> *>(m_pSetVal);

    if (pSetVal)
    {
        uint32_t        i = 0;

        assert(m_vt == (((uint16_t)VariantType::vt_bstr) | (uint16_t)VariantType::vt_set));
        arrayValue.resize(pSetVal->size());
        for (auto subValue : *pSetVal)
            arrayValue[i++] = subValue;
    }
    else
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
    }

    return arrayValue;
}

std::set<bool>& CustomVariantValue::ToBoolSet()
{
    if (nullptr == m_pSetVal)
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
        m_vt = (((uint16_t)VariantType::vt_bool) | (uint16_t)VariantType::vt_set);
        m_pSetVal = new std::set<bool>();
    }
    else
    {
        assert(m_vt == (((uint16_t)VariantType::vt_bool) | (uint16_t)VariantType::vt_set));
    }

    return *static_cast<std::set<bool> *>(m_pSetVal);
}

std::set<int32_t>& CustomVariantValue::ToInt32Set()
{
    if (nullptr == m_pSetVal)
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
        m_vt = (((uint16_t)VariantType::vt_i4) | (uint16_t)VariantType::vt_set);
        m_pSetVal = new std::set<int32_t>();
    }
    else
    {
        assert(m_vt == (((uint16_t)VariantType::vt_i4) | (uint16_t)VariantType::vt_set));
    }

    return *static_cast<std::set<int32_t> *>(m_pSetVal);
}

std::set<uint32_t>& CustomVariantValue::ToUint32Set()
{
    if (nullptr == m_pSetVal)
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
        m_vt = (((uint16_t)VariantType::vt_ui4) | (uint16_t)VariantType::vt_set);
        m_pSetVal = new std::set<uint32_t>();
    }
    else
    {
        assert((m_vt == (((uint16_t)VariantType::vt_ui4) | (uint16_t)VariantType::vt_set)));
    }

    return *static_cast<std::set<uint32_t> *>(m_pSetVal);
}

std::set<int64_t>& CustomVariantValue::ToInt64Set()
{
    if (nullptr == m_pSetVal)
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
        m_vt = (((uint16_t)VariantType::vt_i8) | (uint16_t)VariantType::vt_set);
        m_pSetVal = new std::set<int64_t>();
    }
    else
    {
        assert(m_vt == (((uint16_t)VariantType::vt_i8) | (uint16_t)VariantType::vt_set));
    }

    return *static_cast<std::set<int64_t> *>(m_pSetVal);
}

std::set<uint64_t>& CustomVariantValue::ToUint64Set()
{
    if (nullptr == m_pSetVal)
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
        m_vt = (((uint16_t)VariantType::vt_ui8) | (uint16_t)VariantType::vt_set);
        m_pSetVal = new std::set<uint64_t>();
    }
    else
    {
        assert(m_vt == (((uint16_t)VariantType::vt_ui8) | (uint16_t)VariantType::vt_set));
    }
    return *static_cast<std::set<uint64_t> *>(m_pSetVal);
}

std::set<float>& CustomVariantValue::ToFloatSet()
{
    if (nullptr == m_pSetVal)
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
        m_vt = (((uint16_t)VariantType::vt_r4) | (uint16_t)VariantType::vt_set);
        m_pSetVal = new std::set<float>();
    }
    else
    {
        assert(m_vt == (((uint16_t)VariantType::vt_r4) | (uint16_t)VariantType::vt_set));
    }

    return *static_cast<std::set<float> *>(m_pSetVal);
}

std::set<double>& CustomVariantValue::ToDoubleSet()
{
    if (nullptr == m_pSetVal)
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
        m_vt = (((uint16_t)VariantType::vt_r8) | (uint16_t)VariantType::vt_set);
        m_pSetVal = new std::set<double>();
    }
    else
    {
        assert(m_vt == (((uint16_t)VariantType::vt_r8) | (uint16_t)VariantType::vt_set));
    }

    return *static_cast<std::set<double> *>(m_pSetVal);
}

std::set<std::string>& CustomVariantValue::ToStringSet()
{
    if (nullptr == m_pSetVal)
    {
        assert(m_vt == (uint16_t)VariantType::vt_empty);
        m_vt = (((uint16_t)VariantType::vt_bstr) | (uint16_t)VariantType::vt_set);
        m_pSetVal = new std::set<std::string>();
    }
    else
    {
        assert(m_vt == (((uint16_t)VariantType::vt_bstr) | (uint16_t)VariantType::vt_set));
    }
    return *static_cast<std::set<std::string> *>(m_pSetVal);
}

bool CustomVariantValue::Compare(const VariantValue& value)
{
    if (m_vt != value.m_vt)
        return false;

    if (m_vt & (uint16_t)VariantType::vt_set)
    {
        uint16_t        uType = (uint16_t)value.m_vt & 0xff;
        bool            bResult = false;

        switch ((VariantType)uType)
        {
        case VariantType::vt_bool:
            bResult = VariantSetValueComplie(reinterpret_cast<std::set<bool> *>(m_pSetVal), reinterpret_cast<std::set<bool> *>(value.m_pSetVal));
            break;
        case VariantType::vt_i4:
            bResult = VariantSetValueComplie(reinterpret_cast<std::set<int32_t> *>(m_pSetVal), reinterpret_cast<std::set<int32_t> *>(value.m_pSetVal));
            break;
        case VariantType::vt_ui4:
            bResult = VariantSetValueComplie(reinterpret_cast<std::set<uint32_t> *>(m_pSetVal), reinterpret_cast<std::set<uint32_t> *>(value.m_pSetVal));
            break;
        case VariantType::vt_i8:
            bResult = VariantSetValueComplie(reinterpret_cast<std::set<int64_t> *>(m_pSetVal), reinterpret_cast<std::set<int64_t> *>(value.m_pSetVal));
            break;
        case VariantType::vt_ui8:
            bResult = VariantSetValueComplie(reinterpret_cast<std::set<uint64_t> *>(m_pSetVal), reinterpret_cast<std::set<uint64_t> *>(value.m_pSetVal));
            break;
        case VariantType::vt_r4:
            bResult = VariantSetValueComplie(reinterpret_cast<std::set<float> *>(m_pSetVal), reinterpret_cast<std::set<float> *>(value.m_pSetVal));
            break;
        case VariantType::vt_r8:
            bResult = VariantSetValueComplie(reinterpret_cast<std::set<double> *>(m_pSetVal), reinterpret_cast<std::set<double> *>(value.m_pSetVal));
            break;
        case VariantType::vt_bstr:
            bResult = VariantSetValueComplie(reinterpret_cast<std::set<std::string> *>(m_pSetVal), reinterpret_cast<std::set<std::string> *>(value.m_pSetVal));
            break;
        default:
            assert(false);
            break;
        }

        return bResult;
    }
    else
    {
        if (m_vt != (uint16_t)VariantType::vt_bstr)
        {
            return 0 == memcmp(this, &value, sizeof(value));
        }
        else
        {
            if ((nullptr == m_strVal) && (nullptr == value.m_strVal))
                return true;

            if ((nullptr == m_strVal) || (nullptr == value.m_strVal))
                return false;

            return 0 == strcmp(m_strVal, value.m_strVal);
        }
    }
}

 

 

使用

main.cpp

#include <iostream>
#include <CustomVariantValue.h>


using namespace std;




int main(int argc, char *argv[])
{

    CustomVariantValue vInt = 1;
    CustomVariantValue vBool = true;

    int rvInt = vInt;
    cout<<rvInt<<endl;

    if(vInt == vBool)
        cout<<"vInt == vBool"<<endl;
    else
        cout<<"vInt!=vBool"<<endl;
    return 0;
}

 

 

——

 

 

 

 

 

 

以上是关于使用C++定义一个万能类型的主要内容,如果未能解决你的问题,请参考以下文章

c++提高编程 1。模板

这些 C++ 代码片段有啥作用?

“你的程序有被限制的函数,请检查你的代码。或你所在位置有无良访问。”怎么解决(C++程序)

在代码片段中包含类型转换

C语言的多态是不是是类似于用结构指针的强制转换来实现的,具体实现方式类似于Linux万能链表???

vs code 自定义代码片段