- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
最近我发现了这个 javalobby 帖子 http://java.dzone.com/articles/how-changing-java-package关于按功能打包java代码。
我喜欢这个想法,但我对这种方法几乎没有疑问。我问了我的问题,但没有得到满意的答复。我希望 StackOverflow 上的人能澄清我的问题。
我喜欢按功能打包的想法,它大大减少了在编码时跨包移动的时间,所有相关的东西都将放在一个地方(包)。但是不同包中的服务之间的交互呢?
假设我们正在构建一个博客应用程序,并且我们将所有与用户相关的操作( Controller /服务/存储库)放在 com.mycompany.myblog.users
包中。以及 com.mycompany.myblog.posts
包中的所有博客文章相关操作( Controller /服务/存储库)。
现在我想显示用户个人资料以及他发布的所有帖子。我应该从 myblog.users.UserController.showUserProfile()
调用 myblog.posts.PostsService.getPostsByUser(userId)
吗?
包之间的耦合呢?
此外,无论我在何处阅读有关按功能打包的信息,每个人都说这是一个很好的做法。那么为什么很多书籍作者甚至框架都鼓励分层分组呢?只是想知道:-)
最佳答案
看看鲍勃叔叔的Package Design Principles .他解释了这些原则背后的原因和动机,我在下面进行了详细说明:
一起重用的类应该打包在一起,以便可以将包视为一种可供您使用的完整产品。那些一起重用的应该与那些不被重用的分开。例如,您的 Logging 实用程序类不一定与您的文件 io 类一起使用。因此,将所有日志分别打包。但是日志类可以相互关联。因此,创建一种完整的日志记录产品,例如,为了获得更好的名称 commons-logging 将其打包在一个(可重)使用的 jar 中,并为 io 实用程序创建另一个单独的完整产品,再次为了更好的名称,例如 commons- io.jar。如果您更新说 commons-io 库以说支持 java nio,那么您可能不一定要对日志库进行任何更改。所以把它们分开比较好。
现在,假设您希望您的日志记录实用程序类支持结构化日志记录,例如通过 splunk 等工具进行某种日志分析。您的日志记录实用程序的某些客户端可能想要更新到您的较新版本;其他一些可能不会。因此,当您发布新版本时,将所有需要并重用的类打包在一起进行迁移。因此,您的实用程序类的某些客户端可以安全地删除旧的 commons-logging jar 并移至 commons-logging-new jar。其他一些客户仍然可以使用旧 jar。但是,不需要客户端同时拥有这两个 jars(新旧),因为您强制他们使用一些用于旧打包 jar 的类。
避免循环依赖。 a 依赖于 b; b 在 c 上;条件;但 d 取决于 a。这种情况显然令人望而却步,因为定义层或模块等将非常困难,而且您不能相对于彼此独立地改变它们。
此外,您可以打包您的类,这样如果一个层或模块发生更改,其他模块或层不必更改。因此,例如,如果您决定从旧的 MVC 框架升级到 rest API 升级,那么可能只有 View 和 Controller 需要更改;你的模型没有。
关于java - 按功能打包好不好?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11733267/
非常简单的应用程序 - 您可以复制 - 粘贴 - 运行。主要只是“创建”应用程序。 - 这不是问题(可能) #include #include #include #include typede
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 6 年前。 Improve t
Haskell 有一个名为 seq 的神奇函数,它接受任何类型的参数并将其简化为弱头范式 (WHNF)。 我读过一些资料[但我现在不记得他们是谁了...],它们声称“多态 seq 很糟糕”。他们在哪些
我正在编写一个脚本,该脚本应该在一堆服务器周围运行并从中选择一堆数据,包括本地服务器。选择我需要的数据所需的 SQL 非常复杂,所以我正在编写一种临时 View ,并使用 OPENQUERY 语句来获
考虑以下代码: case class Vector3(var x: Float, var y: Float, var z: Float) { def add(v: Vector3): Unit =
我正在读这个SO post关于守护线程,答案底部的引述是: But joining a demonized thread opens most likely a whole can of troubl
在阅读有关 Google webtool 工具包的内容时,看到一条声明说“同步 RPC 不好”。他们有什么理由吗?我能想到的一个很好的理由是,对最终用户的响应可能会受到远程服务器延迟或网络问题的影
我有以下 HTML: A Simple Sample Web Page By Sheldon Brown Demonstrating a few HTML feat
我正在做一项简单的任务,但我陷入困境...... output 我需要使第一行与其他所有内容保持一致,但无论我做什么,它都不想接受空格。那么,我应该纠正什么以及为什么?谢谢 public static
我在系统中有一个类,其目的列为“这可以是从午夜算起的秒数。或者带有日期的时间。”我试图解释这有多糟糕,但我无法理解我的观点。有没有人对如何解决这个问题有任何想法。 http://code-slim-j
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: When are C++ macros beneficial? Why is #define bad and
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
始终建议通过将所有代码放在 JS 文件中来避免内联 Javascript 代码,该文件包含在所有页面中。我想知道,这是否不会导致繁重的页面出现性能问题。 例如,假设我们有几十个这样的函数 functi
我主要在 AngularJS 中进行开发,最近我正在研究 Vue.js 并阅读它的指南,在它提到的一页上: By default, all props form a one-way-down bind
我正在构建一个本地化目录,但遇到了设计难题。现在,目录存储一个 Dictionary存储翻译,其中 IString可以是两种类型:Singular或 Plural .这是 IString 的简化版本:
对于我的矩阵类,我做了: template class Matrix { private: std::array, Height> Elements; stat
MSDN documentation说 public class SomeObject { public void SomeOperation() { lock(this) {
建议不要在 Python 中使用 import *。 谁能分享一下原因,这样我下次就可以避免了? 最佳答案 因为它会将很多东西放入您的命名空间(可能会影响之前导入的一些其他对象,而您不会知道它)。 因
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
G'day, 这与my question on star developers有关并到 this question regarding telling someone that they're wri
我是一名优秀的程序员,十分优秀!