news 2026/4/16 14:49:17

每日八股——Go(4)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
每日八股——Go(4)

gRPC是什么?

gRPC(Google Remote Procedure Call) 是一个由谷歌开发的高性能、开源的RPC(远程调用)框架。简单来说,他的核心目的是:让你调用远程服务器上的函数(方法),就像调用本地代码里的函数一样简单。
他主要用于微服务架构,帮助不同服务器之间(甚至不同语言写的服务)进行高效沟通

gRPC的核心两大支柱

gRPC能再性能和体验上超过传统RESTful API,主要归功于:
1、Protocol Buffers(Protobuff)——数据怎么存
这是gRPC默认的序列化机制(类似于XML和JSON,但更强)

- 二进制格式:Protobuf将数据序列化为二进制流,比文本格式(如JSON)体积小得多,传输更快。 - 接口定义语言(IDL):你需要编写一个.Proto文件来定义数据结构和服务接口。 - 强类型:定义了.Proto后数据类型就是严格确定得了,减少了字段拼写错误或类型不匹配带来的Bug

2、HTTP/2——数据怎么传
gRPC建立在HTTP/2协议之上,赋予了它许多HTTP/1.1(REST常用协议)不具备的能力:

- 多路复用:一个TCP可以同时处理多个请求,无需排队。 - 头部压缩:使用HPACK算法,依赖静态字典、动态字典、哈夫曼编码进行压缩,减少了数据传输量。 - 双向流:客服端服务端可以同时、实时地双向发送数据流。

sync.map的底层原理

sync.map是go在1.9引入并发安全Map,核心设计理念是用空间换时间与读写分离。它并不适合所有场景,而是为了读多写少与Key值稳定(大部分操作是更新现有Key而不是插入新Key)优化的。
1、核心结构:两个Map(Read&Dirty)+misses计数+amended标记

read map(只读/快路径):基于atomic操作,访问它不需要加锁,如果能在read里找到数据,性能极高。

dirty map(脏/慢路径):普通的map,包含了read中没有的新键、需要更新/删除的键以及read的可迁移的键,访问必须加锁。

misses技术: 记录“读操作在 read 没命中但去 dirty 找到了”的次数,用于触发迁移。

amended 标记(在 read 里):表示 dirty 中存在 read 没有的键;读 miss 时才需要查 dirty。

2、提升机制(promotion)
当读请求经常在 read miss、但在 dirty 命中,说明 dirty 里的数据已经变“热”,继续让读去 dirty 会导致频繁加锁。 此时misses达到了某个程度,会在持锁下把 dirty 提升为新的 read ,将dirty清空,amended复位,将misses清零。

new和make的区别

Go 里,new 和 make 都用于“创建”,简单来说,new只负责分配零值内存,创建后无法直接使用,而make负责分配并初始化,具体来说,他们的面向的对象不同、返回类型不同、底层行为也不同。

1、面向对象不同

  • make只能用于slice、map、channel三种引用类型。
  • new可以用于任意类型(基本类型、结构体、切片、map 等),但他只分配内存,不负责复杂结构的初始化。

2、返回类型不同

  • make(T,…)返回的是T类型本身(值),因为这三种类型在Go内部本质上是指针包装的结构体,直接返回值即可。
  • new(T)返回的是*T(指向该类型内存的指针)。

3、底层行为不同(核心)

  • new做的事Zeroed Storage(置零),他申请一块内存,将内容全部清零(0,nil,false),然后返回指针。
  • make做的事Initialization(初始化),因为slice/map/channel底层结构很复杂,光是清零是没法使用的,必须经过特定的初始化流程,如果只是new了这三种类型,直接使用会panic。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 13:05:23

灌区PLC阀门远程监控运维系统方案

一、项目背景灌区作为农业用水的重要区域,其水资源的合理分配与高效利用直接关系到农业生产的稳定与发展。传统灌区管理方式中,PLC阀门往往依赖人工现场操作与监控,存在响应速度慢、管理效率低、资源分配不均等问题。随着物联网技术的发展&am…

作者头像 李华
网站建设 2026/4/16 12:22:27

Kubernetes集群升级指南

前言本文演示kubernetes集群从v1.24.1升级到v1.29.15。一、集群升级过程辅助命令&#xff08;1&#xff09;查看节点上运行的pod。kubectl get pod -o wide |grep <nodename>&#xff08;2&#xff09;查看集群配置文件。kubectl -n kube-system get cm kubeadm-config -…

作者头像 李华
网站建设 2026/4/6 0:41:24

维智 MCP 接口服务技术支持指南

&#xff08;一&#xff09;服务概述 维智 MCP Server 基于标准化 MCP 协议&#xff0c;整合丰富地理信息数据&#xff0c;为智能体提供地点搜索、正 / 逆地理编码、IP 定位解析、天气查询四大核心能力。数据覆盖城市级、街道级、坐标级查询&#xff0c;支持 HTTP/SSE 双传输协…

作者头像 李华
网站建设 2026/4/16 14:32:19

制造企业如何打通“三链”协同?一文讲清

目录 一、概念区分 1.产业链 2.供应链 3.价值链 二、那么&#xff0c;不协同具体会带来哪些问题&#xff1f; 1.目标不一致导致的行动矛盾 2.部门之间的优化相互冲突 3.创新想法受制于现实条件 三、怎么才能推动协同&#xff1f; 第一步&#xff0c;从统一目标和评价…

作者头像 李华
网站建设 2026/4/16 11:00:45

【老毛桃WinPE启动盘制作全攻略,附镜像获取渠道】

经常遇到电脑蓝屏、系统崩溃、忘记开机密码的情况&#xff1f;别急着送修&#xff01;一个WinPE启动盘就能轻松解决这些问题。今天就给大家带来超详细的老毛桃WinPE启动盘制作教程&#xff0c;从工具准备到系统安装&#xff0c;每一步都讲得明明白白&#xff0c;零基础小白也能…

作者头像 李华
网站建设 2026/4/16 11:15:39

FlutterOpenHarmony商城App底部导航栏组件开发

前言 底部导航栏是移动应用中最常见的导航模式之一&#xff0c;它为用户提供了在应用主要功能模块之间快速切换的能力。在商城应用中&#xff0c;底部导航栏通常包含首页、分类、购物车、我的等核心入口&#xff0c;用户可以通过点击不同的标签页快速访问对应的功能模块。本文…

作者头像 李华