当前位置: 首页 > news >正文

Go代码解密:理解byte和int8的边界行为

今天看到一个很有意思的 Golang 代码,最后的输出结果为 4

func main() {count := 0for i := range [256]struct{}{} {m, n := byte(i), int8(i)if n == -n {count++}if m == -m {count++}}fmt.Println(count)	// 输出为 4
}

原因如下

  1. i = 0 时,n == -nm == -m 成立,count+2
  2. i = 128 时,n == -nm == -m 成立,count+2
  • 当 i = 128,因为 n 是 int8,所以 n = (1000 0000)2,即 -128。而 -n 则为
    (1000 0000)2 的补码(即先取反码再加1),即 -> (0111 1111)2 -> (1000 0000)2,也是 -128,结果相等。
  • 当 i = 128,因为 m 是 uint8,所以 m = 128,而 -m 则因为 m 为 uint 类型,所以需要对负数 -m 进行求余,最终结果为 (-m) = (-128 % 256) = 128,结果相等。

所以,最终 count 的值为 4。

http://www.lryc.cn/news/206017.html

相关文章:

  • Mac M1下使用Colima替代docker desktop搭建云原生环境
  • Non-constant range: argument must be an integer literal
  • TCP网络通信
  • echarts中,X轴名称过长隐藏,鼠标hove显示全称
  • laravel框架介绍(二) 打开站点:autoload.php报错
  • reactNative导入excel文件
  • mysql 命令行安装
  • JAVA基础知识Fundamental
  • 民宿如何经营与管理?【民宿小程序】
  • 用 Rust 和 cURL 库制作一个有趣的爬虫
  • 华为OD 走方格的方案数(100分)【java】A卷+B卷
  • postgresql|数据库|序列Sequence的创建和管理
  • (完全解决)如何输入一个图的邻接矩阵(每两个点的亲密度矩阵affinity),然后使用sklearn进行谱聚类
  • Unity中Shader的ShaderLOD
  • 图像压缩(4)《数字图像处理》第八章 8.3节 数字图像水印
  • C++之lambda匿名函数总结(二百四十五)
  • STM32F103单片机内部RTC实时时钟驱动程序
  • ChinaSoft 论坛巡礼 | 开源软件生态健康度量论坛
  • Leetcode.2698 求一个整数的惩罚数
  • 大数据Flink(一百零二):SQL 聚合函数(Aggregate Function)
  • 因mapjoin加载内存溢出而导致return code 3
  • pip 指定源
  • 嵌入式中的MCU、ARM、DSP、FPGA
  • 二、PHP基础学习[变量]
  • k8s kubeadm配置
  • B-3:Web安全之综合渗透测试
  • 设计模式—设计模式总览
  • C++ 流程控制(分支、循环、跳转)
  • 【网络协议】聊聊TCP的三挥四握
  • Docker镜像仓库