go-iconv

小1彤彤 · · 2809 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

https://my.oschina.net/u/659405/blog/342406
windows go amd64 libiconv 缺失报错问题
windows amd64 的go环境使用的gcc环境带的libiconv库不匹配,使用iconv-go库的时候报错,就自己编译了一个
步骤如下,下载libiconv源代码http://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.14.tar.gz
安装msys64
http://blog.csdn.net/akof1314/article/details/17842215
软件安装
下载msys2-x86_64软件包,双击安装到某根目录下,比如D:\msys64。不要用空格目录
打开运行mingw64.exe
pacman是MSYS2自带的软件管理工具:
可通过修改msys64\etc\pacman.d下的三个文件修改软件源,可供选择的有:中国科学技术开源软件镜像、北京理工大学镜像、日本北陆先端科学技术大学院大学SourceForge镜像、The UK Mirror Service Sorceforge mirror等。
下载后的软件包默认存放目录msys64\var\cache\pacman\pkg;若命令行下载速度较慢,可以到到软件源网站使用下载工具下载相应的软件包,然后拷贝到此目录,接着使用命令行进行安装。
运行msys2_shell.bat: pacman -Sy 更新本地包数据
升级核心包:pacman -S --needed filesystem msys2-runtime bash libreadline libiconv libarchive libgpgme libcurl pacman ncurses libintl, 之后需要关闭所有 MSYS2 shell,然后运行 autorebase.bat
升级其他包:pacman -Su
常用命令: 
pacman -Q查看已安装的软件包
pacman -S -g查看软件组
pacman -Q -g base-devel查看软件组包含的软件
pacman -Q -l vim查询软件包的内容
pacman -Q -s nettle查询软件所在的包
查看工具帮助:pacman -h ;pacman -S -h

建议通过安装软件组来安装工具链
应为是go64所以安装gcc 64
pacman -S mingw-w64-x86_64-toolchain
p
            pacman -S mingw-w64-i686-toolchain
p
            pacman -S base-devel
p
            pacman -S vim


打开msys,gcc -v测试保证是默认gcc版本
然后进入libiconv的解压目录
./configure
make
在lib/.libs目录存在生成目标文件
拷贝libiconv.dll.a(文件可以不用)以及libiconv-2.dll至iconv.h相关目录(GOPATH=D:\WebstormProjects\testgo\clib目录下)
go get https://github.com/qiniu/iconv
修改源码D:\WebstormProjects\testgo\src\github.com\qiniu\iconv\iconv.go
添加
//#cgo CFLAGS:  -ID:/WebstormProjects/testgo/clib     //-I表示搜索头文件目录
//#cgo LDFLAGS: -LD:/WebstormProjects/testgo/clib -llibiconv-2  //-L表示搜索动态库1目录
编译输出目录,记得运行时加上
set path=D:\WebstormProjects\testgo\clib;%path%
不然会报错找不到dll

D:\Program\msys64\mingw64\include下有这个头文件和库


 


有疑问加站长微信联系(非本文作者)

本文来自:开源中国博客

感谢作者:小1彤彤

查看原文:go-iconv

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2809 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传