您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關怎么在golang中設置seek光標位置,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
golang 是Google開發的一種靜態強類型、編譯型、并發型,并具有垃圾回收功能的編程語言,其語法與 C語言相近,但并不包括如枚舉、異常處理、繼承、泛型、斷言、虛函數等功能。
os.Open()-->*File,err *****
File.Seek(offset, whence),設置光標的未知
offset,偏移量
whence,從哪開始:0從頭,1當前,2末尾
package main import ( "os" "fmt" ) func main() { /* seek(offset int, whence int),表示設置光標的位置 offset int,設置多少個字節 whence int,從哪開始 0,距離文件開頭 1,當前的位置 2,距離文件末尾 */ //file,_:= os.Open("C:\\liu\\pro\\aa.txt") //RDONLY file,_:=os.OpenFile("C:\\liu\\pro\\aa.txt",os.O_RDWR,0) //1.打開文件后,光標默認在文件開頭。 bs := make([] byte, 1) defer file.Close() //2.seek() //設置光標的位置在:距離文件開頭,4個字節處。 //file.Seek(8,0) count, _:= file.Read(bs) fmt.Println(string(bs[:count])) //a file.Seek(4,2) //count, _= file.Read(bs) //fmt.Println(string(bs[:count])) // file.Write([]byte{65,66,67}) fmt.Println("寫完了。。") }
補充:Go語言-命令行參數(os.Args, flag包)
大部分Go程序都是沒有UI的,運行在純命令行的模式下,該干什么全靠運行參數。
這里介紹下Go語言命令行程序和他們的參數。
程序獲取運行他時給出的參數,可以通過os包來實現。先看代碼:
package main import ( "fmt" "os" "strconv" ) func main () { for idx, args := range os.Args { fmt.Println("參數" + strconv.Itoa(idx) + ":", args) } }
運行起來得到的如下:
$go run main.go 1 3 -X ?
參數0: /tmp/go-build116558042/command-line-arguments/_obj/exe/main
參數1: 1
參數2: 3
參數3: -X
參數4: ?
可以看到,命令行參數包括了程序路徑本身,以及通常意義上的參數。
程序中os.Args的類型是 []string ,也就是字符串切片。所以可以在for循環的range中遍歷,還可以用 len(os.Args) 來獲取其數量。
如果不想要輸出os.Args的第一個值,也就是可執行文件本身的信息,可以修改上述程序:
for idx, args := range os.Args[1:] {
將range后面的切片,去掉第一個元素。
輸出切片的所有元素,還有更簡潔的方式:
fmt.Println(strings.Join(os.Args[1:], "\n")) fmt.Println(os.Args[1:]) /* 后一種方式的結果是[1 3 -X ?],這是fmt.Println輸出切片的格式 */
flag包相比單純的通過os.Args切片分析命令行參數,提供了更強的能力。
來看個例子:
package main import ( "fmt" "flag" ) var b = flag.Bool("b", false, "bool類型參數") var s = flag.String("s", "", "string類型參數") func main() { flag.Parse() fmt.Println("-b:", *b) fmt.Println("-s:", *s) fmt.Println("其他參數:", flag.Args()) } ------------------------------------ $ go run main.go -b: false -s: 其他參數: [] ------------------------------------ $ go run main.go -b -b: true -s: 其他參數: [] ------------------------------------ $ go run main.go -b -s test others -b: true -s: test 其他參數: [others] ------------------------------------ $ go run main.go -help Usage of /tmp/go-build080353851/command-line-arguments/_obj/exe/main: -b bool類型參數 -s string string類型參數 exit status 2
使用flag包,首先定義待解析命令行參數,也就是以"-"開頭的參數,比如這里的 -b -s -help等。-help不需要特別指定,可以自動處理。
這里指定了兩個參數,-b和-s:
var b = flag.Bool("b", false, "bool類型參數") var s = flag.String("s", "", "string類型參數") ----------------- 原型: func Bool(name string, value bool, usage string) *bool func String(name string, value string, usage string) *string
通過flag.Bool和flag.String,建立了2個指針b和s,分別指向bool類型和string類型的變量。所以后續要通過 *b 和 *s 使用變量值。
flag.Bool和flag.String的參數有3個,分別是命令行參數名稱,默認值,提示字符串。
參數 | 功能 |
---|---|
name | 命令行參數名稱,比如 -b, -help |
value | 默認值,未顯式指定的參數,給出隱式的默認值,比如本例中-b未給出的話,*b=false |
usage | 提示信息,如果給出的參數不正確或者需要查看幫助 -help,那么會給出這里指定的字符串 |
flag使用前,必須首先解析:
flag.Parse()
上文已經說明,通過flag方法定義好的參數變量指針,通過間接引用操作即可使用其內容:
fmt.Println("-b:", *b) fmt.Println("-s:", *s)
參數中沒有能夠按照預定義的參數解析的部分,通過flag.Args()即可獲取,是一個字符串切片。
fmt.Println("其他參數:", flag.Args())
需要注意的是,從第一個不能解析的參數開始,后面的所有參數都是無法解析的。即使后面的參數中含有預定義的參數:
$ go run main.go -b stop -s test others -b: true -s: 其他參數: [stop -s test others]
看完上述內容,你們對怎么在golang中設置seek光標位置有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。