go语言基础博客 go语言基础教程

组件分享之后端组件——基于Go语言的HTML和CSS网站生成器Hugo近期正在探索前端、后端、系统端各类常用组件与工具,对其一些常见的组件进行再次整理一下,形成标准化组件专题 , 后续该专题将包含各类语言中的一些常用组件 。欢迎大家进行持续关注 。
本节分享一个基于Go语言的HTML和CSS网站生成器 hugo ,它针对速度、易用性和可配置性进行了优化 。Hugo 获取一个包含内容和模板的目录,并将它们呈现为一个完整的 HTML 网站 。Hugo 依赖于 Markdown 文件和元数据的前端,你可以从任何目录运行 Hugo 。这适用于您没有特权帐户的共享主机和其他系统 。例如我们日常编写一些博客文章,进行快速生成一套静态页面进行分享时可以使用它来进行生成一套静态页面作为我们的博客部署基础 。
【go语言基础博客 go语言基础教程】它支持大量的主题模板,我们可以通过进行选择相关的主题使用,有兴趣的小伙伴可以进行深入研究一下
学习区块链开发是学习go语言、hyper ledger fabric比较好、还是以太坊智能合约比较好或者公链开发?Fabric区块链开发详解go语言基础博客 , 本课程面向初学者go语言基础博客,内容即包含Hyperledger Fabric的身份证书与MSP服务、权限策略、通道配置与启动、链码通信接口等核心概念go语言基础博客,也包含Fabric网络设计、链码与应用开发的操作实践,是学习Fabric区块链开发的最佳选择 。
给你个免费区块链博客看看 。
如何看待go语言泛型的最新设计?Go 由于不支持泛型而臭名昭著go语言基础博客 , 但最近,泛型已接近成为现实 。Go 团队实施了一个看起来比较稳定go语言基础博客的设计草案,并且正以源到源翻译器原型的形式获得关注 。本文讲述的是泛型的最新设计,以及如何自己尝试泛型 。
例子
FIFO Stack
假设你要创建一个先进先出堆栈 。没有泛型 , 你可能会这样实现:
type Stack []interface{}func (s Stack) Peek() interface{} {
return s[len(s)-1]
}
func (s *Stack) Pop() {
*s = (*s)[:
len(*s)-1]
}
func (s *Stack) Push(value interface{}) {
*s =
append(*s, value)
}
但是,这里存在一个问题:每当你 Peek 项时,都必须使用类型断言将其从 interface{} 转换为你需要的类型 。如果你的堆栈是 *MyObject 的堆栈 , 则意味着很多 s.Peek().(*MyObject)这样的代码 。这不仅让人眼花缭乱,而且还可能引发错误 。比如忘记 * 怎么办go语言基础博客?或者如果您输入错误的类型怎么办go语言基础博客?s.Push(MyObject{})` 可以顺利编译,而且你可能不会发现到自己的错误 , 直到它影响到你的整个服务为止 。
通常,使用 interface{} 是相对危险的 。使用更多受限制的类型总是更安全 , 因为可以在编译时而不是运行时发现问题 。
泛型通过允许类型具有类型参数来解决此问题:
type Stack(type T) []Tfunc (s Stack(T)) Peek() T {
return s[len(s)-1]
}
func (s *Stack(T)) Pop() {
*s = (*s)[:
len(*s)-1]
}
func (s *Stack(T)) Push(value T) {
*s =
append(*s, value)
}
这会向 Stack 添加一个类型参数,从而完全不需要 interface{} 。现在,当你使用 Peek() 时,返回的值已经是原始类型,并且没有机会返回错误的值类型 。这种方式更安全,更容易使用 。(译注:就是看起来更丑陋 , ^-^)
此外,泛型代码通常更易于编译器优化 , 从而获得更好的性能(以二进制大小为代价) 。如果我们对上面的非泛型代码和泛型代码进行基准测试,我们可以看到区别:
type MyObject struct {
X
int
}
var sink MyObjectfunc BenchmarkGo1(b *testing.B) {
for i := 0; ib.N; i{
var s Stack
s.Push(MyObject{})
s.Push(MyObject{})
s.Pop()
sink = s.Peek().(MyObject)
}
}
func BenchmarkGo2(b *testing.B) {
for i := 0; ib.N; i{
var s Stack(MyObject)
s.Push(MyObject{})
s.Push(MyObject{})
s.Pop()
sink = s.Peek()
}
}
结果:
BenchmarkGo1BenchmarkGo1-161283752887.0 ns/op48 B/op2 allocs/opBenchmarkGo2BenchmarkGo2-162840647941.9 ns/op24 B/op2 allocs/op
在这种情况下,我们分配更少的内存,同时泛型的速度是非泛型的两倍 。
合约(Contracts)
上面的堆栈示例适用于任何类型 。但是,在许多情况下,你需要编写仅适用于具有某些特征的类型的代码 。例如 , 你可能希望堆栈要求类型实现 String() 函数
go语言基础博客的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于go语言基础教程、go语言基础博客的信息别忘了在本站进行查找喔 。

    推荐阅读