- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
最近我在两个系统上编译了 ICU 49.1.2 - 一个是 Ubuntu,一个是基于 Debian 的系统(Raspberry Pi 的“Wheezy”)。 Ubuntu 系统可以运行,但当我尝试运行任何 ICU 可执行文件或将其与我的应用程序链接时,RPi 系统报告错误:
me@raspberrypi ~/icu/source $ genrb -V
genrb: error while loading shared libraries: libicudata.so.49: cannot open shared object file: No such file or directory
我已经验证了库的存在:
me@raspberrypi ~/icu/source $ find / -name 'libicudata.so*' 2>/dev/null
/usr/local/lib/libicudata.so
/usr/local/lib/libicudata.so.49.1.2
/usr/local/lib/libicudata.so.49
pkg-config 证实了这一点:
me@raspberrypi ~/icu/source $ pkg-config --libs-only-L icu-uc
-L/usr/local/lib
我还确保在安装 ICU 后运行 sudo ldconfig
。我什至尝试在故障系统上运行 make check
:
LD_LIBRARY_PATH=../../lib:../../stubdata:../../tools/ctestfw:$LD_LIBRARY_PATH ./../../bin/uconv -f ibm-37 ./samples/ibm-37-test.txt
./../../bin/uconv: can not initialize ICU. status = U_FILE_ACCESS_ERROR
make[2]: *** [check-local] Error 1
make[2]: Leaving directory `/home/uli/icu/source/extra/uconv'
make[1]: *** [check-recursive] Error 2
make[1]: Leaving directory `/home/uli/icu/source/extra'
make: *** [check-recursive] Error 2
据我所知,这些系统在必要文件的位置和存在方面是相同的。看起来基于 Debian 的 Raspberry Pi 坚持在其他地方(大概是/usr/lib)寻找 libicudata.so 而不是/usr/local/lib。我可以更改 ./configure 脚本上的 --prefix 来解决问题,但我想了解为什么一个系统可以工作而另一个系统不能。
更新
好吧,我认为我可以通过将“--prefix”参数更改为 ./configure 脚本来解决问题,但事实证明这不起作用。我在/usr/lib 和/usr/local/lib 中有 libicudata.so.49,但 ICU 仍然找不到这些库。
我还尝试创建一个仅包含 ICU 库的“Hello World”程序,看看会发生什么。同样的失败:
me@raspberrypi ~ $ gcc -licudata -licuuc helloworld.c
me@raspberrypi ~ $ ./a.out
./a.out: error while loading shared libraries: libicudata.so.49: cannot open shared object file: No such file or directory
me@raspberrypi ~ $ ldd a.out
/usr/lib/arm-linux-gnueabihf/libcofi_rpi.so (0xb6f41000)
libicudata.so.49 => not found
libicuuc.so.49 => /usr/local/lib/libicuuc.so.49 (0xb6df8000)
libc.so.6 => /lib/arm-linux-gnueabihf/libc.so.6 (0xb6cc9000)
libicudata.so.49 => not found
libpthread.so.0 => /lib/arm-linux-gnueabihf/libpthread.so.0 (0xb6caa000)
libdl.so.2 => /lib/arm-linux-gnueabihf/libdl.so.2 (0xb6c9f000)
libstdc++.so.6 => /usr/lib/arm-linux-gnueabihf/libstdc++.so.6 (0xb6bd2000)
libm.so.6 => /lib/arm-linux-gnueabihf/libm.so.6 (0xb6b61000)
libgcc_s.so.1 => /lib/arm-linux-gnueabihf/libgcc_s.so.1 (0xb6b39000)
/lib/ld-linux-armhf.so.3 (0xb6f4d000)
更新 2
我现在正在重新编译并注释掉 LDFLAGSICUDT 标志(RPi 的编译速度有点慢)。
至于其他评论,这里是文件命令的输出:
me@raspberrypi ~ $ file /usr/local/lib/libicudata.so*
/usr/local/lib/libicudata.so: symbolic link to `libicudata.so.49.1.2'
/usr/local/lib/libicudata.so.49: symbolic link to `libicudata.so.49.1.2'
/usr/local/lib/libicudata.so.49.1.2: ELF 32-bit LSB shared object, ARM, version 1 (SYSV), dynamically linked, BuildID[sha1]=0xfb336da457f28964a6161af4d7b07902882d6fa8, not stripped
最佳答案
我刚刚看了一下 12.04 LTS 上的 icu 包。这是一个较旧的版本 (4.8),但在 source/config/mh-linux 中注释掉了 LDFLAGSICUDT 标志,并且注释指出仅将其链接为数据会导致太多问题。
注释掉 LDFLAGSICUDT 可以解决问题。
关于ubuntu - 基于 Debian 系统构建的 ICU 49 加载 libicudata.so 失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17687336/
我正在尝试学习 ICU 语法并希望能够表达在 ICU message format 中列出. 例如,给定数据: items: - cool - handy - neat 我希望能够生成如下
是否可以获得适当的大写,例如使用 ICU4C 的英文文本但没有构建任何自定义的非大写单词集?比如说,鉴于对峡湾的渴望,我希望获得对峡湾的渴望。 使用 ucasemap_utf8ToTitle() 和
我想编译 icu sqlite extension静态链接到 icu . 这是我试过的,也许错误对你来说是显而易见的。 > cd icu/source> ./runConfigureIcu Linux
我试图将我们 CI 环境中的 Node 版本从 Node 6 升级到 Node 8。我也更新了完整的 icu 版本。 $NODE_ICU_DATA 设置为 /usr/lib/node_modules/
我今天开始使用最新的 Android Build Tools (ABT) v19.0.3 收到消息。乍一看,我认为这可能是 ABT 的问题。然而,更仔细的调查显示这条消息: android.suppo
unicode 排序背后的理论是什么?我明白它是如何工作的,但我不明白为什么 they决定采用此标准进行归类排序。 似乎当您有两个字符串要比较时,例如使用 ucol_strcolliter(): uc
我的应用程序可能在一个列表中包含由不同字母/语言组成的字符串。我似乎无法找到有关对这些进行排序的正确方法应该是什么的任何信息,或者任何表明 ICU 支持此功能的迹象。 示例列表: 苹果 яблоко
如何在iPhone应用程序的工作区中使用ICU(Unicode国际组件)将sqlite编译为项目? 我之前已经编译了sqlite合并,但是我不确定应该下载哪些文件以及需要将哪些脚本添加到xcode中-
我正在尝试使用 ICU 音译器对某些文本进行非常具体的转换,如 here 所述. 我的文本包含半角片假名字符和常规拉丁字符。我想将半角片假名转换为全角片假名,同时保持非片假名字符不变。 我想简单地应用
有没有办法探测ICU library对于所有 UChar's表示库支持的货币符号? 我当前的解决方案是遍历所有语言环境并针对每个语言环境,执行如下操作: const DecimalFormatSymb
谁能解释为什么下面的比较不相等? void CompareTest() { UErrorCode status = U_ZERO_ERROR; UChar ruleset[500]; *rul
有没有办法探测 ICU最小面额的货币区域设置?例如,美国为 0.01 美元,韩国 (ko_KR) 为 ₩1。我想在 DecimalFormat object 上调用 getRoundingIncrem
我正在创建 SQLite3 的自定义构建,我想实现不区分大小写的文本列。 是否可以创建不区分大小写的排序规则? 最佳答案 你可能想调用 ucol_setStrength具有 UCOL_PRIMARY
我们有使用 ICU 库处理 Unicode 字符串的代码。当我们尝试构建它时,没有出现编译错误,但链接失败了。我用以下代码创建了一个小测试程序: #define U_STATIC_IMPLEMENTA
有人知道 ICU 字符集检测器的数据是如何构建的吗?添加其他语言是否困难? 例如,我在错误跟踪器中看到,自 2007 年以来就打开了检测泰语的票证,但直到今天都没有新内容。 谢谢 最佳答案 我会在 I
您好,我将我的sql语句修改为 CREATE VIRTUAL TABLE [v_fts] USING fts4 ( [title], tokenize=icu )" 但是当我尝试插入数据时出现错误
我的目标是逐个字符地迭代 Unicode 文本字符串,但下面的代码迭代的是代码单元而不是代码点,即使我使用的是 next32PostInc () 应该迭代代码点: void iterate_codep
是否可以在不退回到正则表达式的情况下使用 ICU 完成? 目前我规范化文件名是这样的: protected function normalizeFilename($filename) { $t
我了解 ICU 的本地化部分 - 日期、时间和货币格式、整理等。在消息翻译方面,我看到有人说 ICU 不提供消息翻译功能 - 例如查看 this SOF question . 但是,在查看 ICU 文
我想知道是否有一种方法可以在 ICU (c++) 库中引用字符串。存在 "\Q"+ string + "\E"但我生成的输入作为提供的字符串输入。似乎没有任何 ICU 引用正则表达式方法。只需将字符串
我是一名优秀的程序员,十分优秀!