GB2312与UNICODE码互转

 

static int code_convert(char *from_charset, char *to_charset, char *inbuf, int inlen, char *outbuf, int outlen)
{
	iconv_t cd;
	char **pin = &inbuf;
	char **pout = &outbuf;

	cd = iconv_open(to_charset, from_charset);
	if (cd == 0)
	{
		return -1;
	}

	memset(outbuf, 0, outlen);

	if (iconv(cd, pin, &inlen, pout, &outlen) == -1)
	{
		iconv_close(cd);
		return -1;
	}

	iconv_close(cd);

	return 0;
}

int g2u(char *inbuf,size_t inlen,char *outbuf,size_t outlen)
{
	return code_convert("gb2312","utf-8",inbuf,inlen,outbuf,outlen);
}

int u2g(char *inbuf,int inlen,char *outbuf,int outlen)
{
	return code_convert("utf-8","gb2312",inbuf,inlen,outbuf,outlen);
}

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
GB2312是一种常见的汉字编系统,而Unicode是一种全球通用的字符编标准。当需要将GB2312的字符换为Unicode时,需要进行字符编换操作。对于需要存储字库的情况,可以按照以下步骤进行换。 首先,需要明确要存储的字库范围,即所需换的GB2312字符集的大小。根据范围确定需要换的字符数量,从而确定所需存储的Unicode的字节数量。可以根据需求确定存储方式,可以选择将Unicode按照特定格式存储在文件或者数据库中。 其次,创建一个存储字库的数据结构,可以选择数组、链表等数据结构。将GB2312字符作为输入,通过编换工具或者编程语言中提供的换函数,将GB2312换为对应的Unicode。将换得到的Unicode存储在字库的数据结构中,可以使用字符的索引作为Unicode的位置。 最后,将存储好的字库数据结构保存到文件或者数据库中,以便后续使用。存储方式可以根据需求选择,可以将Unicode保存为二进制文件,也可以将Unicode按照特定格式保存到数据库的表中。在使用字库时,可以根据需要从文件中读取字库数据或者从数据库中查询相应的Unicode。 总结来说,将GB2312换为Unicode并存储为字库可以通过确定范围、换编、选择存储方式等步骤完成。通过合理的存储方式,可以方便快速地使用和查询存储的Unicode
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值