UTF-8 到UTF -16 转换C程序

这是一个C语言实现的函数,将UTF-8编码的字符串转换为Big Endian格式的UTF-16编码。函数处理了从ASCII到UTF-16的各种Unicode字符范围,并检查目标缓冲区是否足够防止越界。当遇到无法转换的字符时,程序会输出错误信息并终止转换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

程序代码如下:
/** \brief
 *  以下实现都是Big Endian格式
 *  返回值为utf16字符的长度
 *  attention :UTF16还能表示一部分的UCS-4代码点
 *  这里为了简便就没有添加到代码中
 *  因此这里的UTF16其实是UCS-2
 * \param dest char*  目标字符串数组首地址
 * \param src const char* 源字符串数组首地址
 * \param destMaxLen int  目标字符串数组最大长度,防止越界
 * \return int 目标字符串的长度
 *
 */
int utf8ToUtf16(char *dest,const char *src,int destMaxLen)
{
    int destLen=0;  //记录目标字符串的长度
    int i=0;
    char temp;
    while(i<strlen(src))
    {
       if(destMaxLen-destLen>=2)
        {
            if ((src[i] | '\x7f')=='\x7f')
                //U+0000-U+007F
            {
                dest[destLen++]=0x00;
                dest[destLen++]=src[i];
                i=i+1;
            //源串移动一位
            }
         else if((src[i] | '\x1f')=='\xdf')
                //U+0080-U+07FF
                {
                    dest[destLen++]=((0x1c & src[i])>>2);
                    dest[destLen++]=((0x3f & src[i+1]))+((0x03 &src[i])*64);
                    i=i+2;
                }
         else if((src[i] | '\x0f')=='\xef')
                //U+0800-U+FFFF
                {
                    dest[destLen++]=((0x0f & src[i])*16)+((0x3c & src[i+1])>>2);
                    dest[destLen++]=(0x03 & src[i+1])*64+(0x3f & src[i+2]);
                    i=i+3;
                }

            else {
                temp=src[i];
                printf("%x\n",(temp | 0x0f));
                printf("convert error!\n");
                break;
            }
        }
        else{
                printf("Destination string capicity is not enough!Transformation terminated!\n");
                break;
        }
    }
    return destLen;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值