- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我知道使用 GET 和 SET 函数的公共(public)变量的缺点/私有(private)变量的优点,但目前我正在使用 Ogre3D 开发自己的第一个“真实”游戏(C++)..同时,我有时需要 6-7 getFunctions() 来访问我需要对其执行单个操作的数据。所以,我想知道这是否不是矫枉过正/过度设计,以及何时将新的直接指针存储到其他类/函数中的某些对象可能有用。但这听起来不像良好的一致性、良好的编程风格和/或可读性。 (我来自德国,实际上并不知道“一致性”这个词是否合适,如果不合适请纠正我。我指的是代码结构的同质性,例如整个代码遵循严格的编程风格)
那么,一个GetFunction(返回指向对象的指针)需要多少时间?拥有大约 5-7 个 Get 是否过度设计?
或者:对于|R getFunctions() 中的Y,|R 中的哪个X 调用ObjectPointer,是否建议创建对象指针的本地拷贝?
可能有人会说这是过度优化,但另一个方面是可读性 getFunctions()..
我的游戏中的一个示例,用于获取本地玩家在某个“基地”中拥有的 Swordsman 数量。
int numSwordsman = GameManager::getSingletonPtr()->getMatchInstance()->getPlayerData()->getLocalPlayer()->getGameElementManager()->getBase(EWT_MAINBASE)->getSwordsmann();
更糟糕的是这样的
Ogre::Vector2 newVec2 = Ogre::Vector2(GameManager::getSingletonPtr()->getSceneManager()->getCameraNode()->getViewport()->getActualHeight() / GameManager::getSingletonPtr()->getMainGameLoop()->getMouse()->getState()->x.abs,GameManager::getSingletonPtr()->getSceneManager()->getCameraNode()->getViewport()->getActualWidth() GameManager::getSingletonPtr()->getMainGameLoop()->getMouse()->getState()->y.abs);
除了您需要大约 20 到 30 秒才能了解那里发生的事情这一事实之外,输入这些内容也是一种巨大的痛苦。
我个人更喜欢写这样的代码
Ogre::Vector2 newVec2 = Ogre::Vector2(GameManager::getSingletonPtr()->
getSceneManager()->getCameraNode()->getViewport()->getActualHeight()
/ GameManager::getSingletonPtr()->getMainGameLoop()->getMouse()->getState().X.abs,
GameManager::getSingletonPtr()->
getSceneManager()->getCameraNode()->getViewport()->getActualWidth()
/ GameManager::getSingletonPtr()->getMainGameLoop()->getMouse()->getState().Y.abs);
但对于不了解我的编码风格的人来说,它可能会像 **** 一样令人困惑,并且超出了所有人类已知的编程风格和实践。
你怎么看待这个话题?这整个 Get->Get->Get->Get->Get 过度设计了吗?还是必然的必要?你如何处理“遥远”的对象指针?不重要的主题或与性能密集型应用程序相关?关于代码设计的任何提示和技巧?还是 7-8'Get's 仍然是标准?
最佳答案
我会将您的代码示例重写为:
auto GM = GameManager::getSingletonPtr();
auto VP = GM->getSceneManager()->getCameraNode()->getViewport();
auto mouse = GM->getMainGameLoop()->getMouse()->getState();
Ogre::Vector2 newVec2 = Ogre::Vector2(
VP->getActualHeight() / mouse.X.abs,
VP->getActualWidth() / mouse.Y.abs);
只是为了可读性;在效率方面,我怀疑它会更糟,而且可能会更好。
(此外,由于不知道表面之下发生了什么,我宁愿一次获取鼠标状态:我不想在鼠标移动的任何一侧获取 X 和 Y!)
如果效率是一个问题,编译所有的优化,然后查看生成的汇编代码。比较代码重构前后的清晰度;也许它会是一样的。 (这里唯一要注意的是编译器技术一直在改进,所以现在的最佳实践可能在两年内就不是最佳实践。)
还有一个提示:阅读 Martin Fowler 的《重构》一书,以提高您的直觉,判断何时添加抽象层是好的,何时折叠抽象层是好的。是的,我知道它现在已经 15 岁了,但是恕我直言,这个建议非常有效……即使这些例子都是用 java 编写的;-)
关于c++ - GET GET GET GET GET DO - 过度设计?效率与一致性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27562922/
GhostScript PDF/A 生成好像有错误 当您通过 GhostScript 生成 PDF/A 文档时,当您单击 Adobe Reader 时,会出现一个一致性选项卡,其中显示: “一致性
我有一个需要测试的 XPath 引擎实现。 是否有一组标准的一致性测试可以用来验证是否符合 XPath 规范(与 XSLT 相关)。 什么将是完美的 XML 文档 XPath 表达式和预期的结果。 最
帮助我了解在这种情况下我可以期望与 MongoDB 的一致性级别。 我们正在运行一个副本集,其中 Mongoid 中的 consistency 标志设置为 strong,这意味着只读到 master。
假设我有一个采用一个参数的方法。 此参数应满足以下要求: 'of type':方法需要知道参数属于特定类(或子类)。 'implements interface':方法需要知道参数实现了特定的接口(i
当协议(protocol)将属性声明为可选而具体类型将其声明为非可选时,如何使具体类型符合协议(protocol)? 这是问题所在: protocol Track { var trackNum
我正在考虑使用浏览器的 navigator.mimeTypes 数组作为第三级用户/浏览器标识符。例如,当我在 Chrome 上运行时... console.log(navigator.mimeTyp
我有以下协议(protocol): protocol ProtoAInput { func funcA() } protocol ProtoA { var input: ProtoAI
如果选择“最终”一致性,则发生写入的区域内的一致性是什么? 如果我只需要区域强一致性,应该选择哪个选项? 最佳答案 如果您需要在主要区域内进行强读取,则应该选择强一致性或有界过时一致性。 关于azur
您好,我是一名初学者,目前正在尝试学习 java 编程。课本上的问题: 编写一个程序来帮助人们决定是否购买混合动力汽车。你的程序的输入应该是:•新车的成本•预计每年行驶里程•预计汽油价格 •每加仑英里
我正在尝试制作一个可以在 UILabel 上使用的 Swift 协议(protocol), UITextField , 和 UITextView包含他们的text , attributedText ,
我有一个类扩展: extension UICollectionViewCell { class func registerFromNibInCollectionView(collectionV
为了在 Swift 中模拟对象进行测试,我通常遵循这样的模式:编写一个协议(protocol)来描述我想要的对象的行为,然后使用 Cuckoo 为其生成模拟以进行测试。 通常,这些协议(protoco
假设我有两个非通用协议(protocol)(1) protocol StringValue { var asString: String {get} } protocol StringProv
我有一组协议(protocol)可以在 UITableView 中显示一个元素: protocol TableRepresentableRow { var title: String { get
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
用“class”标记 CacheManager 解决了我的问题。 案例:一个简单的缓存器,mutating get 不是我想要的,那么对于引用类型或类类型应该怎么做? protocol Cacher
我想要一个符合协议(protocol)的变量,但是 swift 编译器告诉我协议(protocol)没有确认。 protocol A {} protocol B { var a : A { g
如果我有一个类 Christmas 和一个协议(protocol) Merry,要使 Christmas 符合 Merry,很多人会这样做: class Christmas { ... } e
@objc public protocol P1 { func p1foo() } @objc public protocol P2 { func p2foo() } class A: NSO
我有一些结构符合的基本协议(protocol)(模型)。它们也符合 Hashable protocol Model {} struct Contact: Model, Hashable { v
我是一名优秀的程序员,十分优秀!