成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > Golang 實(shí)現(xiàn)超大文件讀取的兩種方法

Golang 實(shí)現(xiàn)超大文件讀取的兩種方法

熱門標(biāo)簽:阿克蘇地圖標(biāo)注 外呼系統(tǒng)用什么卡 excel地圖標(biāo)注分布數(shù)據(jù) 評(píng)價(jià)高的400電話辦理 壽光微信地圖標(biāo)注 電話機(jī)器人軟件免費(fèi) 百度地圖標(biāo)注后傳給手機(jī) 外呼系統(tǒng)顯本地手機(jī)號(hào) 涿州代理外呼系統(tǒng)

Golang超大文件讀取的兩個(gè)方案

流處理方式

分片處理

去年的面試中我被問(wèn)到超大文件你怎么處理,這個(gè)問(wèn)題確實(shí)當(dāng)時(shí)沒(méi)多想,回來(lái)之后仔細(xì)研究和討論了下這個(gè)問(wèn)題,對(duì)大文件讀取做了一個(gè)分析

比如我們有一個(gè)log文件,運(yùn)行了幾年,有100G之大。按照我們之前的操作可能代碼會(huì)這樣寫:

func ReadFile(filePath string) []byte{
    content, err := ioutil.ReadFile(filePath)
    if err != nil {
        log.Println("Read error")
    }
    return content
} 

上面的代碼讀取幾兆的文件可以,但是如果大于你本身及其內(nèi)存,那就直接翻車了。因?yàn)樯厦娴拇a,是把文件所有的內(nèi)容全部都讀取到內(nèi)存之后返回,幾兆的文件,你內(nèi)存夠大可以處理,但是一旦上幾百兆的文件,就沒(méi)那么好處理了。

那么,正確的方法有兩種

第一個(gè)是使用流處理方式代碼如下

func ReadFile(filePath string, handle func(string)) error {
    f, err := os.Open(filePath)
    defer f.Close()
    if err != nil {
        return err
    }
    buf := bufio.NewReader(f)
 
    for {
        line, err := buf.ReadLine("\n")
        line = strings.TrimSpace(line)
        handle(line)
        if err != nil {
            if err == io.EOF{
                return nil
            }
            return err
        }
        return nil
    }
}

第二個(gè)方案就是分片處理

當(dāng)讀取的是二進(jìn)制文件,沒(méi)有換行符的時(shí)候,使用下面的方案一樣處理大文件

func ReadBigFile(fileName string, handle func([]byte)) error {
    f, err := os.Open(fileName)
    if err != nil {
        fmt.Println("can't opened this file")
        return err
    }
    defer f.Close()
    s := make([]byte, 4096)
    for {
        switch nr, err := f.Read(s[:]); true {
        case nr  0:
            fmt.Fprintf(os.Stderr, "cat: error reading: %s\n

補(bǔ)充:golang 讀取大文件處理sync.pool + bufio.NewReader(f)

看代碼吧~

文件大小

package main
import (
	"bufio"
	"fmt"
	"io"
	//"math"
	"os"
	"strings"
	"sync"
	"time"
)
func main() {
	/*
	文件數(shù)據(jù)樣例
	{"remark": "來(lái)電時(shí)間:  2021/04/15 13:52:07客戶電話:13913xx39xx ", "no": "600020510132021101310210547639", "title": "b-ae0e-0242ac100907", "call_in_date": "2021-04-15 13:52:12", "name": "張三", "_date": "2021-06-15", "name": "張三", "meet": "1"}
	1、我們?nèi)〕?call_in_date": "2021-04-15 13:52:1的數(shù)據(jù)寫入另一個(gè)文件
	*/
	var (
		s time.Time //當(dāng)前時(shí)間
		file *os.File
		fileStat os.FileInfo
		err error
		lastLineSize int64
	)
	s = time.Now()
	if file, err = os.Open("/Users/zhangsan/Downloads/log.txt");err != nil{
		fmt.Println(err)
	}
	defer func() {
		err = file.Close() //close after checking err
	}()
	//queryStartTime, err := time.Parse("2006-01-02T15:04:05.0000Z", startTimeArg)
	//if err != nil {
	//	fmt.Println("Could not able to parse the start time", startTimeArg)
	//	return
	//}
	//
	//queryFinishTime, err := time.Parse("2006-01-02T15:04:05.0000Z", finishTimeArg)
	//if err != nil {
	//	fmt.Println("Could not able to parse the finish time", finishTimeArg)
	//	return
	//}
	/**
	* {name:"log.log", size:911100961, mode:0x1a4,
	modTime:time.Time{wall:0x656c25c, ext:63742660691,
	loc:(*time.Location)(0x1192c80)}, sys:syscall.Stat_t{Dev:16777220,
	Mode:0x81a4, Nlink:0x1, Ino:0x118cba7, Uid:0x1f5, Gid:0x14, Rdev:0,
	Pad_cgo_0:[4]uint8{0x0, 0x0, 0x0, 0x0}, Atimespec:syscall.Timespec{Sec:1607063899, Nsec:977970393},
	Mtimespec:syscall.Timespec{Sec:1607063891, Nsec:106349148}, Ctimespec:syscall.Timespec{Sec:1607063891,
	Nsec:258847043}, Birthtimespec:syscall.Timespec{Sec:1607063883, Nsec:425808150},
	Size:911100961, Blocks:1784104, Blksize:4096, Flags:0x0, Gen:0x0, Lspare:0, Qspare:[2]int64{0, 0}}
	*
	*/
	if fileStat, err = file.Stat();err != nil {
		return
	}
	fileSize := fileStat.Size()//72849354767
	offset := fileSize - 1
	//檢測(cè)是不是都是空行 只有\(zhòng)n
	for {
		var (
			b []byte
			n int
			char string
		)
		b = make([]byte, 1)
		//從指定位置讀取
		if n, err = file.ReadAt(b, offset);err != nil {
			fmt.Println("Error reading file ", err)
			break
		}
		char = string(b[0])
		if char == "\n" {
			break
		}
		offset--
		//獲取一行的大小
		lastLineSize += int64(n)
	}
	var (
		lastLine []byte
		logSlice []string
		logSlice1 []string
	)
	//初始化一行大小的空間
	lastLine = make([]byte, lastLineSize)
	_, err = file.ReadAt(lastLine, offset)
	if err != nil {
		fmt.Println("Could not able to read last line with offset", offset, "and lastline size", lastLineSize)
		return
	}
	//根據(jù)條件進(jìn)行區(qū)分
	logSlice = strings.Split(strings.Trim(string(lastLine),"\n"),"next_pay_date")
	logSlice1  = strings.Split(logSlice[1],"\"")
	if logSlice1[2] == "2021-06-15"{
		Process(file)
	}
	fmt.Println("\nTime taken - ", time.Since(s))
		fmt.Println(err)
}
func Process(f *os.File) error {
	//讀取數(shù)據(jù)的key,減小gc壓力
	linesPool := sync.Pool{New: func() interface{} {
		lines := make([]byte, 250*1024)
		return lines
	}}
	//讀取回來(lái)的數(shù)據(jù)池
	stringPool := sync.Pool{New: func() interface{} {
		lines := ""
		return lines
	}}
	//一個(gè)文件對(duì)象本身是實(shí)現(xiàn)了io.Reader的 使用bufio.NewReader去初始化一個(gè)Reader對(duì)象,存在buffer中的,讀取一次就會(huì)被清空
	r := bufio.NewReader(f) //
	//設(shè)置讀取緩沖池大小 默認(rèn)16
	r = bufio.NewReaderSize(r,250 *1024)
	var wg sync.WaitGroup
	for {
		buf := linesPool.Get().([]byte)
		//讀取Reader對(duì)象中的內(nèi)容到[]byte類型的buf中
		n, err := r.Read(buf)
		buf = buf[:n]
		if n == 0 {
			if err != nil {
				fmt.Println(err)
				break
			}
			if err == io.EOF {
				break
			}
			return err
		}
		//補(bǔ)齊剩下沒(méi)滿足的剩余
		nextUntillNewline, err := r.ReadBytes('\n')
		//fmt.Println(string(nextUntillNewline))
		if err != io.EOF {
			buf = append(buf, nextUntillNewline...)
		}
		wg.Add(1)
		go func() {
			ProcessChunk(buf, linesPool, stringPool)
			wg.Done()
		}()
	}
	wg.Wait()
	return nil
}
func ProcessChunk(chunk []byte, linesPool *sync.Pool,stringPool *sync.Pool) {
//做相應(yīng)的處理
}

執(zhí)行

go run test2.go "2020-01-01T00:00:00.0000Z" "2020-02-02T00:00:00.0000Z" /Users/zhangsan/go/src/workspace/test/log.log
EOF
Time taken -  20.023517675s
nil>

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • golang文件讀取-按指定BUFF大小讀取方式
  • golang逐行讀取文件的操作
  • Golang 實(shí)現(xiàn)分片讀取http超大文件流和并發(fā)控制
  • 淺談Golang是如何讀取文件內(nèi)容的(7種)
  • golang 使用 viper 讀取自定義配置文件
  • 如何利用Golang解析讀取Mysql備份文件
  • golang讀取文件的常用方法總結(jié)

標(biāo)簽:重慶 吐魯番 梅河口 銅川 雞西 汕頭 欽州 蘭州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Golang 實(shí)現(xiàn)超大文件讀取的兩種方法》,本文關(guān)鍵詞  Golang,實(shí)現(xiàn),超大,文件,讀,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Golang 實(shí)現(xiàn)超大文件讀取的兩種方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Golang 實(shí)現(xiàn)超大文件讀取的兩種方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    亚洲欧美日韩精品久久久久| 国产欧美日韩在线观看视频| 久久综合久久综合亚洲| 成人h动漫精品一区| 日韩在线综合网| 国产一区二区三区天码| 国产美女娇喘av呻吟久久| 国产成人免费av电影| 一本色道久久综合亚洲精品小说| 国产综合久久久久| 一区二区三区蜜桃| 好看的日韩精品视频在线| 乱色精品无码一区二区国产盗| 欧美另类女人| 欧美孕妇毛茸茸xxxx| 免费高清成人在线| 不卡av在线网| 国产1区2区3区中文字幕| 在线播放黄网| 精品亚洲一区二区三区在线观看| 欧美午夜丰满在线18影院| 91在线精品一区二区| 精品中文一区| 亚州福利视频| 日本成人三级电影| www成人免费视频| 中文文字幕一区二区三三| 欧美日韩激情视频8区| 好看的黄色网址| 北岛玲一区二区三区四区| 色播五月综合网| 91视频综合网| 欧美日韩在线播放三区四区| 一区二区免费在线视频| 亚洲一级在线观看| 在线精品国产亚洲| 亚洲高清久久久| 亚洲日本一区二区三区在线不卡| 7777女厕盗摄久久久| 亚洲精品自在久久| 久久er精品视频| 四虎永久在线高清国产精品| 色中色综合影院手机版在线观看| 国产成人免费视频一区| 国产在线视频一区| 久久精品二区三区| 欧美电影免费观看高清| 国产成人一二片| 亚洲伊人久久综合| 999国产精品永久免费视频app| 毛片在线导航| 成人激情在线播放| 丁香天五香天堂综合| 亚洲人成电影| 青草久久视频| 久久精品国产亚洲精品2020| 亚洲色图色老头| 在线观看免费国产小视频| 国产精品探花在线观看| 中文字幕一区二区三区不卡| 亚洲激情图片qvod| www.亚洲在线| 日韩欧美国产成人精品免费| 亚洲午夜激情在线| 久久综合久久美利坚合众国| 成人免费网址在线| 国内精品久久久久久久久蜜桃| 亚洲永久精品免费| 国产精品一级久久久| jizzjizz亚洲中国少妇| 亚洲欧美日韩国产中文专区| 一区二区三区伦理片| 国产精品国模大尺度视频| 国产一区二区三区四区三区四| 奇米777日韩| 亚洲电影中文字幕在线观看| 午夜69成人做爰视频| 久久国产精品一区二区三区四区| 在线亚洲国产精品网| 亚洲综合自拍偷拍| 亚洲欧美日韩综合| 中文娱乐网av| 久久色免费在线视频| 成人在线播放网址| 青青青青国产视频| 欧美一区二区在线免费播放| 91亚洲精品久久久蜜桃借种| 91超碰国产精品| 第三区美女视频在线| 91精品国产91久久| 日韩激情在线| 青青草手机在线观看| 欧美国产日韩精品免费观看| 国产福利一区二区在线精品| 亚洲精品免费av| 91亚洲一线产区二线产区| 91久久精品一区二区三| 久久国产精品一区二区三区| 久久国产精品偷| 尤物在线观看视频| 亚洲天堂手机在线| 91九色porn蝌蚪| 午夜欧美巨大性欧美巨大| 免费观看的av| 99精品人妻国产毛片| 久久精品国产sm调教网站演员| 午夜爱爱毛片xxxx视频免费看| 农民人伦一区二区三区| 欧美人成网站| 亚洲欧美日本一区二区三区| 欧美日韩亚洲综合一区二区三区| eeuss影院在线| 成人h动漫精品一区二区无码| 可以看av的网站久久看| 国产在线88av| 亚洲国产欧美日韩另类综合| 亚洲欧美日韩一区| 精品国产精品网麻豆系列| 日韩激情欧美| 精品国产免费人成网站| 苍井空浴缸大战猛男120分钟| 亚洲资源网你懂的| 国产精品毛片大码女人| 91精品国产九九九久久久亚洲| 中文字幕永久视频| 午夜欧美大尺度福利影院在线看| 欧美videosex性极品hd| 色综合桃花网| 一本色道久久综合狠狠躁的推荐| 国模精品一区二区三区色天香| 亚洲av成人无码一二三在线观看| 性感美女极品91精品| 99精品人妻无码专区在线视频区| 小泽玛利亚av在线| 成人免费视频网站| 久久综合图区亚洲综合图区| 欧美久久综合性欧美| 国产成人亚洲精品狼色在线| 日本a级片电影一区二区| 欧美日本亚洲| 久久精品国产亚洲夜色av网站| 成人网在线观看| 亚洲欧洲精品一区二区精品久久久| 久久久精品毛片| 精品视频免费观看| 色婷婷亚洲十月十月色天| 韩日视频一区| 国产精品一区二区你懂的| 国产精品videossex国产高清| 国产精品在线看| 精品成人佐山爱一区二区| 一本色道久久精品| 中文字幕在线视频一区| heyzo高清国产精品| 激情欧美亚洲| 性爱视频在线播放| 亚洲欧美另类久久久精品2019| 中文字幕精品一区久久久久| 91亚洲国产成人久久精品麻豆| 色网址在线观看| 国产又粗又长又大的视频| 狠狠操天天操夜夜操| 欧美图片激情小说| 亚洲第一精品网站| 国产精品久久久久久婷婷天堂| 欧美精品中文字幕亚洲专区| 欧美优质美女网站| 中文字幕日韩欧美在线视频| 丁香激情综合国产| 国产精品一卡二卡| 色精品一区二区三区| 成年人观看网站| 国产高清视频一区三区| 范冰冰一级做a爰片久久毛片| 网站免费在线观看| 亚洲亚洲精品在线观看| 日韩欧美国产成人| 国产最新自拍视频| 黄色录像特级片| 高清亚洲成在人网站天堂| 成人精品免费在线观看| 久久综合国产精品| 精品日韩在线视频| 一级特黄aaaaaa大片| 国产日韩中文在线| 人人妻人人爽人人澡人人精品| 国产日产欧产精品推荐色| 四季av一区二区三区| 春色校园综合激情亚洲| 狠狠躁夜夜躁人人躁婷婷91| 日韩美脚连裤袜丝袜在线| 国产91av视频| 亚洲欧美一区二区三区在线| 中文字幕一区二区三区av| 中文文字幕一区二区三三| 国产香蕉久久| 成 人 黄 色 片 在线播放| 成年人羞羞的网站| 日韩免费在线观看视频| 久久uomeier| 最近中文字幕av免费高清| 成人在线观看免费网站| 亚洲第一成人在线视频| 成人在线电影在线观看视频| 日本色综合中文字幕| 无码人妻av一区二区三区波多野| 亚洲无人区码一码二码三码的含义| 国产精品传媒入口麻豆| 久久精品日产第一区二区三区乱码| 日韩不卡高清| 欧美黄色一区| 亚洲图片你懂的| 麻豆app在线观看| 蜜臀aⅴ国产精品久久久国产老师| 欧美激情三区| 国产欧美91| 69av视频在线播放| 国产精品久久久久久久久图文区| 精品亚洲欧美日韩| 亚州欧美日韩中文视频| 99久久婷婷国产综合精品| 激情综合亚洲精品| 色综合色综合久久综合频道88| 悠悠资源网久久精品| 亚洲天堂777| 国产日韩欧美综合精品| 在线免费观看麻豆| 国产精品私房写真福利视频| 精品日本一线二线三线不卡| 亚洲男人av| 高清亚洲成在人网站天堂| 国产a视频免费观看| 欧美日韩精品一区二区三区视频播放| 国产激情一区二区三区在线观看| 26uuu精品一区二区在线观看| 日本一区午夜艳熟免费| 国产欧美激情视频| 欧美日韩在线观看视频| 欧美日韩国产成人在线观看| 草草地址线路①屁屁影院成人| 大地资源网在线观看免费官网| 精品国产日韩欧美| 在线观看一区欧美| 户外露出一区二区三区| 国产精品毛片aⅴ一区二区三区| 黄色在线观看网| 天天综合天天综合色| 精品国模一区二区三区欧美| 精品国产第一国产综合精品| 欧美国产日韩另类| 精品成人在线| 欧美极品一区| 国产精品欧美一级免费| 91短视频在线| 亚洲色图欧美视频| 午夜丝袜av电影| 久久精品欧美日韩精品| 中文字幕乱码视频| 色老汉一区二区三区| 亚洲欧美日韩精品综合在线观看| 国产美女在线观看一区| 日韩大陆av| 国产视频第二页| 欧美日韩精品一区二区三区| 亚洲天堂久久久久久久| 性久久久久久久久久久| 久艹在线观看视频| 最新中文字幕第一页| 丁香花在线高清完整版视频| 国产精品美女久久久浪潮软件| 国产福利资源在线| 一二区在线观看| 精品系列免费在线观看| 亚洲一区二区中文字幕在线观看| 97视频久久久| 神马电影久久| 久久se精品一区二区| 国产精品不卡| 在线观影网站| 欧美白人猛性xxxxx交69| 日本黄网站色大片免费观看| av亚洲在线观看| 国外成人在线视频| 91成人在线视频| 黄色综合网址| 91另类视频| aa亚洲婷婷| 欧美日韩亚洲国产一区| 色一情一乱一区二区| 欧美在线观看日本一区| 1024亚洲合集| 在线不卡一区| 亚洲av无码国产精品久久不卡| 日本成a人片在线观看| 久久精品夜色噜噜亚洲a∨| 国产高清视频一区| 奶水喷射视频一区| 国产精品视频自拍| 婷婷五月综合久久中文字幕| 在线视频一二区| 熟女av一区二区| 一本色道久久hezyo无码| 国产乱码精品一区二区三区四区| 日本最新高清不卡中文字幕| 91一区二区三区| 毛毛毛毛毛毛毛片123| 91精品国产色综合久久| 亚洲男女性事视频| 欧美va视频| 99久久无色码| 爱情岛论坛亚洲品质自拍视频网站| 疯狂试爱三2浴室激情视频| 日韩一级网站| 国产成人亚洲综合a∨婷婷图片| 欧洲亚洲免费视频| 日韩福利视频一区| 国产美女视频91| 成人激情黄色小说| 91精品国产91久久久久久最新毛片| 久久综合网导航| 91精品国产高清一区二区三区蜜臀| 91精品国产91热久久久做人人| 超碰在线影院| 成人看片app| 蜜桃av.网站在线观看| 亚洲女人的天堂| 人妻大战黑人白浆狂泄| 日本二三区不卡|