Go中各种newreader和newbuffer的使用

一、bytes.NewBuffer和bytes.NewReader

func main() {var byteArr []bytebuf := bytes.NewBuffer(byteArr)buf.Write([]byte("今天不错"))fmt.Println(buf.String())
}
package mainimport ("bytes""fmt"
)func main() {data := []byte("路多辛的所思所想")reader := bytes.NewReader(data)// 读取整个字节数组buf := make([]byte, len(data))_, err := reader.Read(buf)if err != nil {fmt.Println("Read failed:", err)}fmt.Println("Bytes read:", buf)// 读取字节切片的一部分part := make([]byte, 3)_, err = reader.Read(part)if err != nil {fmt.Println("Read failed:", err)}fmt.Println("Bytes read:", part)// 查找并读取字节切片中的某个字符offset, err := reader.Seek(6, 0)if err != nil {fmt.Println("Seek failed:", err)}ch, size, err := reader.ReadRune()if err != nil {fmt.Println("ReadRune failed:", err)}fmt.Printf("Read %c with size %d at offset %d\n", ch, size, offset)
}

二、strings.NewReader(没有newWriter)

	r := strings.NewReader("abcdefghijklmn")fmt.Println(r.Len())   // 输出14  初始时,未读长度等于字符串长度var buf []bytebuf = make([]byte, 5)readLen, err := r.Read(buf)fmt.Println("读取到的长度:", readLen) //读取到的长度5if err != nil {fmt.Println("错误:", err)}fmt.Println(buf)            //adcdefmt.Println(r.Len())        //9   读取到了5个 剩余未读是14-5fmt.Println(r.Size())       //14   字符串的长度

三、bufio.NewReader和bufio.NewWriter

package main
import ("fmt""io""os"
)
func main() {fmt.Println("嗨客网(www.haicoder.net)")fileName := "C:/haicoder.txt"file, err := os.Open(fileName)if err != nil{fmt.Println("Read file err, err =", err)return}defer file.Close()var chunk []bytebuf := make([]byte, 1024)for{n, err := bufio.NewReader(buf)if err != nil && err != io.EOF{fmt.Println("read buf fail", err)return}//说明读取结束if n == 0 {break}//读取到最终的缓冲区中chunk = append(chunk, buf[:n]...)}fmt.Println("File Content =", string(chunk))
}
package main
import ("bufio""fmt""io/ioutil""os"
)
func main() {fmt.Println("嗨客网(www.haicoder.net)")var(fileName = "C:/haicoder.txt"content = "Hello HaiCoder"file *os.Fileerr error)//使用追加模式打开文件file, err = os.OpenFile(fileName, os.O_APPEND, 0666)if err != nil{fmt.Println("Open file err =", err)return}defer file.Close()writer := bufio.NewWriter(file)//写入文件n, err := writer.Write([]byte(content))if err != nil{fmt.Println("Write file err =", err)return}fmt.Println("Write file success, n =", n)writer.Flush()//读取文件fileContent, err := ioutil.ReadFile(fileName)if err != nil{fmt.Println("Read file err =", err)return}fmt.Println("Read file success =", string(fileContent))
}

总结:
1、使用的newbuffer,缓存区是用来存储内容的,并不能确定具体需要的内存大小,因此newbuffer的参数为不固定的[]byte{};
2、使用的newreader,缓存区应该是有数值的,此时是用来读取其中的内容。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/155987.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据资产到底如何入表?

2024年1月1日起,财政部《企业数据资源相关会计处理暂行规定》正式施行,距离现在只有一个多月的时间。 数据资源入表意味着企业可以将数据资源确认为企业资产负债表中“资产”一项。对于拥有丰富数据资源的企业来说,有望在财务报表中体现其真…

Spring Boot单元测试

目录 1.概述 2.基本使用 3.优势 4.常用属性 1.概述 所谓单元测试就是对功能最小粒度的测试,落实到JAVA中就是对单个方法的测试。对单个方法的测试用junit即可,关于junit作者另一位篇文章中有详细介绍,感兴趣的小伙伴可以去看看&#xff…

Sqlite安装配置及使用

一、下载SQLite Sqlite官网 我下载的是3370000版本:sqlite-dll-win64-x64-3370000.zip 和 sqlite-tools-win32-x86-3370000.zip 二、解压下载的两个压缩包 三、配置环境 四、检查是否安装配置成功 winR:输入cmd调出命令窗口,输入sqlite3后回车查看s…

软件运维面试题

文章目录 面试题你在设备安装时遇到了一个故障,你会怎么做?答案 作为一名实施工程师,你如何保证项目的交付质量?答案 作为一名实施工程师,你在处理技术问题时遇到过比较难解决的情况吗?如果有,可…

百度爬虫的工作原理解析

百度作为中国最大的搜索引擎,其工作原理备受关注。本文将深入探讨百度爬虫的工作原理,介绍其基本流程以及关键技术,帮助读者更好地理解搜索引擎背后的技术核心。 百度爬虫是百度搜索引擎的重要基石,它们被广泛用于收集互联网上的网…

怎样用css画一个圆?

要使用 CSS 画一个圆,可以使用 border-radius 属性为一个元素添加圆角,将 width 和 height 设置为相等的值,从而形成一个圆形。 以下是一个使用 CSS 画圆的简单示例: .circle {width: 100px;height: 100px;background-color: #3…

08-黑马点评项目发布笔记和查看笔记功能的实现

发布笔记 数据模型 tb_blog探店笔记表,包含笔记的标题、文字、图片等 tb_blog探店笔记表对应的实体类 增加用户图标和和用户姓名以及是否被点赞过了的字段,这些字段不属于Blog表只是为了实现在展示笔记的时候同时展示用户的信息 Data EqualsAndHashCode(callSuper false) …

使用sed命令进行文本处理示例

文章目录 前言查找并替换操作在文件中添加文本删除文件中的文本高亮显示文件中的文本 转载请标明出处: https://bigmaning.blog.csdn.net/article/details/134539923 本文出自:【BigManing的博客】 前言 当我们需要在Linux系统中处理文本文件时,经常需要…

包装类型的缓存机制

Java 基本数据类型的包装类型的大部分都用到了缓存机制来提升性能。 Byte,Short,Integer,Long 这 4 种包装类默认创建了数值 [-128,127] 的相应类型的缓存数据,Character 创建了数值在 [0,127] 范围的缓存数据,Boolean 直接返回 True or Fal…

Vue框架学习笔记——v-bind数据单向绑定和v-model数据双向绑定

文章目录 v-bind,数据单向绑定简写形态(省略v-bind,只留冒号)示例一(将输入框数据改为:哈哈哈哈哈):实例二(将Vue实例中的name改为字符串:"单向绑定&quo…

多模态大模型训练数据集汇总介绍

RefCOCO、RefCOCO、RefCOCOg 这三个是从MS-COCO中选取图像得到的数据集,数据集中对所有的 phrase 都有 bbox 的标注。 RefCOCO 共有19,994幅图像,包含142,209个引用表达式,包含50,000个对象实例。RefCOCO 共有19,992幅图像,包含1…

Mybatis Plus分页实现逻辑整理(结合芋道整合进行解析)

Mybatis Plus分页实现逻辑整理(结合芋道整合进行解析) 我希望如春天般的你,身着白色的婚纱,向我奔赴而来,我愿意用全世界最温情的目光,朝着你的方向望去——姗姗来迟。 1.背景介绍 https://baomidou.com/p…

【gpts】学算法题[缺失的第一个正数](https://leetcode.cn/problems/first-missing-positive/)

给出你的题解 (https://leetcode.cn/problems/first-missing-positive/) public class Solution { public int firstMissingPositive(int[] nums) {int len nums.length;for (int i 0; i < len; i) {while (nums[i] > 0 && nums[i] < len && nums…

有依次对应关系的数组X、Y、Z,如何排序其中一个X数组,使得另外的数组还与排序完成后的数组相对应(C语言实现)

1. 目的 有依次对应关系的数组X、Y、Z&#xff0c;排序其中一个X数组&#xff0c;使得另外的数组还与排序完成后的数组相对应&#xff0c;并打印出排序完成后的X、Y、Z数组。 2. 具体实现 以下面的这个对应关系为例&#xff0c;进行相应编程实现。 X [3.7,7.7,-6.6,1.5,-4.5…

用vue实现pdf预览

iframe <iframe :src"fileURLOther"></iframe> import axios from "axios"; data() {return {fileURLOther: "",url:,id:} }methods&#xff1a;{openPDF() {axios({method: "get",url: this.url,//文件的urlparams: {fi…

Linux系统编程学习 NO.9——git、gdb

前言 本篇文章简单介绍了Linux操作系统中两个实用的开发工具git版本控制器和gdb调试器。 git 什么是git&#xff1f; git是一款开源的分布式版本控制软件。它不仅具有网络功能&#xff0c;还是服务端与客户端一体的软件。它可以高效的处理程序项目中的版本管理。它是Linux内…

深入理解Linux网络笔记(六):深度理解TCP连接建立过程

本文为《深入理解Linux网络》学习笔记&#xff0c;使用的Linux源码版本是3.10&#xff0c;网卡驱动默认采用的都是Intel的igb网卡驱动 Linux源码在线阅读&#xff1a;https://elixir.bootlin.com/linux/v3.10/source 5、深度理解TCP连接建立过程 1&#xff09;、深入理解liste…

python查找算法_顺序查找

顺序查找&#xff08;Sequential Search&#xff09;是一种简单直观的搜索算法&#xff0c;用于在无序数组中查找特定元素。它的基本思想是逐个遍历数组中的元素&#xff0c;直到找到目标元素或遍历完整个数组。本文将介绍顺序查找的基本原理&#xff0c;并通过Python代码进行详…

网络爬虫|Selenium——find_element_by_xpath()的几种方法

Xpath (XML Path Language)&#xff0c;是W3C定义的用来在XML文档中选择节点的语言 一、从根目录/开始 有点像Linux的文件查看&#xff0c;/代表根目录&#xff0c;一级一级的查找&#xff0c;直接子节点&#xff0c;相当于css_selector中的>号 /html/body/div/p 二、根据…

LTspice学习笔记

参考博文 LTspice 软件仿真入门–LLC开环仿真练习LTspice:模拟变压器的简单步骤SPICE 语言基本语法和规则