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

每日八股——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。
http://www.rkmt.cn/news/117491.html

相关文章:

  • QtC++定时3秒执行槽函数实战
  • 自动化运维利器Ansible
  • MyBatis-Plus 报错 Invalid bound statement(insert)?其实是 SqlSessionFactoryBean 踩坑了
  • Qt实现Ubuntu程序自动重启
  • 2025年12月食堂净化水处理设备,除铁锰水处理设备,反渗透水处理设备厂家榜:适配性与能耗双维度测评 - 品牌鉴赏师
  • 必看!方形与圆形油炸机挑选,这几个关键要点你得知道
  • 机器学习--逻辑回归
  • 29、Unix 文件操作与管理全解析
  • 第1节:项目性能优化(上)
  • 解析现代网络的“神经系统”—BGP-LS-SPF
  • win11使用KMS命令激活
  • 12月17日
  • 从零构建高性能KV存储服务器:架构设计与实现细节 - 指南
  • 项目实战05—XXX火力发电厂工业蒸汽量预测
  • iOS 应用发布流程中常被忽视的关键环节
  • AI agent 最新 进展
  • WSL2安装教程
  • 人才盘点驱动组织发展
  • PPT排版又丑又慢怎么办?这个“AI生成PPT”功能,3秒拯救你的PPT
  • 邻项交换贪心小记
  • 2025年12月对焊机厂家推荐:行业权威盘点与焊接设备品质红榜发布 - 品牌鉴赏师
  • 人才发展ℓℓ 人才盘点怎么做?这篇完全应用手册给出答案
  • 12月最新论文降AI率全流程,附免费降AI方法+降AI率工具
  • javascript: Convert Word documents (.docx files) to HTML
  • FPGA中的 LUT6
  • 基于SpringBoot+Vue的宠物代遛系统设计与实现
  • 【即插即用模块】AAAI2025 | 高频 + 空间感知!新 HS-FPN 让“极小目标”不再消失!SCI保二区争一区!彻底疯狂!!!
  • 【24h服务】微信公众号评论点赞好友能看到吗?微信留言点赞下单怎么取消? - 速递信息
  • 一个销售数据分析机器人的诞生:看 Dify 如何在 DMS 助力下实现自动化闭环
  • 模具管理系统新解:如何用数字化打通全生命周期,降本30%?