Writing Files

Writing Files #

// Go တွင် ဖိုင်ရေးသားခြင်းသည် ယခင်က ကျွန်ုပ်တို့တွေ့ခဲ့သော
// ဖိုင်ဖတ်ခြင်းနှင့် ဆင်တူသော ပုံစံများကို လိုက်နာသည်။

package main

import (
	"bufio"
	"fmt"
	"os"
)

func check(e error) {
	if e != nil {
		panic(e)
	}
}

func main() {

	// စတင်ရန်အတွက်၊ string (သို့မဟုတ် byte များ) ကို
	// ဖိုင်ထဲသို့ ထည့်သွင်းရေးသားပုံကို ဖော်ပြထားသည်။
	d1 := []byte("hello\ngo\n")
	err := os.WriteFile("/tmp/dat1", d1, 0644)
	check(err)

	// ပိုမိုအသေးစိတ်ရေးသားရန်အတွက်၊ ဖိုင်ကို ရေးသားရန် ဖွင့်ပါ။
	f, err := os.Create("/tmp/dat2")
	check(err)

	// ဖိုင်ဖွင့်ပြီးချက်ချင်း `Close` ကို defer လုပ်ခြင်းသည် ထုံးစံဖြစ်သည်။
	defer f.Close()

	// ကျနော်တို့လုပ်ချင်တဲ့အတိုင်း byte slice များကို `Write` နိုင်သည်။
	d2 := []byte{115, 111, 109, 101, 10}
	n2, err := f.Write(d2)
	check(err)
	fmt.Printf("wrote %d bytes\n", n2)

	// `WriteString` လည်းရှိပါသည်။
	n3, err := f.WriteString("writes\n")
	check(err)
	fmt.Printf("wrote %d bytes\n", n3)

	// ရေးသားထားသည်များကို တည်ငြိမ်သော သိုလှောင်မှုသို့ flush လုပ်ရန် `Sync` ကို အသုံးပြုပါ။
	f.Sync()

	// `bufio` သည် ယခင်က မြင်ခဲ့ရသော buffered reader များအပြင်
	// buffered writer များကိုလည်း ပေးစွမ်းသည်။
	w := bufio.NewWriter(f)
	n4, err := w.WriteString("buffered\n")
	check(err)
	fmt.Printf("wrote %d bytes\n", n4)

	// buffer ထဲရှိ လုပ်ဆောင်ချက်အားလုံးကို အခြေခံ writer ထဲသို့
	// အသုံးချပြီးကြောင်း သေချာစေရန် `Flush` ကို အသုံးပြုပါ။
	w.Flush()
}
# ဖိုင်ရေးသားသည့် ကုဒ်ကို စမ်းသပ်ပြီး run ကြည့်ပါ။
$ go run writing-files.go 
wrote 5 bytes
wrote 7 bytes
wrote 9 bytes

# ထို့နောက် ရေးသားထားသော ဖိုင်များ၏ 
# အကြောင်းအရာများ(content)ကို စစ်ဆေးကြည့်ပါ။
$ cat /tmp/dat1
hello
go
$ cat /tmp/dat2
some
writes
buffered

# နောက်တစ်ဆင့်အနေဖြင့် ယခုလေ့လာခဲ့သော 
# ဖိုင် I/O သဘောတရားအချို့ကို
# `stdin` နှင့် `stdout` stream များတွင် 
# အသုံးချခြင်းကို ကြည့်ကြမည်။