fmt

Scanln用来读取输入数据

示例:

package main                                                                                                                          

import (
"fmt"
"os"
"time"
) func main() {
out := os.Stdout
var d0, d1, d2, d3 string for {
//要读取完整的一行数据, 空格分隔的每个串被一次写入到参数中, 第一个返回值是读取的参数数目,第二个返回值是错误信息
nd, err := fmt.Scanln(&d0, &d1, &d2, &d3)
if err == nil && nd != {
fmt.Fprintf(out, "d0:%s d1:%s d2:%s d3:%s", d0, d1, d2, d3)
fmt.Fprintf(out, "len:%d\n", len(d3))
fmt.Fprintf(out, "num:%d\n", nd)
} else {
fmt.Fprintf(out, "num:%d err:%v\n", nd, err)
}
time.Sleep(time.Second)
}
}

输出:

#1,如果输入的参数个数为3个
a aa aaa
输出:
nd: err:unexpected newline
#2,如果输入的参数个数为4个
a aa aaa aaaa
输出:
d0:a d1:aa d2:aaa d3:aaaalen:
num:
#,如果输入的参数个数为5个
a aa aaa aaaa aaaaa
输出:
num: err:expected newline
num: err:unexpected newline

fmt.Fprintf(out)可以用fmt.Println()替代

bufio

//生成一个新的reader
func NewReader(rd io.Reader) *Reader
//生成一个新的reader,size为该reader的最短buffer长度
func NewReaderSize(rd io.Reader, size int) *Reader
//返回buffer中未被读取的长度
func (b *Reader) Buffered() int
//skip掉buffer,长度为n字节
func (b *Reader) Discard(n int) (discarded int, err error)
//返回next n 字节数据
func (b *Reader) Peek(n int) ([]byte, error)
//读取buffer的数据,读取完毕或者读取p长度的字节
func (b *Reader) Read(p []byte) (n int, err error)
//从buffer中读取一个字节
func (b *Reader) ReadByte() (c byte, err error)
//从buffer中读取若干字节,到delim截止,返回包含delim
func (b *Reader) ReadBytes(delim byte) (line []byte, err error)
//读取一行,\n结尾
func (b *Reader) ReadLine() (line []byte, isPrefix bool, err error)
//读取一个utf编码字,可能1个字节,也可能3个字节
func (b *Reader) ReadRune() (r rune, size int, err error)
//读取一段数据,delim截止,返回为[]byte类型
func (b *Reader) ReadSlice(delim byte) (line []byte, err error)
//读取一段数据,delim截止,返回string类型
func (b *Reader) ReadString(delim byte) (line string, err error)
//抛弃当前buffer的所有数据,并且重置当前值为新reader r,同时重置其它信息
func (b *Reader) Reset(r io.Reader)
//回退一个byte,回退不包含\
func (b *Reader) UnreadByte() error
//回退一个utf编码字,包含\
func (b *Reader) UnreadRune() error
//reader写入到writer中,类似于重新向的概念,需要每次
func (b *Reader) WriteTo(w io.Writer) (n int64, err error)

go pkg的更多相关文章

  1. Atitit usrQBF2312 命名空间pkg 以及 api命名 spec规范

    Atitit usrQBF2312 命名空间pkg 以及 api命名 spec规范 简化英文1 常用类库sdk的命名单词统计表1 简化时间规则1 Namsspace nam spec,参照java . ...

  2. FreeBSD pkg仓库有台湾的镜像了

    http://pkg.freebsd.org/ 在这个页面上可以看到: pkg0.bme.freebsd.org pkg0.nyi.freebsd.org pkg0.twn.freebsd.org p ...

  3. package XXX.i386.rpm is not installed(检查在Linux上安装Oracle所需的pkg时)

    如下转自一个论坛,忘了哪了,一直在电脑上存的. I've got Oracle Enterprise Linux 5 to install an Oracle server. Checking req ...

  4. FreeBSD的新一代包管理工具Pkg 1.3.0 发布

    Pkg 是 FreeBSD 下一代的打包管理工具,用来替代原来的 pkg_info/pkg_create/pkg_add 工具,可以本地打包,也提供远程打包,主要是为了方便远程二进制包升级. Pkg ...

  5. 使用tolua++编译pkg,从而创建自定义类让Lua脚本使用

    步骤一:首先自定义类(这里Himi自定义类名 “MySprite”) MySprite.h 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 // //  ...

  6. 关于MAC的pkg和mpkg的分别

    程序制作完毕后,在mac下通常的方法是要制作一个pkg的安装包,可是你会发现pkg和mpkg的文件出现的比較多,笔者也是经过了一定的试验和尝试,才了解到,pkg是单个文件的pkg,而mpkg事实上是多 ...

  7. golang之pkg(包)

    一.概述 Golang拥有超过100个标准包(可用go list std |wc -l查看) 任何包系统设计的目的都是简化大型程序的设计和维护工作,通过将一组相关的特性放进一个独立的模块以便于理解和更 ...

  8. MPC8313ERDB不新鲜pkg包裹,把文件放进Ramdisk

    MPC8313ERDB不新鲜pkg包裹,把文件放进Ramdisk 经ltib编译器生成rootfs.ext2.gz.uboot它可以直接uboot采用.假设我们编写了相应的外部文件把Ramdisk往里 ...

  9. 如何解压 Mac OS X 下的 PKG 文件(网摘)

    如何解压 Mac OS X 下的 PKG 文件 原文出处:[Macplay] 有时候我们可能需要解包 PKG 格式的安装文件包,在 OS X 系统下完成该操作并不需要你额外再安装软件,系统内置的命令就 ...

  10. macbook查找卸载pkg

    pkg是macOS下的一种比较复杂的安装方式,装完了想要卸载有点不太好找,MAC下有个命令工具pkgutil,运行命令pkgutil --pkgs可以找到你的所有pkg,如图: 当然,也可以用grep ...

随机推荐

  1. 编写CodeMirror Modes详解

    在写新的模式(mode)之前,还是先来概括一下CodeMirror的设计思路.CodeMirror分为三部分:核心,模式,扩展.核心库对外开放了很多接口,而这些接口就是实现新模式或者新扩展的基石. 在 ...

  2. redis超时问题分析

    redis超时问题分析 06/04. 2014 Redis在分布式应用中占据着越来越重要的地位,短短的几万行代码,实现了一个高性能的数据存储服务.最近dump中心的cm8集群出现过 几次redis超时 ...

  3. C#操作xml文件进行增、删、改

    进行操作的xml文件: products.xml <?xml version="1.0" encoding="utf-8"?><product ...

  4. Java基础第二章

  5. logger日志工具类

    日志工厂类 package cn.itcast.utils; import java.util.logging.FileHandler; import java.util.logging.Handle ...

  6. Restful随笔

    Rest,即Resources Representational State Transfer(资源表现层状态转化). ·资源(Resources),网络上的一个实体,每种资源对应一个特定的URI(统 ...

  7. Learning from the CakePHP source code - Part I

    最近开始痛定思痛,研究cakephp的源码. 成长的路上从来没有捷径,没有小聪明. 只有傻傻的努力,你才能听到到成长的声音. 下面这篇文章虽然过时了,但是还是可以看到作者的精神,仿佛与作者隔着时空的交 ...

  8. Android实现动画循环的方式

    每次想到循环播放.重复执行时,脑海中总是冒出在while(true)的实现方式. Thread thread = new Thread(new Runnable(){ public void run( ...

  9. poj 1308Bugs Integrated, Inc. [三进制状压]

    题目链接[http://poj.org/problem?id=1038] 题意: 给出一个N*M大小的图,图中有K个坏点.N (1 <= N <= 150), M (1 <= M & ...

  10. Angularjs directive全面解读(1.4.5)

    说到Angularjs directive即指令,可以这么说Angularjs的灵魂就是指令,学会Angularjs指令那么你的Angularjs的武功就修炼了一半了,当然这只是鄙人的一点点独到见解, ...