windows下使用aspera_vlc windows

windows下使用aspera_vlc windows资源下载官网资源:https://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.16.tar.gz环境配置编译环境:Win764位系统VS2015创建一个VS2015项目,应用程序类型使用静态库,注意取消勾选“使用预编译头”;将资源[libiconv-1.16\lib]文件夹下的所有文件,全部复制到第一步创建的工程目录下,并找到config.h….

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

资源下载

官网资源: https://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.16.tar.gz
CSDN资源:https://download.csdn.net/download/hhhuang1991/11979866
VS2015配置项目+测试代码

环境配置

编译环境:Win7 64位系统 VS2015

  1. 创建一个VS2015项目,应用程序类型使用静态库,注意取消勾选“使用预编译头”;
  2. 将资源[libiconv-1.16\lib]文件夹下的所有文件,全部复制到第一步创建的工程目录下,并找到config.h.in文件,将后缀.in去掉;
  3. 将资源[libiconv-1.16\include]文件夹下的iconv.h.in,复制到工程目录下,并将后缀.in去掉;
  4. 将资源[libiconv-1.16\libcharset\lib]文件夹下的localcharset.c,复制到工程目录下;
  5. 将资源[libiconv-1.16\libcharset\include]文件夹下的localcharset.h.in,复制到工程目录下,并将后缀.in去掉;
  6. 将资源[libiconv-1.16\include]文件夹下的iconv.h.in,复制到工程目录下,并将后缀.in去掉;
  7. iconv.clocalcharset.c文件加载到工程中;
  8. 直接编译工程。

异常排除

  1. iconv.c文件中#include <config.h>改为#include "iconv.h"
    localcharset.c文件中#include <config.h>改为#include "config.h"
 fatal error C1083: 无法打开包括文件: “config.h”: No such file or directory
 fatal error C1083: 无法打开包括文件: “iconv.h”: No such file or directory

Jetbrains全家桶1年46,售后保障稳定

  1. 找到iconv.h文件中,所有带@符号的字符串都要去掉@或屏蔽:
Line21,@DLL_VARIABLE@改为/*@DLL_VARIABLE@*/
Line82,@ICONV_CONST@改为const
Line100, @USE_MBSTATE_T@改为USE_MBSTATE_T
Line101,@BROKEN_WCHAR_H@改为BROKEN_WCHAR_H
Line121, @USE_MBSTATE_T@改为 USE_MBSTATE_T
Line168,@HAVE_WCHAR_T@改为HAVE_WCHAR_T
  1. 找到localcharset.c文件中的sprintf函数,全部替换成安全类型的函数sprintf_s

Demo

  1. 编译上面工程,将会生成静态库libiconv.lib。
  2. 创建一个测试工程。将iconv.h和库文件libiconv.lib拷贝到测试工程目录下,测试代码如下,
#include "stdafx.h" 
#include "..\libiconv\iconv.h"
#pragma comment(lib, "..\\Debug\\libiconv.lib")
#include <iostream>
using namespace std;
int main()
{ 
   
     // 将GBK编码的字串,转成UTF-8编码的字
     iconv_t cd = iconv_open("UTF-8", "GBK"); 
     if ((iconv_t)-1 == cd)  
     { 
   
	 if (EINVAL == errno)
	 { 
   
	   cerr << "The conversion from fromcode to tocode is not supported by the implementation" << endl;
	 }
	 else { 
   
	   cerr << "iconv_open fail!" << endl;
	 }
	  return -1;
     }
     
     // 将转换描述符cd中的转换状态恢复成初始化状态,方法是iconv中的inbuff参数设置成NULL
     iconv(cd, NULL, NULL, NULL, NULL);
     // 将GBK编码的"啊"转成UTF-8编码
     char * inbuff = new char[64];
     memset(inbuff, 0, sizeof inbuff);
     char *outbuff = new char[64];
     memset(outbuff, 0, sizeof outbuff);
     
     // "啊"的GBK编码为0xB0A1,UTF-8编码为0xE2 0x80 0x9C
     inbuff[0] = 0xA1;
     inbuff[1] = 0xB0;
     char * inptr = inbuff;   // 为什么要设置这个中间指针inptr,而不支持采用 inbuff?因为iconv会改变指针inbuff的值,这样在删除内存时delete[] inbuff,将会出错
     size_t insize = 2;
     char * outptr = outbuff;  // 作用与inptr类似
     size_t outsize = 64;
     char *save = new char[64];
     memset(save, 0, sizeof save);
     size_t outsave = 0;
     
     // 资料介绍,iconv每次只转换一个多字节字符。但是经过测试,只要内容是正常,都是一次转换完,不明白其中缘由。
     size_t ret = iconv(cd, (const char **)&inptr, &insize, &outptr, &outsize);
     if ((size_t)-1 == ret) { 
   
        if (E2BIG == errno) { 
   
            cerr << "There is not sufficient room at *outbuf." << endl;
        }
        else if (EILSEQ == errno) { 
   
            cerr << "An invalid multibyte sequence has been encountered in the input." << endl;
        }
        else if (EINVAL == errno) { 
   
            cerr << "An incomplete multibyte sequence has been encountered in the input." << endl;
        }
        goto TestFinished;
     }
     else { 
   
        outsave = 64 - outsize;
        memcpy(save, outptr - outsave, outsave);   // 此处采用memcpy而不采用strcpy的目的是,当ACSII类型字符转换到UCS2类型时,会产生0x00的字符,使用strcpy复制会在此处截断,导致内容丢失
     }
     cout << "successed." << endl;
TestFinished:
     delete[] inbuff;
     delete[] outbuff;
     delete[] save;
     iconv_close(cd);
     getchar();
     return 0;
  }
	
	

参考资源

iconv_open
iconv

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/234978.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • PC傻瓜式安装黑苹果并打造成全能逆向工作站–更新至2021.12.20

    PC傻瓜式安装黑苹果并打造成全能逆向工作站–更新至2021.12.20安装黑苹果有多简单原版Windows镜像安装大家都会,当然Ghost安装除外喔,太“乡村范儿”了。Windows操作系统的安装,无非下列四个步骤。准备镜像→写镜像到U盘→从U盘安装系统→系统自定义配置现在我们安装黑苹果也是同样的流程。先说一下本机的配置:2014年1999元买的宁美国度的组装台式机*CPU:i34160*GPU:HD4400CPU自带*RAM:4…

    2022年6月11日
    37
  • QT(C++)面试总结

    QT(C++)面试总结参考博客QT信号槽机制的优缺点(1)问题:为什么Qt使用信号与槽机制而不是传统的回调函数机制进行对象间的通信呢?回调函数的本质是“你想让别人的代码执行你的代码,而别人的代码你又不能动”这种需求下产生的。回调函数是函数指针的一种用法,如果多个类都关注某个类的状态变化,此时需要维护一个列表,以存放多个回调函数的地址。对于每一个被关注的类,都需要做类似的工作,因此这种做法效率低,不灵活。(2)解决办法Qt使用信号与槽机制来解决这个问题,程序员只需要指定一个类含有哪些信号函数、哪些槽函数,Qt会处理信

    2022年6月25日
    22
  • <Win32_15>用纯C语言来实现WP8中磁贴动态翻转的功能「建议收藏」

    今年年初入手了一部诺基亚新款WP8手机——Lumia620经典蓝,用起来感觉很不错,很流畅、界面很清新到现在,用了大概有大半年时间了,一直很好奇WP8中磁贴动态翻转的实现算法——使用过WP8手机的朋友都知道,这个功能很有3D的效果,看起来感觉很不错但是,它到底是如何实现的呢? 今儿,我就来和大家一起剖析一下它的实现细节WP8中磁贴动态翻转功能细节:(1)将当

    2022年4月13日
    63
  • goland激活码【2021免费激活】

    (goland激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月28日
    983
  • Edge breaker记录

    Edge breaker记录和代码相关性非常强的是这篇文章,几乎就是伪代码了:http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.58.7918&rep=rep1&type=pdf一、Compression阶段命令参数为umbrellla_times4.offB第一个参数就是输入网格,目前支持OFF和OVTable两种文件格式,这里…

    2022年6月1日
    37
  • Linux开机启动nginx「建议收藏」

    Linux开机启动nginx「建议收藏」在/etc/init.d下创建文件nginxvim/etc/init.d/nginxnginx官方脚本修改配置nginx=”/usr/local/nginx/sbin/nginx”#修改成nginx执行程序的路径NGINX_CONF_FILE=”/usr/local/nginx/conf/nginx.conf”#修改成nginx.conf文件的路径设置文件的执行权限chmoda+x/etc/init.d/nginx可以通过下面指令控制启动停止/etc/init..

    2022年10月6日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号