- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我认为 Linux 的一个主要设计缺陷是在以二进制而非源代码形式分发程序时的共享对象 hell 。
这是我的具体问题:我想以 ELF 二进制形式发布一个 Linux 程序,该程序应在尽可能多的发行版上运行,以便我的强制依赖性尽可能低:在任何情况下唯一需要的库是 libpthread, libX11、librt 和 libm(当然还有 glibc)。当我使用 gcc 构建我的程序时,我正在动态链接这些库。
但是,我的程序也可以选择支持 ALSA(声音接口(interface))、Xcursor、Xfixes 和 Xxf86vm 扩展以及 GTK。但是只有当它们在用户的系统上可用时才应该使用这些,否则我的程序应该仍然运行但功能有限。例如,如果 GTK 不存在,我的程序将回退到终端模式。因为我的程序应该仍然能够在没有 ALSA、Xcursor、Xfixes 等的情况下运行。我无法动态链接到这些库,因为如果其中一个库不存在,程序将根本无法启动。
所以我需要手动检查库是否存在,然后使用 dlopen() 一个一个地打开它们,并使用 dlsym() 导入必要的函数符号。然而,这会导致各种问题:
1) 库命名约定:共享对象通常不简单地称为“libXcursor.so”,而是具有某种版本扩展名,如“libXcursor.so.1”,甚至是非常有趣的东西,如“libXcursor.so.0.2000”。这些扩展似乎因系统而异。那么调用dlopen()应该选择哪一个呢?在这里使用硬编码名称似乎是一个非常糟糕的主意,因为名称因系统而异。因此,我想到的唯一解决方法是扫描整个库路径并查找以“libXcursor.so”前缀开头的文件名,然后进行一些自定义版本匹配。但我怎么知道它们真的兼容?
2) 库搜索路径:我到底应该在哪里寻找 *.so 文件?这也因系统而异。有一些默认路径,如/usr/lib 和/lib,但 *.so 文件也可以位于许多其他路径中。所以我必须打开/etc/ld.so.conf 并解析它以找出所有库搜索路径。这不是一件小事,因为/etc/ld.so.conf 文件也可以使用某种 include 指令,这意味着我必须解析更多的 .conf 文件,对可能的文件进行一些检查由循环 include 指令等引起的无限循环。真的没有更简单的方法来找出 *.so 的搜索路径吗?
所以,我的实际问题是:是否有更方便、更简单的方法来实现我想做的事情?创建一个具有一些可选依赖项(如 ALSA、GTK、libXcursor……但没有它也应该可以工作)的 Linux 程序真的那么复杂吗?做我想做的事有某种标准吗?还是我注定要以这种骇人听闻的方式来做?
感谢您的意见/解决方案!
最佳答案
I think a major design flaw in Linux is the shared object hell when it comes to distributing programs in binary instead of source code form.
就系统的创建者而言,这不是设计缺陷;这是一个优势——它鼓励您以源代码形式分发程序。哦,你想卖你的软件?抱歉,这不是 Linux 优化的用例。
Library naming conventions: Shared objects often aren't simply called "libXcursor.so" but have some kind of version extension like "libXcursor.so.1" or even really funny things like "libXcursor.so.0.2000".
是的,这叫做外部库版本控制。了解一下 here .从该描述中应该清楚,如果您在通常会给您 libXcursor.so.1
作为运行时引用的系统上使用 header 编译二进制文件,那么仅您兼容的共享库是 libXcursor.so.1
,尝试 dlopen
libXcursor.so.0.2000
将导致不可预测的崩溃。
任何提供 libXcursor.so
但不提供 libXcursor.so.1
的系统要么安装损坏,要么与您的二进制文件不兼容。
Library search paths: Where should I look for the *.so files after all?
您不应该尝试使用它们的完整路径 dlopen 这些库中的任何一个。只需调用 dlopen("libXcursor.so.1", RTLD_GLOBAL);
,运行时加载器就会在系统适当的位置搜索库。
关于linux - 在运行时加载 Linux 库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15951672/
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 年前。 我有我在代码中使用的第三方库的源代码和对象。该库附带有关如何使
我是一名优秀的程序员,十分优秀!