douqiaoru2583 2017-09-29 12:01
浏览 40
已采纳

将int转换为字节

var x uint64 = 257
var y int = 257
fmt.Println("rv1 is ", byte(x))        // ok
fmt.Println("rv2 is ", byte(y))        // ok
fmt.Println("rv3 is ", byte(257))      // constant 257 overflows byte
fmt.Println("rv4 is ", byte(int(257))) // constant 257 overflows byte 

It is strange.

All of them are converting int to byte,so all of them should be error.

But case 1,2 is ok!

How could be that?

  • 写回答

1条回答 默认 最新

  • duanou9739 2017-09-29 12:18
    关注

    Variable numeric values can be converted to smaller types, with the normal loss of the high bits.

    The compiler refuses to do this for constant values (that is clearly always an error). This is required by the spec (emphasize mine):

    Every implementation must:

    • Represent integer constants with at least 256 bits.
    • Represent floating-point constants, including the parts of a complex constant, > with a mantissa of at least 256 bits and a signed binary exponent of at least 16 bits.
    • Give an error if unable to represent an integer constant precisely.
    • Give an error if unable to represent a floating-point or complex constant due to overflow.
    • Round to the nearest representable constant if unable to represent a floating-point or complex constant due to limits on precision.

    These requirements apply both to literal constants and to the result of evaluating constant expressions.

    Consequently, if you change var x and var y to const x and const y, you get an error for all four cases.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 lammps拉伸应力应变曲线分析
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题
  • ¥30 python代码,帮调试,帮帮忙吧
  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建