安装包100多M,论坛无法上传。只能分享百度盘:https://pan.baidu.com/s/1sgRKdZFcfnfT2FsH2P4luA
提取码:5roq
安装方法:
1.tar -C /usr/local -xzf go$VERSION.$OS-$ARCH.tar.gz
2.export PATH=$PATH:/usr/local/go/bin
提醒:亲测需要开辟swap分区,否则go编译器会因内存不足编译崩溃。由于f1c100s性能有限,编译helloworld耗时很长。
离线
感谢分享,请问怎么移植的呢
哈哈,晕哥没看文字吗?直接把安装包解压到上述目录即可,再添加环境变量。就是这么简单
离线
我还没有下载下来呢,
这个文件 go.tar.gz 里面编译好的 go sdk, 解压缩到f1c100s 的 /usr/local 目录?然后终端调用go 编译?
不用重新编译,解压后,就可以直接用了,因为编译器是编译好的,你可能以为是从源码安装,这一步我已经在我电脑上做了,因为go官方没有提供go的armv5版二进制安装包,所以得自己从源码编译,由于交叉编译有点麻烦,所以在这里只提供了二进制安装包(就是百度盘里的)。我视频演示的是go的命令,go env是查看go的环境参数,go version是查看go编译器版本号。然后写了个helloworld的例子,用go build hello.go 编译生成hello.go的可行性程序。
最近编辑记录 kekemuyu (2019-09-28 12:21:09)
离线
原来如此, 优秀!
请问如何从源码编译成 go.tar.gz ?
有时间我写个详细的教程
离线
感谢感谢!
还有 go 相对于 gcc 有哪些优势?
,应该是go对于c或c++的优势。
搜索一下就知道了,我个人认为最大的特点是“简单,简单,还是tmd简单”。因为简单,代码非常易读,适合多人编写大型程序。被称为云时代的c语言,名副其实。
以下是从网络拷贝
1.开发效率比c和c++快,尤其是涉及到网络开发,go自带的官方库用起来不要太爽。
2.执行性能好。虽然不如 C 和 Java,但通常比原生 Python 应用还是高一个数量级的,适合编写一些瓶颈业务。内存占用也非常省。
3.可直接编译成机器码,不依赖其他库。静态类型语言,但是有动态语言的感觉,静态类型的语言就是可以在编译的时候检查出来隐藏的大多数问题,动态语言的感觉就是有很多的包可以使用,写起来的效率很高。
4.语言层面支持并发,这个就是Go最大的特色,天生的支持并发,可以充分的利用多核,很容易的使用并发
5.内置runtime,支持垃圾回收
6.丰富的标准库,Go目前已经内置了大量的库,特别是网络库非常强大,我最爱的也是这部分。
7.内置强大的工具,Go语言里面内置了很多工具链,最好的应该是gofmt工具,自动化格式化代码,能够让团队review变得如此的简单,代码格式一模一样,想不一样都很困难。
8.跨平台编译,如果你写的Go代码不包含cgo,那么就可以做到window系统编译linux的应用
9.内嵌C支持,go开发者就是C的发明人,所以Go里面也可以直接包含c代码,利用现有的丰富的C库
10.部署简单。Go 编译生成的是一个静态可执行文件,除了 glibc 外没有其他外部依赖。这让部署变得异常方便:目标机器上只需要一个基础的系统和必要的管理、监控工具,完全不需要操心应用所需的各种包、库的依赖关系,大大减轻了维护的负担。这和 Python 有着巨大的区别。由于历史的原因,Python 的部署工具生态相当混乱【比如 setuptools, distutils, pip, buildout 的不同适用场合以及兼容性问题】。官方 PyPI 源又经常出问题,需要搭建私有镜像,而维护这个镜像又要花费不少时间和精力。
11.并发性好。Goroutine 和 channel 使得编写高并发的服务端软件变得相当容易,很多情况下完全不需要考虑锁机制以及由此带来的各种问题。单个 Go 应用也能有效的利用多个 CPU 核,并行执行的性能好。这和 Python 也是天壤之比。多线程和多进程的服务端程序编写起来并不简单,而且由于全局锁 GIL 的原因,多线程的 Python 程序并不能有效利用多核,只能用多进程的方式部署;如果用标准库里的 multiprocessing 包又会对监控和管理造成不少的挑战【我们用的 supervisor 管理进程,对 fork 支持不好】。部署 Python 应用的时候通常是每个 CPU 核部署一个应用,这会造成不少资源的浪费,比如假设某个 Python 应用启动后需要占用 100MB 内存,而服务器有 32 个 CPU 核,那么留一个核给系统、运行 31 个应用副本就要浪费 3GB 的内存资源。
12.良好的语言设计。从学术的角度讲 Go 语言其实非常平庸,不支持许多高级的语言特性;但从工程的角度讲,Go 的设计是非常优秀的:规范足够简单灵活,有其他语言基础的程序员都能迅速上手。更重要的是 Go 自带完善的工具链,大大提高了团队协作的一致性。比如 gofmt 自动排版 Go 代码,很大程度上杜绝了不同人写的代码排版风格不一致的问题。把编辑器配置成在编辑存档的时候自动运行 gofmt,这样在编写代码的时候可以随意摆放位置,存档的时候自动变成正确排版的代码。此外还有 gofix, govet 等非常有用的工具。
最近编辑记录 kekemuyu (2019-09-28 14:11:21)
离线
请问楼主, 有没有 在目标文件系统生成 gcc on arm 的方法,
我看到 buildroot 里面有 BR2_PACKAGE_GCC_TARGET,
但这个选项早已过期了。
我也想像你玩 go 一样, 在板子上执行 gcc
离线
这种玩法有点意思, 要是树莓派我就知道怎么玩, 执行 apt-get install gcc 就行了, 编译我不会。
离线
请问楼主, 有没有 在目标文件系统生成 gcc on arm 的方法,
我看到 buildroot 里面有 BR2_PACKAGE_GCC_TARGET,
但这个选项早已过期了。
我也想像你玩 go 一样, 在板子上执行 gcc
这个我有,ARMv5的gcc,用的musl的库文件。
离线
@Beta_vulgaris 请问哪里可以下载呢?
离线
这个最好用交叉编译......
离线
不过我想问下, go编译出来一般很大. 你们使用tf启动吗?
离线
是的,一般10m左右,需要大容量的spiflash,比如32M的
离线
是的,一般10m左右,需要大容量的spiflash,比如32M的
好吧...淘宝32M一个要7块钱...有点贵
离线
有点尴尬, lichee nano如果用了wifi模块, 就不能插tf卡了
离线
go可以直接跨平台编译出任何目标cpu平台和系统的目标代码吧?
离线
go可以直接跨平台编译出任何目标cpu平台和系统的目标代码吧?
基本上常用的系统和架构都支持
离线
学习了
离线
楼主厉害
有没有兴趣把nodejs支持上
离线