代码重构 —— 化繁为简

本文涉及 KISS原则,DRY原则

1 设计层面

1.1 保持架构的一致性,不要另辟新径

比如渲染场景管理中,最扁平的架构:manager / scener / object 三层。

  • 都是1对N的关系
  • 一个mgr管理一群scener,一个scener下面N个object,

一些新手会把object搞成一个,在object下面搞一层 layer,最终object的含义非常不同了,

让我也"眼前一亮",居然还能这么扩展

1.2 coding的时候,多想一步,不要无脑的直接干

比如类或者结构体,业务A一个struct,业务B一个struct。

好处:物理隔离 没有风险,不会出错,

坏处:代码碰撞,结构体膨胀,

不够简洁,同时触犯了DRY,do not repeat yourself,

2 实战

拿RHI模块来说。见过撇足的设计,耦合了大量的业务类。RHI定义了一层shader,业务模块中又大量的派生,定义出来

cpp 复制代码
XXXShader : public RHI::shader {}
YYYShader : public RHI::shader {}

不止shader,program,renderer都是配套的,无谓的封装导致结构体膨胀,代码大量冗余。一个业务3个类,N个业务 3*N的增长。

如何解决呢?

结构体本质是不同类型的集合,采用反射的形式进行抽象和提炼。

1)函数的形式:

cpp 复制代码
setUniform1f("key", v1f)
setUniform4f("key", v4f)
setUniformMat44("mvp", mat)

2)静态存储的形式

map< std::key, std::any> ,类似lua的metatable,

any在c++17之后采用,自己网上找一个就行。

3 推广

同样的道理,JNI的交互也经常遇到这类问题。

不好的设计,Java中的一个类,为了对应c++的一个类,硬生生的在JNI层又搞了一个类JXXX 类管理反射相关的信息。

cpp 复制代码
class GuideAreaLayerConfig
{
public:
    std::string day_tex;
    std::string night_tex;
    float erase_dis;
}

class JGuideAreaLayerConfig {
public:
    static jobject ToJavaObject(JNIEnv* env, const GuideAreaLayerConfig& layer_config);
    static GuideAreaLayerConfig Parse(JNIEnv* env, jobject obj);
    static void RegisterMe(JNIEnv* env);
public:
  static jclass clazz;
  static jfieldID textureDay;
  static jfieldID textureNight;
  static jfieldID eraseDis;
};
java 复制代码
class GuideAreaLayerConfig extends LayerBaseConfig {
    public GuideAreaLayerConfig() {
    }

    public float eraseDis = 3;
    public String textureDay = "";
    public String textureNight = "";
}

也可以利用反射的形式,采用map进行抽象管理,大幅度压缩代码。JNI的类型setter和getter 自有一套。

相关推荐
北京阿法龙科技有限公司26 分钟前
AR眼镜赋能跨国设备运维:打破空间隔阂,重构高效协作|阿法龙XR云平台
运维·重构·ar
onebound_noah5 小时前
电商图片搜索:技术破局与商业落地,重构“视觉到交易”全链路
大数据·前端·网络·人工智能·重构·php
Ace_31750887765 小时前
京东商品详情接口终极突破:从多接口联动解析到数据全息重构
python·重构
SEO_juper5 小时前
谷歌搜索全面AI化:SGE如何重构我们的搜索体验与营销格局
人工智能·ai·重构·数字营销
老蒋新思维5 小时前
破局与重构:借 “创始人 IP + AI” 开启智能商业新征程|创客匠人
网络·人工智能·网络协议·tcp/ip·重构·知识付费·创客匠人
KKKlucifer5 小时前
智能越进化,防线越脆弱?AI 时代数据安全的底层挑战与重构
人工智能·重构
迦蓝叶9 小时前
从繁琐到优雅:用 Project Panama 改变 Java 原生交互
java·jni·native·java新特性·原生接口·跨语言开发·projectpanama
深圳光特通信豆子2 天前
精准配置重构光模块成本效能:深圳光特通信1X9、SFP单收/单发光模块
重构
云雾J视界3 天前
碳中和终极武器——嵌入式AI重构能源管理战局
人工智能·重构·算力·碳中和·能源管理·嵌入式ai·低功耗硬件
ZKNOW甄知科技3 天前
重构企业运维智慧:低代码 ITSM 知识管理平台的创新与实践
大数据·运维·人工智能·程序人生·低代码·重构·it