Golang丰富的I/O----用N种Hello World展示
Golang丰富的I/O----用N种Hello World展示
Golang是我目前用过的最好的语言,一接触便深深地喜爱,不断实践,喜爱之情日久弥深。原因之一便是简单、强大、易用。编程操作涉及频率最高的莫过于I/O,标准io包提供的两个接口(io.Reader和io.Writer)对I/O进行了伟大的统一抽象,将简单、强大、易用的特点体现地淋漓尽致。两个接口的定义如下:
typeReaderinterface {
Read(p []byte) (n int, err error)
}
typeWriterinterface {
Write(p []byte) (n int, err error)
}
标准库中的多个包实现了这两个接口,从而提供了丰富而强大的I/O功能。下面用N种输出“Hello,world!”来感受下。
package main
import (
"bufio"
"bytes"
"fmt"
"io"
"log"
"mime/quotedprintable"
"os"
"strings"
"text/tabwriter"
)
func main() {
//1
fmt.Println("hello, world!")
//2
io.WriteString(os.Stdout, "Hello, World!\r\n")
os.Stdout.WriteString("Hello, World!\r\n")
//3
w := bufio.NewWriter(os.Stdout)
fmt.Fprint(w, "Hello, ")
fmt.Fprint(w, "world!\r\n")
w.Flush() // Don't forget to flush!
fmt.Fprint(os.Stdout, "hello, world!\r\n")
//4
r := strings.NewReader("hello, world!\r\n")
if _, err := io.Copy(os.Stdout, r); err != nil {
log.Fatal(err)
}
r1 := strings.NewReader("hello, world!\r\n")
buf := make([]byte, 8)
// buf is used here...
if _, err := io.CopyBuffer(os.Stdout, r1, buf); err != nil {
log.Fatal(err)
}
r2 := strings.NewReader("hello, world!\r\n")
//buf := make([]byte, 8)
if _, err := io.CopyN(os.Stdout, r2, int64(r2.Len())); err != nil {
log.Fatal(err)
}
//5
var b bytes.Buffer // A Buffer needs no initialization.
b.Write([]byte("Hello, "))
fmt.Fprintf(&b, "world!\r\n")
b.WriteTo(os.Stdout)
// Output: Hello world!
//6
wTab := tabwriter.NewWriter(os.Stdout, 1, 1, 1, ' ', tabwriter.AlignRight)
defer wTab.Flush()
wTab.Write([]byte("Hello, world!\r\n"))
//7
wQuote := quotedprintable.NewWriter(os.Stdout)
wQuote.Write([]byte("Hello, world!\r\n"))
wQuote.Write([]byte("These symbols will be escaped: = \t"))
wQuote.Close()
wQuote.Write([]byte("\r\n"))
//8
log := log.New(os.Stdout, "", 0)
log.Println("Hello, world!")
}
以上代码均来自go源码,编译运行输出如下:
hello, world! Hello, World! Hello, World! Hello, world! hello, world! hello, world! hello, world! hello, world! Hello, world! Hello, world! Hello, world! These symbols will be escaped: =3D =09 Hello, world!
第一种很常见,
fmt.Println("hello, world!")
各种go语言书籍中均展示了该种形式的Hello World。
第二种是io包和os包提供的WriteString函数或方法,对io.Writer进行了封装。
第三种是fmt包提供的Fprint函数,与第一种类似。从go源码可以看出Print和Println分别是对Fprint和Fprintln函数的封装。
func Print(a ...interface{}) (n int, err error) {
return Fprint(os.Stdout, a...)
}
func Println(a ...interface{}) (n int, err error) {
return Fprintln(os.Stdout, a...)
}
第四种是io包提供的三个copy函数:io.Copy、io.CopyBuffer和io.CopyN。这三个函数是对copyBuffer函数的封装,
// copyBuffer is the actual implementation of Copy and CopyBuffer. // if buf is nil, one is allocated. func copyBuffer(dst Writer, src Reader, buf []byte) (written int64, err error)
copyBuffer函数借助buf缓冲从Reader读取数据然后写入到Writer中。
第五种是bytes包提供的方法,对Writer方法进行了封装。
// WriteTo writes data to w until the buffer is drained or an error occurs. // The return value n is the number of bytes written; it always fits into an // int, but it is int64 to match the io.WriterTo interface. Any error // encountered during the write is also returned. func (b *Buffer) WriteTo(w io.Writer) (n int64, err error)
第六种是text包实现的io.Writer接口,text/tabwriter包可以实现文本列对齐输出。
// Write writes buf to the writer b.
// The only errors returned are ones encountered
// while writing to the underlying output stream.
//
func (b *Writer) Write(buf []byte) (n int, err error) {
第七种是"mime/quotedprintable"包实现的io.Writer接口。
// Write encodes p using quoted-printable encoding and writes it to the
// underlying io.Writer. It limits line length to 76 characters. The encoded
// bytes are not necessarily flushed until the Writer is closed.
func (w *Writer) Write(p []byte) (n int, err error) {
第八种也是比较常用的,由log包提供的。
这么多种Hello
World的写法可能不是全面的,但这是我见过的写法最多的一种语言。
Golang丰富的I/O----用N种Hello World展示的更多相关文章
- golang中发送http请求的几种常见情况
整理一下golang中各种http的发送方式 方式一 使用http.Newrequest 先生成http.client -> 再生成 http.request -> 之后提交请求:clie ...
- golang中获取字符串长度的几种方法
一.获取字符串长度的几种方法 - 使用 bytes.Count() 统计 - 使用 strings.Count() 统计 - 将字符串转换为 []rune 后调用 len 函数进行统计 ...
- golang的序列化与反序列化的几种方式
golang用来序列化的模块有很多,我们来介绍3个. json 首先登场的是json,这个几乎毋庸置疑. 序列化 package main import ( "encoding/json&q ...
- Golang简单写文件操作的四种方法
package main import ( "bufio" //缓存IO "fmt" "io" "io/ioutil" ...
- Golang- import 导入包的几种方式:点,别名与下划线
包的导入语法 在写Go代码的时候经常用到import这个命令用来导入包文件,看到的方式参考如下: import( "fmt" ) 然后在代码里面可以通过如下的方式调用 fmt.Pr ...
- golang 开发 Struct 转换成 map 两种方式比较
原文链接:https://www.jianshu.com/p/81c4304f6d1b 最近做Go开发的时候接触到了一个新的orm第三方框架gorose,在使用的过程中,发现没有类似beego进行直接 ...
- 解决 golang unrecognized import path "golang.org/x" 之类错误的一种尝试
如果使用的开发IDE是goland,那么 打开 FILE -> setting -> Go Modules 选项 ,在proxy 选项上填写 "https://goproxy.i ...
- golang struct结构体初始化的几种方式
type User struct { Id int `json:"id" orm:"auto"` // 用户名 Username string `json:&q ...
- [goa]golang微服务框架学习(三)-- 使用swagger-ui展示API
既然goa框架自动生成啦swagger-json文件,那么如何用swagger-ui展示出来呢? 这里分三步: 1.下载swagger-ui的web代码 2.添加swagger.json 和 swag ...
随机推荐
- 一个非常好用的图片切割工具(c# winform开发) 附源码
本人业余时间开发了一个图片切割工具,非常好用,也很灵活! 特别对大型图片切割,更能体现出该软件的优势! 开发工具为winform,源码下载地址:http://download.csdn.net/dow ...
- Code Kata:超级偶数数列 javascript实现
超级偶数(SuperEven)是指每一位都是偶数的正整数,例如: 0,2,4,6,8,20,22,24,26,28,40,...,88,200,202,... 要求写一个函数,输入项数n,返回数列第n ...
- log4net使用注意事项
1配置Log4net Log4net的配置文件有几种使用方式,这里将配置log4net的部分独立出来,即关于log4net的配置独立成文件log4net.config. 1)写入Mysql log4n ...
- 实践作业1:测试管理工具实践 Day4
由小组吴辉同学和王俊杰同学负责撰写使用手册,详细记录了环境配置完整过程,以及从软件登陆开始,创建一个测试计划,创建新版本,创建测试用例集,分配测试用例到测试计划,关联到测试用例这一系列完整过程. 刘思 ...
- CCF-201503-3-节日
问题描述 试题编号: 201503-3 试题名称: 节日 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 有一类节日的日期并不是固定的,而是以"a月的第b个星期c&q ...
- eclipse和myeclipse中将项目发布到tomcat的root目录
1.在eclipse中,将项目直接部署在tomcat的root目录中,这样便可以直接ip:port访问项目: 项目右键->属性->web project settings 添加之后直接启动 ...
- ngixn配置
nginx 配置入门 之前的nginx配置是对nginx配置文件的具体含义进行讲解,不过对于nginx的新手可能一头雾水. 今天看到个文档不错,翻译过来分享给大家,可以让新手更详细地了解nginx配置 ...
- And【sql语句之为何用and一个字段两个值得不到表中的数据】
一.[一个表的一个字段的多个条件用and连接] 用and是查不到值的, and是多个条件同时成立, 也就是一个字段是不能同时等于两个值的. '; 二[相同两个表的两个相同字段的查询用and连接] '; ...
- Arrays.asList()生成的List抛UnsupportedOperationException分析
一.背景:使用工具类 Arrays.asList()把数组转换成集合时,使用其修改集合相关的方 法,它的 add/remove/clear 方法会抛出 UnsupportedOperationExce ...
- 基于 Vue.js 的移动端组件库mint-ui实现无限滚动加载更多
通过多次爬坑,发现了这些监听滚动来加载更多的组件的共同点, 因为这些加载更多的方法是绑定在需要加载更多的内容的元素上的, 所以是进入页面则直接触发一次,当监听到滚动事件之后,继续加载更多, 所以对于无 ...