RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1595212
Accepted
Gleb Ryabushko
Gleb Ryabushko
Asked:2024-09-29 21:56:29 +0000 UTC2024-09-29 21:56:29 +0000 UTC 2024-09-29 21:56:29 +0000 UTC

在 Unity 中组织项目架构的最佳方式是什么?

  • 772

我目前正在做一个项目Unity。简而言之,这是一款关于太空的游戏,玩家控制一颗行星“绕”其恒星运行,并保护其免受各种危险。

在我的项目中,我有一个抽象类AbstractMovementSystem,其中的类PlanetMovementSystem和MoveToTargetSystem.这样做是因为在上面的类中仍然会有方法Move和字段_maxSpeed,_currentSpeed并且创建抽象类可以让您遵守该原则DRY。

这些类仅负责将对象“移动”到新位置。在这种情况下,这个新位置的计算发生在实现该接口的PlanetMovementCalc和类中。这就是问题开始的地方:MoveToTargetCalcIMoveCalculator

要计算新位置,MoveToTargetCalc需要两个向量和一个速度,以及 PlanetMovementCalc-input以 类型值的形式表示float轨道半径和速度。正如您可以想象的,如果我添加两种方法来计算 中的新位置IMoveCalculator,那么我将必须实现为MoveToTargetCalc, 设计的方法,PlanetMovementCalc反之亦然。什么PlanetMovementCalc,什么MoveToTargetCalc——这当然是没有必要的。如果你将方法实现为空,那么这将违反里氏原则,而如果你以正常方式实现方法,那么它只是一堆不会被使用的额外代码。

问题:该怎么办?一般来说,从项目中删除接口,因为PlanetMovementCalc根据 MoveToTargetCalc设计它们不应该互换?或者说使用接口有什么意义吗?如果是,那么如何正确使用它们呢?

(我为这个愚蠢的问题道歉,我只是没有太多经验,而且我无法“记录”自己)

c#
  • 1 1 个回答
  • 59 Views

1 个回答

  • Voted
  1. Best Answer
    Yaroslav
    2024-09-30T12:34:18Z2024-09-30T12:34:18Z

    奇怪的是,建筑是从命名开始的!如果你的架构以类开始GameManager,任何人都会说你的架构是ShinimaHuina,甚至没有指定这个类到底做什么。

    abstract。private。 。publicETC。这些是访问修饰符,而不是名称成员!Manager或者说System,在 99% 的情况下,当一个人无法表述该实体到底在做什么时,这些词是寄生的吗?缩写绝对是邪恶的,但缩写是可以接受的,就像在特定领域中普遍接受的那样,例如Str在Agi电子Int游戏中,尽管当一个单词在某些情况下被缩写而在其他情况下不被缩写时,就会变得一团糟。


    除了它有两个字段这一事实之外AbstractMovementSystem,您还没有写过有关其业务流程的任何文字。为什么叫它AbstractMovementSystem?因为鬼知道什么是抽象的,而是与运动相关的东西!如果不同的实体仅通过属性和方法的名称联合起来,那么它们通过一个公共接口联合起来,因为它们不继承任何逻辑,就像单元和可破坏的装饰一样,它们都处理IDamagable,但收到的伤害处理方式不同由每个。基于 和 两个属性Speed,MaxSpeed您只能挑选出界面ISpeed,尽管行星以可变速度移动并且具有速度上限,这非常奇怪。

    在这些情况下,我诚实地将类命名为ala...XXX并且已经实现了我需要的功能,我在方法名称的上下文中给出了反映此功能的名称,或者鉴于多重职责将实体划分为多个实体。


    我实在不明白为什么运动的逻辑要分类,为什么星球的运动不描述到星球的收银台上?在某些情况下,我们将逻辑从类中取出,例如在模式中State,因为它发生了变化,但为什么会在这里呢?

    如果太阳系中的所有物体都按照牛顿力学运动,就会有一个 type 类CelestialBody,所有物体都继承自该类,以及某种NewtonPhysics.你的情况并非如此,游戏不需要真实的物理,恒星不会移动,行星严格地沿圆周移动,而飞船则可以随心所欲地飞行,它们实际上没有任何共同点与彼此。


    你的问题不在于接口,也不在于抽象,而在于事实上你无法阐明你需要做什么......以及为什么你应该这样做......而你只是跑在机车前面,所以奔跑而不去思考,因为思考会让人痛苦!

    • 1

相关问题

  • 使用嵌套类导出 xml 文件

  • 分层数据模板 [WPF]

  • 如何在 WPF 中为 ListView 手动创建列?

  • 在 2D 空间中,Collider 2D 挂在玩家身上,它对敌人的重量相同,我需要它这样当它们碰撞时,它们不会飞向不同的方向。统一

  • 如何在 c# 中使用 python 神经网络来创建语音合成?

  • 如何知道类中的方法是否属于接口?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5