Linux下字符转换函数

Linux下面的没有命名为 WideCharToMultiByte() 和 MultiByteToWideChar() 函数,WideCharToMultiByte,MultiByteToWideChar是windows下的函数,在linux下也有类似的两个函数:

mbstowcs()
wcstombs()

值得注意的是:

size_t mbstowcs(wchar_t *wcstr,const char *mbstr,size_t count);

这个函数的第三个参数count,大小一定要是mbstr长度的2倍,否则出来的中文也会是乱码

测试一下:

setlocale(LC_ALL,"zh_CN.GB18030");
wchar_t wcstr[20] = L"字符测试123abc";

int len = wcslen(wcstr)+1;
printf("len = %d /n",len);
for(int i = 0; i < len; i++)
    printf("0x%08x ",wcstr[i]);
printf("/n");

char str[55] = {0};    
int n = wcstombs(str,wcstr,55);
if(-1 == n)
{
   perror("wcstombs ");
   exit(-1);
 }    
printf("n = %d/n",n);
for(int i = 0; i < n+1; i++)
   printf("0x%08x ",str[i]);
printf("/n");    
wchar_t wch[50]={0};
int m = mbstowcs(wch,str,n);    
if(m == -1)
{
   perror("Converting");
   exit(-1);
}
printf("m = %d/n",m);
for(int i =0; i<m+1;i++)
  printf("0x%08x ",wch[i]);
 printf("/n");
 return 0;

还有呢,转码还可以使iconv函数族,包含以下三个函数:
iconv_t iconv_open(const char *tocode, const char *fromcode);

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

int iconv_close(iconv_t cd);

测试一下:

#include <stdio.h> 
#include <iconv.h> 
#include <string.h>
#define BUFLEN 256
char outbuf[BUFLEN]; 
char inbuf[BUFLEN] = "characters convertion";
int main() 
{     
     char *pin = inbuf; 
     char *pout = outbuf; 

     int inlen = strlen(pin); 
     int outlen = BUFLEN;
     int retsize;
     iconv_t cd;
     cd = iconv_open("UTF-8", "GBK");
     if((iconv_t)-1 == cd) { 
             perror("iconv_open error"); 
             return -1; 
     }
     retsize = iconv(cd, &pin, (size_t *)&inlen, &pout, (size_t *)&outlen);
     if((size_t)-1 == retsize) { 
             perror("iconv error"); 
             return -2;    
     }
     if(outlen > 0) { 
             printf("%s/n", outbuf); 
     }
     iconv_close(cd);
     return 0; 
}

另外

关于Linux下转码的资料,这里比较全:

http://www.360doc.com/content/11/0119/14/1317564_87612492.shtml

仔细读,所有的问题基本都可以找到答案。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux中有一个命令行工具叫做base64,可以用来进行base64编码和解码操作。base64是一种将二进制数据转换成可打印字符的编码方式,常用于在网络传输中传递二进制数据或存储二进制数据。 在Linux中,可以使用以下命令进行base64编码和解码: 1. 编码:将二进制数据转换为base64编码字符串 ``` echo -n "Hello, World!" | base64 ``` 输出结果为: ``` SGVsbG8sIFdvcmxkIQ== ``` 2. 解码:将base64编码字符转换为二进制数据 ``` echo -n "SGVsbG8sIFdvcmxkIQ==" | base64 -d ``` 输出结果为: ``` Hello, World! ``` 除了命令行工具,Linux还提供了一些C语言库函数用于进行base64编码和解码操作。其中,`<openssl/bio.h>`头文件中的函数可以实现base64编码和解码。以下是一个示例代码: ```c #include <stdio.h> #include <openssl/bio.h> #include <openssl/evp.h> int main() { const char* input = "Hello, World!"; int input_len = strlen(input); // 编码 BIO* b64 = BIO_new(BIO_f_base64()); BIO* bio = BIO_new(BIO_s_mem()); bio = BIO_push(b64, bio); BIO_write(bio, input, input_len); BIO_flush(bio); BUF_MEM* bptr; BIO_get_mem_ptr(bio, &bptr); printf("Base64 编码结果:%s\n", bptr->data); // 解码 BIO* b64_decode = BIO_new(BIO_f_base64()); bio = BIO_new_mem_buf(bptr->data, bptr->length); bio = BIO_push(b64_decode, bio); char output[256]; int output_len = BIO_read(bio, output, input_len); output[output_len] = '\0'; printf("Base64 解码结果:%s\n", output); // 释放资源 BIO_free_all(bio); return 0; } ``` 这段代码使用了OpenSSL库中的函数进行base64编码和解码操作。编码结果为`SGVsbG8sIFdvcmxkIQ==`,解码结果为`Hello, World!`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值