设为首页 收藏本站
查看: 975|回复: 0

[经验分享] Golang fmt包使用小技巧

[复制链接]

尚未签到

发表于 2018-9-20 11:35:02 | 显示全部楼层 |阅读模式
Golang fmt包使用小技巧

Go语言fmt包实现了类似于C语言printf和scanf的格式化I/O函数。格式谓词用%前导,go语言中称为”verb”。verbs从C派生而来,但更简单。以下是在开发过程中用过的一些实用小技巧。



一 用十六进制打印数组或切片,每个byte两个字符,每两个字符用空格间隔



该功能在通信协议类的开发中使用频繁,向终端设备发送的控制命令及应答信息需要打印在日志中,或调试时打印收发数据,通常这些是十六进制格式的,并且需要每两个字符之间用空格间隔。

  

    data := []byte{1, 2, 4, 88, 99, 120, 245, 241}  

  fmt.Printf("% X\r\n", data)
  

  fmt.Printf("% x\r\n", data)
  

  

输出结果:


  

01 02 04 58 63 78 F5 F1  

  

01 02 04 58 63 78 f5 f1  




二 打印结构体时输出字段名




  

typePersionstruct {  

  Name string
  

  Age int
  

  ID string
  

  
}
  

  p := Persion{"xiaoming", 12, "1302222222"}
  

  fmt.Printf("%v\r\n", p)
  

  fmt.Printf("%+v\r\n", p)
  

  

输出结果:

  

{xiaoming 12 1302222222}  

  
{Name:xiaoming Age:
12>  

默认的%v打印只有值,%+v可以增加结构体字段名






三 重复使用操作数



经常会遇到同一个值在格式化打印内容中出现多次的情况,go语言提供了重复使用操作数的机制。

  

    x := int64(0xdeadbeef)  

  fmt.Printf("%d %[1]x %#[1]x %#[1]X\r\n", x)
  

  

输出结果

  

3735928559 deadbeef 0xdeadbeef 0XDEADBEEF  


四 打印不同进制的数值时增加前缀
  

    x = 200  

  px := &x
  

  fmt.Printf("%#d %#[1]o %#[1]b %#[1]x %#[1]X %p %#[2]p\r\n", x,px)
  

  输出结果
  

200 0310 11001000 0xc8 0XC8 0xc042040228 c042040228  

  #为8进制数值增加0;为十六进制%#x增加0x;为十六进制%#X增加0X;%#p抑制了0x;
  #对十进制d和二进制b不起作用。

五 打印复杂结构体
开发过程中经常用到复杂的结构体,结构体中带有层层嵌套结构,并且字段是结构体的指针,对这样的字段printf打印的是指针的值,这不是我们需要的。

例如有如下在开发中用到的结构体,avro描述

  

{  

  

"type": "record",  

  

"name": "intersection",  

  

"fields" : [  

  
{
"name": "inter_id", "type": "int"},  

  
{
"name": "name", "type": "string"},  

  
{
"name": "shape", "type": "int"},  

  
{
"name": "primary_unit", "type": "int"},  

  
{
"name": "unit_two", "type": "int"},  

  
{
"name": "unit_three", "type": "int"},  

  
{
"name": "longitude", "type": "double"},  

  
{
"name": "latitude", "type": "double"},  

  
{
"name": "entrances", "type": {"type": "array", "name": "", "items": {  

  

"type": "record",  

  

"name": "entrance",  

  

"fields" : [  

  
{
"name": "en_id", "type": "int"},  

  
{
"name": "name", "type": "string"},  

  
{
"name": "degree", "type": "int"},  

  
{
"name": "orientation", "type": "int"},  

  
{
"name": "side_walks", "type": {"type": "array", "name": "", "items": {  

  

"type": "record",  

  

"name": "side_walk",  

  

"fields" : [  

  
{
"name": "id", "type": "int"}  

  
]
  

  
}}},
  

  
{
"name": "motor_lanes", "type": {"type": "array", "name": "", "items": {  

  

"type": "record",  

  

"name": "motor_lane",  

  

"fields" : [  

  
{
"name": "id", "type": "int"},  

  
{
"name": "lane_flow", "type": "int"},  

  
{
"name": "has_waiting_area", "type": "boolean"}  

  
]
  

  
}}},
  

  
{
"name": "non_motor_lanes", "type": {"type": "array", "name": "", "items": {  

  

"type": "record",  

  

"name": "non_motor_lane",  

  

"fields" : [  

  
{
"name": "id", "type": "int"},  

  
{
"name": "lane_flow", "type": "int"}  

  
]
  

  
}}},
  

  
{
"name": "exit_lanes", "type": {"type": "array", "name": "", "items": {  

  

"type": "record",  

  

"name": "exit_lane",  

  

"fields" : [  

  
{
"name": "id", "type": "int"},  

  
{
"name": "lane_flow", "type": "int"}  

  
]
  

  
}}},
  

  
{
"name": "exit_non_motor_lanes", "type": {"type": "array", "name": "", "items": "non_motor_lane"}}  

  
]
  

  
}}}
  

  
]
  

  
}
  



生成的代码如下(部分省略)



  

typeIntersectionstruct {  

  InterID int32`json:"inter_id" xorm:"pk notnull"`
  

  Name string`json:"name"`
  

  Shape int32`json:"shape"`
  

  PrimaryUnit int32`json:"primary_unit"`
  

  UnitTwo int32`json:"unit_two"`
  

  UnitThree int32`json:"unit_three"`
  

  Longitude float64`json:"longitude"`
  

  Latitude float64`json:"latitude"`
  

  Entrances []*Entrance `json:"entrances" xorm:"-"`
  

  
}
  

  

  
typeEntrancestruct {
  

  InterID int32`json:"-" xorm:"pk notnull"`
  

  EnID int32`json:"en_id" xorm:"pk notnull"`
  

  Name string`json:"name"`
  

  Degree int32`json:"degree"`
  

  Orientation int32`json:"orientation"`
  

  SideWalks []*SideWalk `json:"side_walks" xorm:"-"`
  

  MotorLanes []*MotorLane `json:"motor_lanes" xorm:"-"`
  

  NonMotorLanes []*NonMotorLane `json:"non_motor_lanes" xorm:"-"`
  

  ExitLanes []*ExitLane `json:"exit_lanes" xorm:"-"`
  

  ExitNonMotorLanes []*NonMotorLaneExit `json:"exit_non_motor_lanes" xorm:"-"`
  

  
}
  

  

如果进行打印,输出只有一层结构,嵌套的部分只有指针值。



要打印完整的结果,有两种方法:一种是用反射实现自定义的print进行深度打印;另外一种是利用json包。

  

    bData, _ := json.MarshalIndent(dbConf, "", "\t")  

  fmt.Println(string(bData))
  

  


六 终端程序打印等待



经常会写些工具类软件,如果耗时较长,增加等待输出会使提高用户使用体验。以下引用《Go语言程序设计》的例子。

  

package main  

  

  
import (
  

  "fmt"
  

  "time"
  

  
)
  

  

  
func main() {
  

  go spinner(100 * time.Millisecond)
  

  const n = 45
  

  fibN := fib(n) //slow
  

  fmt.Printf("\rFibonacci(%d)=%d\n", n, fibN)
  

  
}
  

  

  
func spinner(delay time.Duration) {
  

  for {
  

  for _, r := range `-\|/` {
  

  fmt.Printf("\r%c", r)
  

  time.Sleep(delay)
  

  }
  

  }
  

  
}
  

  

  
func fib(x int) int {
  

  if x < 2 {
  

  return x
  

  }
  

  

  return fib(x-1) + fib(x-2)
  

  
}
  

  

斐波那契函数计算较慢,开启goroutine进行打印等待符号,计算完成后退出。







































运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-598819-1-1.html 上篇帖子: golang解析json配置文件 下篇帖子: golang json 编码解码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表