Biuget-Golang

Golang语言的 os 包中OpenFile 函数,如下所示:

func OpenFile(name string, flag int, perm FileMode) (*File, error) {
}

其中 name 是文件的文件名,如果不是在当前路径下运行需要加上具体路径;flag 是文件的处理参数,为 int 类型,根据系统的不同具体值可能有所不同,但是作用是相同的。

  1. O_RDONLY:只读模式打开文件;
  2. O_WRONLY:只写模式打开文件;
  3. O_RDWR:读写模式打开文件;
  4. O_APPEND:写操作时将数据附加到文件尾部(追加);
  5. O_CREATE:如果不存在将创建一个新文件;
  6. O_EXCL:和 O_CREATE 配合使用,文件必须不存在,否则返回一个错误;
  7. O_SYNC:当进行一系列写操作时,每次都要等待上次的 I/O 操作完成再进行;
  8. O_TRUNC:如果可能,在打开时清空文件。

【实例】该段代码为博主测试用于模拟输出日志。

package main

import (
	"bufio"
	"fmt"
	"io"
	"os"
	"strings"
	"sync"
	"time"
)


func main() {
	var list []string
 	mx := sync.Mutex{}
 	LogFileReading(&list,&mx)

 	for _, v := range list {
 		if strings.Contains(v,"/coco-server/v2/user-getGroupList") || strings.Contains(v,"/coco-server/v2/userSession/isPCOnline") ||
			strings.Contains(v,"/coco-server/msg-synOffLineMsg") || strings.Contains(v,"/coco-server/msg-updateMsgIndex")	{
			time.Sleep(1 * time.Second)
			LogFileWrite(v)
		}

	}
}

func LogFileReading(list *[]string,mutex *sync.Mutex)  {
	filePath := "目录"
	inputFile, inputError := os.OpenFile(filePath,os.O_RDONLY,0)
	if inputError != nil {
		fmt.Sprintf("An error occurred on opening the inputfile\n" +
			"Does the file exist?\n ")
		return
	}
	//及时关闭file
	defer inputFile.Close()
	//读取文件时,使用带缓存的 *Reader
	inputReading := bufio.NewReader(inputFile)
	for {
		//ReadString将文件内容真正的读取出来
		inputString, readerError := inputReading.ReadString('\n')
		if readerError == io.EOF {
			return
		}
		mutex.Lock()
		*list = append(*list, inputString)
		mutex.Unlock()
	}
}

func LogFileWrite(v string) {
	filePath := "目录"
	file, err := os.OpenFile(filePath, os.O_WRONLY|os.O_APPEND|os.O_CREATE, 0666)
	if err != nil {
		fmt.Println("File open failed!", err)
	}
	//及时关闭file
	defer file.Close()

	//写入文件时,使用带缓存的 *Writer
	write := bufio.NewWriter(file)
	write.WriteString(v)
	//Flush将缓存的文件真正写入到文件中
	write.Flush()
}

  

转载请声明出处哦~,本篇文章发布于Biuget-Golang的博客:

https://www.cnblogs.com/Biuget-Golang/

分类:

Golang

技术点:

相关文章: