直接將字符變量賦值給整型變量,即可實現(xiàn)字符到對應ASCII碼的轉(zhuǎn)換。
瓊結(jié)網(wǎng)站建設公司成都創(chuàng)新互聯(lián)公司,瓊結(jié)網(wǎng)站設計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為瓊結(jié)超過千家提供企業(yè)網(wǎng)站建設服務。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設公司要多少錢,請找那個售后服務好的瓊結(jié)做網(wǎng)站的公司定做!
Go中的binary包實現(xiàn)了簡單的數(shù)字與字節(jié)序列的轉(zhuǎn)換以及變長值的編解碼
package main
import ( "fmt" "bytes" "encoding/binary" ) func main(){ n := 0x12345678 bytesBuffer := bytes.NewBuffer([]byte{}) //BigEndian 大端順序存儲 LittleEndian小端順序存儲 binary.Write(bytesBuffer, binary.BigEndian, int32(n)) data:=bytesBuffer.Bytes() fmt.Printf("[0]: %#x addr:%#x\n",data[0],data[0]) fmt.Printf("[0]: %#x addr:%#x\n",data[1],data[1]) fmt.Printf("[0]: %#x addr:%#x\n",data[2],data[2]) fmt.Printf("[0]: %#x addr:%#x\n",data[3],data[3]) }
輸出
[0]: 0x12 addr:0xc042010248 [1]: 0x34 addr:0xc042010249 [2]: 0x56 addr:0xc04201024a [3]: 0x78 addr:0xc04201024b
也可以使用下面的方式
n := 0x12345678 var data []byte = make([]byte,4) //操作的都是無符號整型 binary.BigEndian.PutUint32(data,uint32(n))
可以使用下面的方式判斷當前系統(tǒng)的字節(jié)序類型
const INT_SIZE int = int(unsafe.Sizeof(0))
//判斷我們系統(tǒng)中的字節(jié)序類型 func systemEdian() { var i int = 0x1 bs := (*[INT_SIZE]byte)(unsafe.Pointer(i)) if bs[0] == 0 { fmt.Println("system edian is little endian") } else { fmt.Println("system edian is big endian") } }
結(jié)構(gòu)體與[]byte不能直接轉(zhuǎn)化,可以通過gob來轉(zhuǎn)換。
編碼時如下,假設默認的結(jié)構(gòu)體為data
func Encode(data interface{}) ([]byte, error) { buf := bytes.NewBuffer(nil) enc := gob.NewEncoder(buf) err := enc.Encode(data) if err != nil { return nil, err } return buf.Bytes(), nil }解碼時如下,data為需要解碼的字節(jié)數(shù)組,to為相應的接收結(jié)構(gòu)體,記住to的結(jié)構(gòu)體結(jié)構(gòu)應與被編碼的data相一致,解碼后內(nèi)容保存在to里面,直接使用to即可
func Decode(data []byte, to interface{}) error { buf := bytes.NewBuffer(data) dec := gob.NewDecoder(buf) return dec.Decode(to) }使用的時候:
b, err := Encode(data) if err != nil { //錯誤處理 } if err := Decode(b, to); err != nil { //錯誤處理}
golang語言本身就是c的工具集,開發(fā)c的程序用到的大部分結(jié)構(gòu)體,內(nèi)存管理,攜程等,golang基本都有,他只是在這個基礎上又加了一些概念這里說一個很小的問題,就是字節(jié)數(shù)組轉(zhuǎn)string的問題,網(wǎng)上大部分都是這樣轉(zhuǎn)的(包括google上):string(p[:]),這個轉(zhuǎn)完了是有問題的,我們再來看一下string這個結(jié)構(gòu)體:
struct String
{
byte* str;
intgo len;
};
這個結(jié)構(gòu)體讓我想起了nginx的string,他是這樣定義的:
typedef struct {
size_t len;
u_char *data;
} ngx_str_t;
golang里邊 string的概念其實不是以前遇到\0結(jié)尾的概念了,他其實就是一塊連續(xù)的內(nèi)存,首地址+長度,上面那樣賦值,如果p里邊有\(zhòng)0,他不會做處理這個時候,如果再對這個string做其他處理就可能出問題了,比如strconv.Atoi轉(zhuǎn)成int就有錯誤,解決辦法就是需要自己寫一個正規(guī)的轉(zhuǎn)換函數(shù):
func byteString(p []byte) string {
for i := 0; i len(p); i++ {
if p[i] == 0 {
return string(p[0:i])
}
}
return string(p)
}
這樣就不會出問題了