news 2026/4/18 12:41:35

每日八股——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/18 12:32:51

实际项目开发应用--485通信

一、485通信波特率的选择 长距离485Modbus通信时,波特率设置“小点更好” ——核心原则是“优先保证通信稳定性,再兼顾效率”,高波特率会加剧信号衰减、抗干扰能力下降,反而容易出现丢包、误码;低波特率虽通信速度慢&a…

作者头像 李华
网站建设 2026/4/18 7:55:57

【JavaSE】十八、URL HTTP请求格式 常见报头 状态码 会话保持

文章目录Ⅰ. URLⅡ. 报文格式Ⅲ. HTTP 请求方法💥 GET 和 POST 的区别Ⅳ. HTTP 常见报头Ⅴ. HTTP 状态码Ⅵ. 会话保持一、Cookie二、Session三、两者区别四、理解 cookie、session、token 三者的区别Ⅰ. URL 统一资源描述定位符 URL(Uniform Resource L…

作者头像 李华
网站建设 2026/4/18 8:34:36

车间每天报喜不报忧,直到真 OEE 摆上墙,谁都装不下去!

目录 一、车间数据造假,到底有多日常? 1. 停机时间“自动消失” 2. 产量“向上取整”,报废“向下取整” 3. 点检表天天签,谁也没看过 二、为什么大家宁愿造假,也不愿报真实? 1. 指标只考结果&#xf…

作者头像 李华
网站建设 2026/4/18 10:05:57

python3.7-python3.12通过whl安装dlib

1、安装Cmakepip install cmake2、安装boostpip install cmake3、通过whl文件安装dlib下载链接中包括python3.7-python3.12版本对应的dlib库例如我的python版本是3.12,在.whl下载路径下,输入以下指令安装pip install dlib-19.24.2-cp312-cp312-win_amd64…

作者头像 李华
网站建设 2026/4/18 11:06:38

合并区间(二维vector使用,多维vector使用默认sort)

注意点&#xff1a; 1.sort自带的比较函数是支持多维数组比较的&#xff0c;使用的是字典序比较&#xff1b; 2.对于多维的vector&#xff0c;可以使用back&#xff0c;front,at等函数 比较例子&#xff1a; 二维 vector 示例 vector<vector<int>> v {{2,5},{1,3}…

作者头像 李华
网站建设 2026/4/18 5:54:57

ubuntu远程rdp连接屏幕分辨率太小

# 切换root权限 sudo -i # 编辑XRDP的会话配置文件 nano /etc/xrdp/startwm.sh在文件的最顶部&#xff08;#!/bin/sh下面&#xff09;添加一行分辨率配置&#xff08;比如设置为 1920x1080&#xff0c;可根据需求调整&#xff09;&#xff1a;bash运行# 设置XRDP默认分辨率&…

作者头像 李华