news 2026/6/10 17:08:30

扩展使用已有的类型-–-behaviac

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
扩展使用已有的类型-–-behaviac

原文

在某些情况下,除了运行时库(C++)中提供支持的一些基本类型(bool、short、int、float等)之外,behaviac还支持扩展使用已有的或者用户自定义的类、结构体和枚举类型。

这里有两种情况,其处理方式是不同的:

  • 有些类型是程序中本来就有的,该类型可能是某个第三方库中提供的,但这些类型是不方便随意修改的。
  • 另外一些可以随便修改的类型,请参考自定义类或结构体。

字符串和数组类型

需要注意的是,behaviac组件为了支持C++的反射系统,对字符串和数组类型有如下要求:

  • 字符串:不要使用std::string,需要使用behaviac::string,因为behaviac::string使用了自定义的allocator,可以对内存的使用进行统一的管理。
  • 数组:不要使用std::vector,需要使用behaviac::vector。

char类型

此外,需要对char、signed char和unsigned char做出一些必要的说明:

  • 在C++中,char、signed char和unsigned char是三个不同的类型。
  • 在编辑器中,分别对应char、sbyte、ubyte。
  • 对于C#,char、sbyte和byte是基本类型,分别对应编辑器中的char、sbyte和ubyte。

扩展使用已有的类型

对于已有的不能修改源码的类型,需要按照如下步骤进行扩展:

  • 在.h文件中,通过宏BEHAVIAC_EXTEND_EXISTING_TYPE特化某个需要的类型。

    如下代码样例所示(假设TestNS::Float2是某个第三方库中的类型,需要用到但不能修改它):

BEHAVIAC_EXTEND_EXISTING_TYPE(myFloat2,TestNS::Float2);
  • 定义一个“相似”的struct(myFloat2),该struct的作用是用来定义那个已存在的类的成员,以便behaviac能够访问该类。
  • 通过DECLARE_BEHAVIAC_STRUCT的第二个参数isRefType为true或false表示该类型是否为引用类型,如下代码所示。
structmyFloat2{floatx;floaty;DECLARE_BEHAVIAC_STRUCT(myFloat2,false);myFloat2(){}myFloat2(constTestNS::Float2&v):x(v.x),y(v.y){}};
  • 在命名空间StringUtils的嵌套子空间Private中实现该类型的ToString()和FromString()函数。注意myFloat2中需要实现相应的转换构造函数(myFloat2(const TestNS::Float2& v)),如下代码样例所示:
namespacebehaviac{// ValueToString & ValueFromStringnamespaceStringUtils{namespacePrivate{template<>inlinebehaviac::stringToString(constTestNS::Float2&val){//myFloat2::ToString is defined by DECLARE_BEHAVIAC_STRUCT(myFloat2)myFloat2temp(val);returntemp.ToString();}template<>inlineboolFromString(constchar*str,TestNS::Float2&val){myFloat2 temp;//myFloat2::FromString is defined by DECLARE_BEHAVIAC_STRUCT(myFloat2)if(temp.FromString(str)){val.x=temp.x;val.y=temp.y;returntrue;}returnfalse;}}}}
  • 实现该类型的模板函数SwapByteTempl(),注意该函数不能放在任何命名空间(namespace)中,如下代码样例所示:
template<typenameSWAPPER>inlinevoidSwapByteTempl(TestNS::Float2&v){SwapByteTempl<SWAPPER>(v.x);SwapByteTempl<SWAPPER>(v.y);}
  • 在命名空间behaviac的嵌套子空间Details中实现该类型的Equal()模板函数,如下代码样例所示:
namespacebehaviac{namespaceDetails{template<>inlineboolEqual(constTestNS::Float2&lhs,constTestNS::Float2&rhs){returnTag::IsEqualWithEpsilon(lhs.x,rhs.x)&&Tag::IsEqualWithEpsilon(lhs.y,rhs.y);}}}
  • 在初始化注册(Register)的部分需要加上如下的代码,反注册(UnRegister)的部分添加相应UnRegister的代码。注意:这部分Register/UnRegister的代码不是必须的,如果该类型没有用作par或者没有用作条件比较,就可以不需要。
behaviac::TypeRegister::Register<TestNS::Float2>("TestNS::Float2");behaviac::TypeRegister::UnRegister<TestNS::Float2>("TestNS::Float2");

详细代码可以参考behaviac组件C++源码库中btunittest工程的extendstruct.h文件。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 16:48:30

C++ Template(模板)解读和模板报错如何“逆向阅读”定位

一、Template&#xff08;模板&#xff09;解读 一、模板本质&#xff1a;不是泛型&#xff0c;是“代码生成器”Template 编译期函数 / 类型生成系统template<typename T> T add(T a, T b) { return a b; }编译期行为&#xff1a; add<int> -> 生成一个 i…

作者头像 李华
网站建设 2026/6/10 15:04:18

不止ChatGPT!多智能体协同框架AutoGen、CAMEL全解析,小白也能上手

在数字化浪潮席卷全球的今天&#xff0c;人工智能领域正不断突破边界。当单个智能体的能力逐渐触达瓶颈&#xff0c;多智能体协同恰似一把 “智能密钥”&#xff0c;解开了更复杂任务的解决密码。尤其是大语言模型加持下的多智能体协同架构&#xff0c;已悄然在各行业掀起变革&…

作者头像 李华
网站建设 2026/6/10 9:56:35

企业知识库成“数字垃圾场“?RAGFlow三招教你打造AI智能大脑,小白程序员也能上手! 企业知识库常沦为“数字垃圾场“,根源在于三个误区:一是“为了做而做“,只强调

知识管理 # RAG # 效率革命 RAGFlow 实践 1.知识库沦为“数字垃圾场”的根源在于“为了做而做”&#xff0c;增加了员工负担。 2.成功的知识库是需要“养”的生物&#xff0c;必须持续调试、优化&#xff0c;而非静态的“U盘”。 3.终局是嵌入工作流&#xff08;Workflow&#…

作者头像 李华
网站建设 2026/6/10 0:56:29

2025大厂Java面试高频真题整理!

2025快要结束&#xff0c;想必有不少小伙伴已经开始提前为明年面试做准备了。今天写下这篇文章的原因是这几天有很多粉丝在后台找我&#xff0c;希望我出一份对标明年金三银四的面试题总结&#xff0c;近期急需面试。不过我一个人短时间内肯定是不能把近期的高频面试题全部总结…

作者头像 李华