基于golang uint8、int8与byte的区别说明

简单说明

uint8与byte可以说是一样的,因为文档中有这样的定义:

The Go Programming Language Specification
Numeric types
uint8 the set of all unsigned 8-bit integers (0 to 255)
byte alias for uint8

也就是说,我们在需要将这两种类型转换为string的时候都是可以直接使用string()来进行的。

而int8的取值范围为-128~127,所以int8不能直接与uint8、byte进行直接转换。

举例

注:部分来源于网上

###uint8&&byte ###

package main
import (
 "fmt"
)
func ByteSlice(b []byte) []byte { return b }
func main() {
 b := []byte{71, 72}
 u8 := []uint8{98, 99}
 fmt.Printf("%v %v\n", b, u8)
 fmt.Println(ByteSlice(b))
 fmt.Println(ByteSlice(u8))
 fmt.Println(string(b))
 fmt.Println(string(u8))
}

output:

[71 72] [98 99]
[71 72]
[98 99]
GH
bc

###int8&&byte ###

因为两者间的类型及取值范围这些都不相同,不能直接进行转换。int8取值范围为:-128~127,如果要转化的话需要使用bytevalue=256+int8value

var r byte
var v int8
v = -70
if v < 0 {
 r = byte(256 + int(v))
} else {
 r = byte(v)
}

但是,实际上我们可以直接使用byte进行强制转换,因为byte会自动检测v原有类型,然后进行转换的。

var r byte
var v int8
v = -70
r = byte(v)

以此类推,如果要将[]int8转换为string,只需要一个for循环将每个字符转换为byte后就好办了。

注:如有觉得写的不好的地方欢迎随时指出

补充:Golang中int, int8, int16, int32, int64区别

猫哥写Golang过程中,遇到整数常用int,因为可以少打至少一个字符。 T_T

一直没有意识到其实各个int还是有区别的,起码是内存空间上的区别。

一段简单粗暴的程序,描述一下区别:

package main
import (
 "fmt"
 "unsafe"
)
func main() {
 var i1 int = 1
 var i2 int8 = 2
 var i3 int16 = 3
 var i4 int32 = 4
 var i5 int64 = 5
 fmt.Println(unsafe.Sizeof(i1))
 fmt.Println(unsafe.Sizeof(i2))
 fmt.Println(unsafe.Sizeof(i3))
 fmt.Println(unsafe.Sizeof(i4))
 fmt.Println(unsafe.Sizeof(i5))
}

输出结果:

8

1

2

4

8

真的想不到int型,反而是占空间最大的。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。如有错误或未考虑完全的地方,望不吝赐教。

(0)

相关推荐

  • golang类型转换组件Cast的使用详解

    开源地址 https://github.com/spf13/cast Cast是什么? Cast是一个库,以一致和简单的方式在不同的go类型之间转换. Cast提供了简单的函数,可以轻松地将数字转换为字符串,将接口转换为bool类型等等.当一个明显的转换是可能的时,Cast会智能地执行这一操作.它不会试图猜测你的意思,例如,你只能将一个字符串转换为int的字符串表示形式,例如"8".Cast是为Hugo开发的,Hugo是一个使用YAML.TOML或JSON作为元数据的网站引擎. 为什么

  • Golang 之区分类型别名与类型定义的方法

    一.类型别名(Type Alias).类型定义是什么? 类型别名 是 Go 1.9 版本添加的新功能.主要应用于代码升级.工程重构.迁移中类型的兼容性问题.C/C++ 语言中,代码的重构升级可以使用宏快速定义新的代码.Go 语言中并未选择通过宏,而是选择通过类型别名解决重构中最复杂的类型名变更问题. 在 Go 1.9 版本之前内建类型定义的代码如下: type byte uint8 type rune int32 在Go 1.9 版本之后内建类型定义的代码如下: type byte = uint

  • 详解golang中发送http请求的几种常见情况

    方式一 使用http.Newrequest 先生成http.client -> 再生成 http.request -> 之后提交请求:client.Do(request) -> 处理返回结果,每一步的过程都可以设置一些具体的参数,下面是一个最朴素最基本的例子: //question ???将stdout重定向为response信息??? package main import ( "fmt" "io" "net/http" &q

  • Go语言string,int,int64 ,float之间类型转换方法

    (1)int转string s := strconv.Itoa(i) 等价于s := strconv.FormatInt(int64(i), 10) (2)int64转string i := int64(123) s := strconv.FormatInt(i, 10) 第二个参数为基数,可选2~36 注:对于无符号整形,可以使用FormatUint(i uint64, base int) (3)string转int i, err := strconv.Atoi(s) (4)string转in

  • 基于golang uint8、int8与byte的区别说明

    简单说明 uint8与byte可以说是一样的,因为文档中有这样的定义: The Go Programming Language Specification Numeric types uint8 the set of all unsigned 8-bit integers (0 to 255) byte alias for uint8 也就是说,我们在需要将这两种类型转换为string的时候都是可以直接使用string()来进行的. 而int8的取值范围为-128~127,所以int8不能直接与

  • 基于golang的简单分布式延时队列服务的实现

    一.引言 背景 我们在做系统时,很多时候是处理实时的任务,请求来了马上就处理,然后立刻给用户以反馈.但有时也会遇到非实时的任务,比如确定的时间点发布重要公告.或者需要在用户做了一件事情的X分钟/Y小时后,EG: "PM:我们需要在这个用户通话开始10分钟后给予提醒给他们发送奖励" 对其特定动作,比如通知.发券等等.一般我接触到的解决方法中在比较小的服务里都会自己维护一个backend,但是随着这种backend和server增多,这种方法很大程度和本身业务耦合在一起,所以这时需要一个延

  • 基于Golang实现Redis协议解析器

    本文实现Redis的协议层,协议层负责解析指令,然后将指令交给核心database执行 echo database用来测试协议层的代码 https://github.com/csgopher/go-redis RESP协议 RESP是客户端与服务端通信的协议,格式有五种: 正常回复:以“+”开头,以“\r\n”结尾的字符串形式 错误回复:以“-”开头,以“\r\n”结尾的字符串形式 整数:以“:”开头,以“\r\n”结尾的字符串形式 多行字符串:以“$”开头,后跟实际发送字节数,再以“\r\n”

  • 基于python中staticmethod和classmethod的区别(详解)

    例子 class A(object): def foo(self,x): print "executing foo(%s,%s)"%(self,x) @classmethod def class_foo(cls,x): print "executing class_foo(%s,%s)"%(cls,x) @staticmethod def static_foo(x): print "executing static_foo(%s)"%x a=A(

  • 基于golang时间转换的问题

    一般在获取到时间字符串,需要将时间字符串格式化为golang的"time.Time"对象的时候,通常有2个函数,分别是. time.Parse(layout, value string) (Time, error) time.ParseInLocation(layout, value string, loc *Location) (Time, error) 两个函数相比,不一样的地方在于,Parse()函数解析的时候,会默为UTC时间,获取的Time对象转换为Unix()对象后,会比当

  • 基于js中this和event 的区别(详解)

    今天在看javascript入门经典-事件一章中看到了 this 和 event 两种传参形式.因为作为一个初级的前端开发人员平时只用过 this传参,so很想弄清楚,this和event的区别是什么,什么情况下用什么比较合适. onclick = changeImg(this)       vs     onclick = changeImg(event) <img src='usa.gif' onclick="changeImg(event)" /> <scrip

  • 基于Java中throw和throws的区别(详解)

    系统自动抛出的异常 所有系统定义的编译和运行异常都可以由系统自动抛出,称为标准异常,并且 Java 强烈地要求应用程序进行完整的异常处理,给用户友好的提示,或者修正后使程序继续执行. 语句抛出的异常 用户程序自定义的异常和应用程序特定的异常,必须借助于 throws 和 throw 语句来定义抛出异常. throw是语句抛出一个异常. 语法:throw (异常对象); throw e; throws是方法可能抛出异常的声明.(用在声明方法时,表示该方法可能要抛出异常) 语法:[(修饰符)](返回

  • 基于substring()和substr()的使用以及区别(实例讲解)

    在JavaScript中,通常会用到截取,那所谓截取呢,其实就是要获得被截取元素的某个位置到某个位置的内容,那么JS给我提供了substring和substr这两种方法: 这两种截取的方式有什么区别呢?直接代码演示: substring(a,b): a:表示起始位置 b:表示结束位置 !但是值得注意的是:截取时,截取内容当中包含了开始位置的元素,但是不包含结束位置的元素! 示例: function sub1(){ var str = 'javascript'; return str.substr

  • 基于Python中capitalize()与title()的区别详解

    capitalize()与title()都可以实现字符串首字母大写. 主要区别在于: capitalize(): 字符串第一个字母大写 title(): 字符串内的所有单词的首字母大写 例如: >>> str='huang bi quan' >>> str.capitalize() 'Huang bi quan' #第一个字母大写 >>> str.title() 'Huang Bi Quan' #所有单词的首字母大写 非字母开头的情况: >>

  • 基于numpy.random.randn()与rand()的区别详解

    numpy 中有一些常用的用来产生随机数的函数,randn()和rand()就属于这其中. numpy.random.randn(d0, d1, -, dn) 是从标准正态分布中返回一个或多个样本值. numpy.random.rand(d0, d1, -, dn) 的随机样本位于[0, 1)中. import numpy as np arr1 = np.random.randn(2,4) print(arr1) print('**********************************

随机推荐