Golang fmt包使用小技巧
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)
输出结果:
F5 F1
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 }
{Name:xiaoming Age: ID:}
默认的%v打印只有值,%+v可以增加结构体字段名
三 重复使用操作数
经常会遇到同一个值在格式化打印内容中出现多次的情况,go语言提供了重复使用操作数的机制。
x := int64(0xdeadbeef)
fmt.Printf("%d %[1]x %#[1]x %#[1]X\r\n", x)
输出结果
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)
输出结果
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进行打印等待符号,计算完成后退出。
Golang fmt包使用小技巧的更多相关文章
- Golang的防坑小技巧
Golang的防坑小技巧 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 作为一名小白,在之前没有接触到编程的小伙伴,难免会踩到一些坑,比如说刚刚入门的时候你需要安装环境,学习Gol ...
- golang fmt包
fmt fmt包实现了类似C语言printf和scanf的格式化I/O.主要分为向外输出内容和获取输入内容两大部分. 向外输出 标准库fmt提供了以下几种输出相关函数. Print Print系列函数 ...
- R包的小技巧
通常我们都是直接使用library(pkg_name) 的形式加载R包,在同一台机器上面,对于我们而言,这个包所在的路径一定是在.libPaths() 路面的,但是对于其他用户而言,这个路径可能不存 ...
- golang格式化输出-fmt包用法详解
golang格式化输出-fmt包用法详解 注意:我在这里给出golang查询关于包的使用的地址:https://godoc.org 声明: 此片文章并非原创,大多数内容都是来自:https:// ...
- [转]Golang 中使用 JSON 的小技巧
taowen是json-iterator的作者. 序列化和反序列化需要处理JSON和struct的关系,其中会用到一些技巧. 原文 Golang 中使用 JSON 的小技巧是他的经验之谈,介绍了一些s ...
- SpringBoot小技巧:Jar包换War包
SpringBoot小技巧:Jar包换War包 情景 我们都知道springBoot中已经内置了tomcat,是不需要我们额外的配置tomcat服务器的,但是有时这也可能是我们的一个瓶颈,因为如果我们 ...
- SpringBoot小技巧:修改java可执行jar包内容
SpringBoot小技巧:修改java可执行jar包内容 情景描述 在生产环境中,有时候我们发现了个小bug,开发迅速修改代码后,很多时候我们不得不重新发布一个新的可执行jar包上去替换掉.但是这样 ...
- 『GoLang』fmt包的使用
目录 1. fmt 包初识 2. 格式化 verb 应用 2.1 通用 2.2 布尔值 2.3 整数 2.4 浮点数与复数 2.5 字符串和 []byte 2.6 指针 2.7 其他 flag 2.8 ...
- IDEA的小技巧:1.Java代码不被识别2.目录下创建的文件夹所显示样式不是文件夹,而是"包"图标样式的问题
在Idea上面一个正常的代码结构是这个样子的,但是有的时候,比如说当我们直接在一个文件夹中随便的创建的时候就会出现一些问题,比如说想让某个地方为代码目录,某个地方为资源目录的时候,直接的创建目录是不成 ...
随机推荐
- 数据库—Mysql
今天跟大家来聊聊Mysql,首先介绍一下它的历史: Mysql是一个关系型数据库管理系统,最先由瑞典的MySQL AB公司开发,后来被sun公司收购,后因sun公司又被Oracle公司收购,致使MyS ...
- 初学者易上手的SSH-整合
许久没更新博客了! spring还有一章aop(面向切面),我就没讲述了,你们可以去看下代理模式. 那么我们开始整合:struts2 2.3.4 ,hibernate 5.2.10 ,spring ...
- 深入讲解HashMap原理
1. HashMap概述: HashMap是基于哈希表的Map接口的非同步实现.此实现提供所有可选的映射操作,并允许使用null值和null键.此类不保证映射的顺序,特别是它不保证该顺序恒久不变 ...
- Nodejs的运行原理-科普篇
前言 Nodejs目前处境稍显尴尬,很多语言都已经拥有异步非阻塞的能力.阿里的思路是比较合适的,但是必须要注意,绝对不能让node做太多的业务逻辑,他只适合接收生成好的数据,然后或渲染后,或直接发送到 ...
- 再学习之Spring(面向切面编程)
一.概念 1.理论 把横切关注点和业务逻辑相分离是面向切面编程所要解决的问题.如果要重用通用功能的话,最常见的面向对象技术是继承(inheritance)或 组成(delegation).但是,如果在 ...
- 基于跳跃表的 ConcurrentSkipListMap 内部实现(Java 8)
我们知道 HashMap 是一种键值对形式的数据存储容器,但是它有一个缺点是,元素内部无序.由于它内部根据键的 hash 值取模表容量来得到元素的存储位置,所以整体上说 HashMap 是无序的一种容 ...
- Java开发小技巧(四):配置文件敏感信息处理
前言 不知道在上一篇文章中你有没有发现,jdbc.properties中的数据库密码配置是这样写的: jdbc.password=5EF28C5A9A0CE86C2D231A526ED5B388 其实 ...
- Git~GitLab当它是一个CI工具时
CI我们都知道,它是持续集成的意思,主要可以自动处理包括编译,测试,发布等一系列的过程,而GitLab也同样包含了这些功能,我们可以通过pipeline很容易的实现一个软件从编译,测试,发布的自动化过 ...
- java多线程编程核心技术——第五章总结
定时器Timer的使用 1.1方法schedule(TimerTask task, Date time)的测试 1.2方法schedule(TimerTask task, Date firstTime ...
- JAVA入门[4]-IntelliJ IDEA配置Tomcat
一.新建Maven Module测试站点 \ 二.配置Application Server 1.File->Setting,打开设置面板: 2.选中Application Servers,点击+ ...