构建静态框架和与其他开源库的内部链接的设计方法

Posted

技术标签:

【中文标题】构建静态框架和与其他开源库的内部链接的设计方法【英文标题】:Design approach for building static framework and internal linking with other open source libraries 【发布时间】:2013-12-07 14:55:50 【问题描述】:

我正在创建一个静态框架以分发给其他项目。我对构建框架的设计方法有些困惑。我以前从未构建过框架。

我正在构建类似于AdColony framework 的东西,我将在其中将一些唯一的 id 传递给框架,它会在内部调用多个 API,并将最终输出传输回具有适当委托的应用程序。在那个 AdColony 框架中,只有一个 .h 文件是公开的。

我想知道一些问题:

1) 我打算使用 AFNetworking 进行所有服务器通信和解析。因此,在构建框架时,我如何将我的静态框架与 AFNetworking 链接起来。 AFNetworking 标头将在最终的 .framework 输出中可见?如果我的框架需要外部 AFNetworking 链接,那么我强迫其他开发人员包含 AFNetworking 是一种好方法吗?还是我必须写下我自己的基本网络层?

2) 我可以隐藏我的所有包装器和模型类,只让开发人员可以看到 1 个类以进行配置和处理输出吗?

除了上述问题,如果您有构建此框架的最佳设计方法,请提出建议。

【问题讨论】:

出于好奇,您打算分发该框架还是仅供个人(或内部)使用? @KaanDedeoglu 是的,我正计划分发该框架。您对以上问题有个人意见或建议吗? 我打算建议您创建自己的私有 Cocoapods 库,因为您不想隐藏实现细节。 【参考方案1】:

1。你可以做两件事:

将 AFNetworking 添加到您的框架中。并将 AFNetworking 的标头设置为公共标头。您可以更改一些包含以创建干净的包含标头。

将您的框架与 AFNetworking 链接,并强制其他开发人员链接 AFNetworking。

如何知道要遵循哪种方法?

如果我的框架将提供一些网络层,我将使用第一种方法。我会维护我的项目。如果您只将 AFNetworking 用于您的内部实现,则第二种方法很有用。但是当 AFNetworking 更改您正在使用的内容时,您将需要维护您的框架。


2 。是的,你可以。

您可以设置公共标头。因此,如果您只想拥有一个公共类,则需要将该标头设置为公共。请记住,.h 中的所有方法都是公开的。因此,如果您想确保没有人可以调用您的方法,则需要将方法声明放在您将在 .m 中使用的类别中

另一个建议:看看这个project。

【讨论】:

"您只能公开一个标头。"打扰一下?你到底是怎么得出这个结论的? @KamilKocemba:也许向我解释错了。我的意思是他可以设置一个像public这样的标题。因为他的一个问题是:“只让 1 个类对开发人员可见以进行配置和处理输出?”所以我的回答是:“是的,您可以拥有或设置一个标头为公开”。对不起我的英语不好。 :) @dcorbatta 看起来卡米尔对你投了反对票,他不理解实际问题。我也看了他的解决方案。他发布了一些与 cocoapods 相关的内容。我不明白 cocoapods 如何负责构建静态框架和内部链接。仅供参考:我将使用您的第二种方法,我将使用 AFNetworking 的内部实现,因为我不向其他开发人员提供任何网络层 嗯,cocoapods 用于分发您的框架并解决您的框架所需的 amy 依赖。 很遗憾@KamilKocemba 仅仅因为他不理解这个问题而否决了我的回答。

以上是关于构建静态框架和与其他开源库的内部链接的设计方法的主要内容,如果未能解决你的问题,请参考以下文章

angularJs项目实战!03:angularjs与其他类库的协作

java内部类

开源库的使用方法以及libjpeg的移植详解

Java 内部类

java23种设计模式之四:建造者模式

使用带有内部库的 maven 构建 android 项目