golang
已收录文章:14262篇
-
中介者模式通过引入中心化中介者减少对象间直接依赖,降低耦合度,提升可维护性与扩展性;在Golang中通过定义中介者和组件接口实现,组件通过中介者通信而非直接交互;优势为解耦,局限是中介者可能成为承担过多职责的“上帝对象”;可通过划分职责、下放业务逻辑或使用多个细粒度中介者避免该问题;典型应用场景包括GUI组件协调、聊天室消息传递、工作流引擎任务调度及事件驱动架构中的处理器协调。434 收藏
-
Golang使用crypto/tls包实现安全通信,通过生成自签名证书(如openssl命令)用于测试,配置tls.Config加载证书并监听TLS连接;客户端需正确配置tls.Config并避免InsecureSkipVerify生产使用;可通过设置MinVersion/MaxVersion强制协议版本,监控证书有效期或用Let'sEncrypt自动管理证书;启用HTTP/2只需支持TLS1.2以上且双方兼容,net/http库自动协商。434 收藏
-
Go语言构建缓存通过哈希校验源码、依赖、编译器版本等输入生成唯一标识,命中缓存时直接复用编译结果,避免重复编译,显著提升编译效率。434 收藏
-
Go的time包用于处理时间日期,time.Now()获取当前时间,可提取年月日等信息;2.时间格式化使用固定参考时间“MonJan215:04:05MST2006”对应占位符,Parse解析字符串时间,ParseInLocation支持指定时区;3.可通过Sub计算时间差,Add进行时间加减,Before、Equal比较时间先后;4.Sleep实现程序暂停,Ticker周期执行任务,After用于超时控制。434 收藏
-
问题内容接触go没多久,在网上看了看tcp聊天服务器,大概实现就是:遇到有用户连接就直接开一个goruntine,这样的性能是否算高呢?假设只是一台4核8gb机器。大概能启动多少goruntine?怎么样能充分433 收藏
-
etcd clientv3 客户端 etcd 客户端 clientv3 接入的示例将会以 Go 客户端为主,读者需要准备好基本的开发环境。 首先是 etcd clientv3 的初始化,我们根据指定的 etcd 节点,建立客户端与 etcd 集群的连接433 收藏