ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

为什么iconv函数需要非const inbuffer?

2019-05-16 08:50:16  阅读:178  来源: 互联网

标签:c-3 linux iconv


document of iconv中,功能简介是这样的:

#include <iconv.h>

size_t iconv (iconv_t cd, const char* * inbuf, 
      size_t * inbytesleft, 
      char* * outbuf, 
      size_t * outbytesleft);

但是,当我在我的系统中检查iconv.h时,函数概要是这样的:

extern size_t iconv (iconv_t __cd, char **__restirct __inbuf,
      size_t *__restrict __inbytesleft,
      char **__restirct __outbuf,
      size_t *__restrict __outbytesleft);

在这两个函数概要中,一个是const char **,但另一个只是char **.

为什么文档中的函数概要与我系统中的函数概要不同?为什么iconv函数需要一个非const的inbuffer?

我的g版本是6.3.0.

最佳答案:

iconv()的问题在于它不是C标准的一部分,但是它以两种不同的标准指定.其中一个是POSIX-1.2008

#include <iconv.h>

size_t iconv(iconv_t cd, char **restrict inbuf,
       size_t *restrict inbytesleft, char **restrict outbuf,
       size_t *restrict outbytesleft);

另一个是SUSv2

#include <iconv.h>

size_t iconv(iconv_t cd, const char **inbuf, size_t *inbytesleft,
    char **outbuf, size_t *outbytesleft);

它们的** inbuf的常量不同,所以如果你想在两个标准之间保持可移植性,不幸的是你必须传递一个非const ** inbuf.

编辑:因为这是一个双指针,问题更糟,see my answer here.简而言之,这些规范在任何一个方向都不兼容……

您作为“iconv文档”链接的是GNU libiconv的文档,该文档旨在用于本身不提供iconv()的平台上 – 这显然遵循SUSv2规范.

您在系统中找到的头文件属于glibc,即平台的C库,此实现遵循POSIX-1.2008规范.

标签:c-3,linux,iconv
来源: https://codeday.me/bug/20190516/1113584.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有