golang中的标准库log】的更多相关文章

Go语言内置的log包实现了简单的日志服务.本文介绍了标准库log的基本使用. 使用Logger log包定义了Logger类型,该类型提供了一些格式化输出的方法.本包也提供了一个预定义的"标准"logger,可以通过调用函数Print系列(Print|Printf|Println).Fatal系列(Fatal|Fatalf|Fatalln).和Panic系列(Panic|Panicf|Panicln)来使用,比自行创建一个logger对象更容易使用. 例如,我们可以像下面的代码一样直…
数据格式介绍 是系统中数据交互不可缺少的内容 这里主要介绍JSON.XML.MSGPack JSON json是完全独立于语言的文本格式,是k-v的形式 name:zs 应用场景:前后端交互,系统间数据交互 json使用go语言内置的encoding/json 标准库 编码json使用json.Marshal()函数可以对一组数据进行JSON格式的编码 func Marshal(v interface{}) ([]byte, error) 示例过结构体生成json 点击查看代码 type Per…
在 Go http包的Server中,每一个请求在都有一个对应的 goroutine 去处理.请求处理函数通常会启动额外的 goroutine 用来访问后端服务,比如数据库和RPC服务.用来处理一个请求的 goroutine 通常需要访问一些与请求特定的数据,比如终端用户的身份认证信息.验证相关的token.请求的截止时间. 当一个请求被取消或超时时,所有用来处理该请求的 goroutine 都应该迅速退出,然后系统才能释放这些 goroutine 占用的资源. 为什么需要Context 基本示…
简介 golang 中的创建一个新的 goroutine , 并不会返回像c语言类似的pid,所有我们不能从外部杀死某个goroutine,所有我就得让它自己结束,之前我们用 channel + select 的方式,来解决这个问题,但是有些场景实现起来比较麻烦,例如由一个请求衍生出的各个 goroutine 之间需要满足一定的约束关系,以实现一些诸如有效期,中止routine树,传递请求全局变量之类的功能.于是google 就为我们提供一个解决方案,开源了 context 包.使用 conte…
Go语言内置的net/http包十分的优秀,提供了HTTP客户端和服务端的实现. http客户端 基本的HTTP/HTTPS请求 Get.Head.Post和PostForm函数发出HTTP/HTTPS请求. resp, err := http.Get("http://5lmh.com/") ... resp, err := http.Post("http://5lmh.com/upload", "image/jpeg", &buf) .…
参考链接 输入输出的底层原理 终端其实是一个文件,相关实例如下: os.Stdin:标准输入的文件实例,类型为*File os.Stdout:标准输出的文件实例,类型为*File os.Stderr:标准错误输出的文件实例,类型为*File 以文件的方式操作终端: func main() { var buf [16]byte os.Stdin.Read(buf[:]) fmt.Println(string(buf[:])) } 文件操作相关API func Create(name string)…
html/template包实现了数据驱动的模板,用于生成可对抗代码注入的安全HTML输出.它提供了和text/template包相同的接口,Go语言中输出HTML的场景都应使用text/template包. 模板 在基于MVC的Web架构中,我们通常需要在后端渲染一些数据到HTML文件中,从而实现动态的网页效果 模板示例 通过将模板应用于一个数据结构(即该数据结构作为模板的参数)来执行,来获得输出.模板中的注释引用数据接口的元素(一般如结构体的字段或者字典的键)来控制执行过程和获取需要呈现的值…
时间类型 time.Time类型表示时间.我们可以通过time.Now()函数获取当前的时间对象,然后获取时间对象的年月日时分秒等信息.示例代码如下: func main() { current := time.Now() fmt.Println(current) // 2021-11-26 16:13:54.3960877 +0800 CST m=+0.011114601 // 将时间类型转换成字符串类型 strCurrent := current.Format("2006-01-02 15:…
反射 反射是指程序在运行期对程序本身访问和修改的能力 变量的内在机制 变量包含类型信息和值信息 var arr [10]int arr[0] = 10 类型信息:是静态的元信息,是预先定义好的 值信息:是程序运行过程中动态改变的 反射的使用 reflect包封装了反射相关的方法 获取类型信息:reflect.TypeOf,是静态的 获取值信息:reflect.ValueOf,是动态的 空接口和反射 反射可以在运行时动态获取程序的各种详细信息 反射获取interface类型信息 反射获取inter…
strconv 包 strconv包实现了基本数据类型与其字符串表示的转换,主要有以下常用函数: Atoi().Itia().parse系列.format系列.append系列. string与int类型转换 这一组函数是我们平时编程中用的最多的. Atoi() Atoi()函数用于将字符串类型的整数转换为int类型,函数签名如下. func Atoi(s string) (i int, err error) 如果传入的字符串参数无法转换为int类型,就会返回错误. func main() {…