我正在将应用程序从 CentOS 6 移植到 Mac OS X。它依赖于 iconv 并在 CentOS 中正常工作。但是,在 Mac OS X 上却没有。我看到以下行为:
const char *codePages[] = { "MAC", "LATIN1", "ISO_8859-1", "WINDOWS-1252", "ASCII" };
int codePagesCount = 5;
iconv_t converter1 = iconv_open("UTF-32", codePages[0]);// Works
if(converter1 != (iconv_t)-1)
iconv_close(converter1);
iconv_t converter2 = iconv_open("UTF−32", "MAC");// Fails, returns -1
if(converter2 != (iconv_t)-1)
iconv_close(converter2);
这段代码看起来很简单:第一个 iconv_open 创建转换器并从 codePages 数组获取代码页名称,它的零元素是 MAC,所以对我来说 Mac OS X 必须支持从它自己的代码页到 Unicode 的转换是合乎逻辑的。第一次调用 iconv_open 有效。但是,对 iconv_open 的第二次调用也是如此。它还创建了从 Mac 编码到 Unicode 的转换器。并且由于任何原因它失败并返回-1。当调用具有相同参数的相同函数(一个是硬编码数组的元素,另一个是硬编码字符串)导致第一次调用正常功能而第二次调用失败时,这种情况的原因可能是什么?