- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我已经为 Android 开发了几个月,这个问题一次又一次地出现:添加全新功能 (API) 以支持库而不在标准 SDK 中提供它们的动机是什么?
示例:
FragmentTabHost API 只能通过 android.support.v4.app.FragmentTabHost
获得。大多数时候都可以,但是如果你想使用 fragment 嵌套和PreferenceFragment在一起,你死在水里 - 嵌套需要你切换到 android.support.v4.app.Fragment
(用于支持低于 4.2),但在这个支持库中没有 PreferenceFragment 的实现.因此,您要么实现自定义变通办法,要么使用已经实现它们的第三方库(参见 this question)
编辑:正如@eugen 在他的回答中指出的那样,我自己从支持 native fragment 的 support-v13 中引用了 FragmentTabHost。但是,此信息不会改变整个问题。事实上,如果我将这个 API 与 fragment 嵌套一起使用,我的应用程序将无法在今天大约 30% 的设备上运行(原生 fragment 从 4.2 开始支持嵌套)。
示例:
我今天遇到的另一个问题(并且浪费了太多时间)是 ActionBarDrawerToggle可通过 android.support.v7.app.ActionBarDrawerToggle
获得。我想使用这个功能,因此我将整个 com.android.support:appcompat-v7:21.0.+
添加到项目的依赖项中。我猜这会做,但我错了——我的应用程序没有编译(缺少支持库引用的资源)。在网上尝试了一些技巧后,我找到了this question最终提供了解决方案。简而言之:v7 支持库依赖于 SDK,因此我必须定义 compileSdkVersion 21
.
后果:
现在,我告诉自己:FragmentTabHost 尚未添加到任何 SDK 版本中,这意味着即使在 4-5 年后,开发人员仍将继续使用 support-v4 lib 来提供此功能(因为即使此 API是今天添加的,您可能需要数年时间才能安全地假设所有目标设备都 native 支持它),对吧?相同的论点适用于 android.support.v4.widget.DrawerLayout
和仅存在于支持库中的其他 API。
如果开发人员一定要使用支持库多年,这也意味着他们一定会在这些问题已经解决很久之后遇到上述不一致/依赖问题,对吧?
问题:
Google 为什么要永久保留这些库?如果所有新的 API 都与兼容性库并行添加到 SDK 中,这样兼容性库可能会老化并在某个时候“退役”,这不是更好吗?
编辑:在@eugen 的回答之后,我现在更加困惑 - 一些 API “进化”与更新的支持库,但没有进入主 SDK(如 FragmentTabHost,它从 support-v4 演变为支持-v7)。不将它们添加到 SDK 的原因是什么?
最佳答案
FragmentTabHost API is available only through android.support.v4.app.FragmentTabHost.
不正确。您提供的链接指向 android.support.v13.app.FragmentTabHost
(与 android.support.v4.app.FragmentTabHost
不同)适用于 native fragment
,但使 API 13 以上引入的 API 从 API 13 开始可用。
In short: v7 support library has dependency on SDK, therefore I had to define compileSdkVersion 21.
当然21版本的库需要21版本的工具和21版本的SDK。 始终使用相应版本的构建工具,编译 SDK 和支持库!
从今天开始,建议使用以下值:
compileSdkVersion 22
buildToolsVersion '22.0.1'
targetSdkVersion 22
compile 'com.android.support:support-v4:22.0.0'
compile 'com.android.support:appcompat-v7:22.0.0' // includes support-v4
compile 'com.android.support:support-v13:22.0.0' // includes support-v4
Now, I tell myself: FragmentTabHost haven't been added to any SDK version yet, which implies that even 4-5 years from now developers will continue to use support-v4 lib for providing this functionality (because even if this API is added today, it will take years before you could safely assume that all target devices support it natively), right?
这意味着如果您使用 support-v13
库来实现它,您无需担心。它将在 API 13 中运行。
阅读上面的 support-v4
和 support-v13
之间的区别。
Why would Google want to keep these libraries forever?
因为您很可能希望支持旧平台。这意味着您需要一个支持库。
即使现在你使用 appcompat-v7
中的 ActionBarActivity
(最初打算将操作栏向后移植到 API 7)和 minSdkVersion 14
因为你想要那个 Material 设计的后端。这也意味着你被支持 fragment 卡住了,因为 ActionBarActivity
正在使用它们。
Won't it be better for everybody if all the new APIs were added to SDK in parallel to compatibility libs, such that compatibility libraries could age and "resign" at some point?
支持图书馆时代。您可能已经注意到 recyclerview-v7
(以及其他最近的 android 库)自 API 7 而非 API 4 以来可用。而且您可能还注意到 RecyclerView
不在原生 SDK。当您可以推出支持库以供所有人使用时,为什么要将其添加到 native SDK 以使其仅可用于最新平台?
关于android - 为什么 AOSP 添加新的 API 来支持库而不将它们添加到 SDK?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29197821/
Java 库和 android 库有什么区别,各自有什么优点/缺点? 最佳答案 您可以在 Android 应用程序中包含标准 Java .jar 文件库。它们在 .apk 构建时被翻译成 Dalvik
所以,我现在的代码就像从 Java 层加载库(比如 liba.so),并在内部 liba.so 加载 libb.so。因此,如果我必须将所有库打包到 APK 中并将其安装在没有 root 访问权限的设
我想在我的系统中设置 LEDA 库。 我已经从以下链接下载了 LEDA 库 http://www.algorithmic-solutions.info/free/d5.php Instruct
我想用 autoconf 创建一个共享库。但是,我希望共享库具有“.so”扩展名,而不是以“lib”开头。基本上,我想制作一个加载 dlopen 的插件。 .是否有捷径可寻? 当我尝试使用 autoc
我需要在 Apps 脚本应用程序上修改 PDF。为此,我想使用 JS 库:PDF-LIB 我的代码: eval(UrlFetchApp.fetch("https://unpkg.com/pdf-lib
我正在构建一个使用以下 Boost header 的程序(我使用的是 Microsoft Visual C++ 10), #include #include #include #include
当我通过 cygwin 在 hadoop 上运行此命令时: $bin/hadoop jar hadoop-examples-*.jar grep input output 'dfs[a-z.]+' 我
我已经通过 vcpgk 成功安装了一个 C++ 库,名为:lmdb:x64-windows 我还安装了lmdb通过 Cabal 安装的 Haskell 绑定(bind)包 在尝试测试 lmdb 包时:
我该如何解决这个问题? 我刚刚将 javacv jar 文件复制到我的项目 Lib 文件夹下,但出现了这个错误! 我可以找到这个thread来自谷歌,但不幸的是,由于我国的谷歌限制政策,该页面无法打开
我有一个 Android 库项目 FooLib。 FooLib 引用 Android Context 之类的东西,但不需要任何资源文件(res/ 中的东西)所以我目前将其打包为供我的应用使用的 JAR
我正在开发一个 Android 应用程序(使用 Android Studio),它能够通过手势识别算法了解您正在进行的 Activity 。对于我使用 nickgillian ithub 帐户上可用的
关于从 .NET Framework 项目中引用 .NET Standard 类库的问题有很多类似的问题,其中 netstandard 库中的 NuGet 包依赖项不会流向 netframework
我已经从互联网上下载了 jna-4.2.2.jar,现在想将这个 jar 导入到我的项目中。但是当我试图将这个 jar 导入我的项目时,出现以下错误。 [2016-06-20 09:35:01 - F
我正在尝试通过编译在 Mac 上安装 rsync 3.2.3。但是,我想安装所有功能。为此,它需要一些库,此处 ( https://download.samba.org/pub/rsync/INSTA
进入 Web 开发有点困难。过去 5 年我一直致力于 winforms 工作。所以我正在努力从一种切换到另一种。前段时间,我使用过 JavaScript,但现在还没有大量的 JavaScript 库
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我正在寻找一个用Python编写的与logstash(ruby + java)类似的工具/库。 我的目标是: 从 syslog 中解析所有系统日志 解析应用程序特定日志(apache、django、m
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我花了几天时间试图寻找用于 JavaPOS 实现的 .jar 库,但我找不到任何可以工作的东西。我找到了很多像这样的文档:http://jpos.1045706.n5.nabble.com/file/
这个问题在这里已经有了答案: Merge multiple .so shared libraries (2 个答案) 关闭 9 年前。 我有我在代码中使用的第三方库的源代码和对象。该库附带有关如何使
我是一名优秀的程序员,十分优秀!