gpt4 book ai didi

objective-c - 为客户端、服务器和插件组织框架

转载 作者:搜寻专家 更新时间:2023-10-30 20:26:54 24 4
gpt4 key购买 nike

我正在从事一个大型项目,该项目包括一个服务器、一些用于控制可以加载到服务器进程中的设备的插件,以及可以连接到服务器的客户端。我正在寻找构建最终需要存在的框架的最佳实践。

有些头文件在客户端、服务器和插件之间共享,有些头文件特定于系统的各个方面。有时 header 仅在客户端和服务器或服务器和插件之间共享。同样,存在可以在项目的所有三个方面之间共享的通用代码,以及仅由一个特定方面需要的代码。

项目完成后,我们需要发布客户端应用程序和插件开发者 API,供第三方开发。

我不确定如何正确构建支持此功能所需的框架。

我需要有 2 个独立的框架吗?或者我可以拥有 1 个包含所有 header 并提供 2 个单独的动态库的框架吗?

如果我需要 2 个独立的框架,我该如何处理在系统各个方面共享的头文件?我不想将它们复制到每个框架中以避免版本控制可能出现的问题。

第三个仅 header 框架是否是一个合理的选择?

谁能推荐在 OS X 上使用框架构建此类事物的最佳实践?

最佳答案

框架 = 库 + 那个库的 header

每个框架只需要包含您要公开的接口(interface)的头文件。即使使用通用 header 构建所有三个框架,您也没有义务将它们捆绑在一起。

一个 3 框架方法会很好,即使其中一个框架只捆绑了公共(public)头文件而根本没有库。示例:如果您在 Mac 上安装 Qt,您会看到它分布在许多框架中,但 header 从不在它们之间重复。还有一些框架只包含头文件而没有代码(例如 QtScript.framework)。

关于objective-c - 为客户端、服务器和插件组织框架,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6282183/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com