一期Go群问答-并发控制-数据竞争-错误与异常

news2024/11/15 13:41:26

每周更新Go技术交流群的群问答内容,有需要可发我Go加群讨论学习。

并发控制

waitGroup.done()不是必须写在main方法中吗? 为什么我的协程没有成功等待?

:如果用了wait group,请求就直接卡住了,如果只有一个goroutine那和直接调用函数没有区别其实。你是想请求立刻返回,然后其他数据稍后返回的话,用中间件比如kafka。或者用回调callback

错误现场

错误原因:没有能成功等待goroutine执行完,done要放goroutine里,外面是wait

参考用例

var wg sync.WaitGroup
sList := []string{"a", "b"}
wg.Add(len(sList))
for _, d := range sList {
        go func() {
            defer wg.Done()
            fmt.Println(d)
        }()
    }
wg.Wait()

数据竞争

如果不同的线程写同一个map的不同key内容是不是不用sync.Map了?会存在数据竞争吗?但是如果我make的时候提前指定容量呢?

:会影响的,估计map中的hmap会影响到,有几率会在运行时报错

机器马:你在用之前没法确定会用哪个key啊,除非你再用结构体封装一层

:我想到两个办法,1是用这个,还有一个是弄个channel,如果数据用途不一样,弄成结构体channel,用一个goroutine来接收他们。单独用一个线程来接受数据,go这个东西就是个语言,怎么好用怎么来,虽然一直是在推channel,但只要实现需求。

sync.Map为什么没有len测长度方法?

Mike: 看来有人也遇到这么问题,为杀map支持len(),而sync.Map不支持。有兴趣的可以看看issue. 简单说官方认为 map 本来就不应该有length的实现。

机器马: 2017年社区就在吵要不要加个len方法了。一般syncmap都不会单独使用,而是封装到结构体里,然后再写一层方法,所以一般就会在这一层做count,用原子操作计数。

追问sync.Map 这个Range 方法有个返回值,是bool是用来返回是否rangemap吗?range如何处理碰到到空的?

:这个bool是传入函数的返回值,调用完以后如果是Map是空的,实际上就什么也没做,不会给返回。里面给迭代,你传入的函数处理下k v的行了。没办法判断是否为空。

登陆验证

我们可以用UUID生成我们的token,为什么还要用jwt呢(redis中存储token和用户信息对应关系)?

Mike: 无状态 jwt不在服务端存储任何状态。RESTful API的原则之一是无状态,通过redis存储token和用户信息,违背了无状态原则。

Mike: JWT的优点:

  1. 可扩展性好 应用程序分布式部署的情况下,session 需要做多机数据共享,通常可以存在数据库或者redis里面。而jwt不需要。
  2. 无状态 jwt不在服务端存储任何状态。RESTful API的原则之一是无状态,发出请求时,总会返回带有参数的响应,不会产生附加影响。用户的认证状态引入这种附加影响,这破坏了这一原则。另外jwt的载荷中可以存储一些常用信息,用于交换信息,有效地使用 JWT,可以降低服务器查询数据库的次数。

Mike: 缺点:由于jwtpayload是使用base64编码的,并没有加密,因此jwt中不能存储敏感数据。而session的信息是存在服务端的,相对来说更安全。

:关于前端现实当前是哪个用户的问题,只需要后端把用户基本信息存cookie里就可以了。后端用token获取用户信息,把二者分离开。

:关于Mike所述的第一个优点,实际上也有弊端,因为必须等待token记录的时间到期,jwt才会判定token过期,服务端无法主动过期。也无法做多平台挤出登陆,类似于QQ那样子。
gtoken就是存redis

此用户名已被占用: jwt一般还要再加密吧?我记得是有rsa
:确实是要加密的

宋跑跑:签名加密?

此用户名已被占用: 难道不是吗? 不然token裸奔。

宋跑跑 (宋跑跑): 害 信息其实都能拿到了。

异常处理

go你们在项目中都是怎么异常处理的呀,java是抛出自定义有业务异常然后全局异常捕获?

张朝胤Golang不是if err=nil?全局try catch怎么处理?

Mikefmt. Errorf 可以包装多层错误,再用 errors.ls集中判断。没必要把java里面那一套带进Go,这两门语言的哲学本来就不一样。

宋跑跑recover

国玮exception != error,错误是错误 异常是异常,错误是可以考虑降级处理 不影响程序运行的 异常反之。例如最常用的 error 级别,Go 语言贡献者 Davio 认为,对错误进行降级处理后,应该打印 info 级别的日志,这意味着我处理了错误,或者往上抛并 warp 它。不过我不是很赞同这个观点 infoerror 的处理是完全不同的。错误就该打出来。

国玮: 对于错误 其实Go的哲学就是 error is value,你把它当做一个值来处理,exception 是那种会让程序崩溃的,崩溃恢复用recover就行。

吆吆好叼啊:可以这么理解吗?service层出现异常直接返回,controller层调用service层方法进行处理,如果出现错误,controller层返回前端自定义异常json数。

国玮: 可以,调用者处理错误。不需要像java那样抛出业务异常,有个专门的对controller层处理的异常处理类。但是这句话里面,要注意,是错误,不是异常!要弄清楚它们的概念呀。

国玮Java 中的异常,是可以继承的,那么就是说父 exception 可以接收一切 子 exception,这就没有做到细分。

国玮: 错误可以用 Wrap 一层一层往上抛(error std lib 的一个方法),大概意思就是 Warp 去包装错误,为错误提供更多的“证据”和“线索”,但是并没有真正的处理错误,处理错误本质上还是交给调用者。

Mike: 其实很灵活的,对于错误处理完全看业务需要,有些错误可以跳过,有些不行,必须得返回。

国玮: 嗯嗯,在实际编码中,确实是这样的,不过 Dave 认为,如果你对错误不关心,那么你也不应该关心它返回的值。可能是提醒我们要谨慎吧!

其他

大家有go 单体项目推荐吗,我阅读阅读(最好是格式规范)?

https://github.com/golang-standards/project-layout

本文由mdnice多平台发布

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/176377.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux C编程一站式学习笔记5

Linux C编程一站式学习笔记 chap5 深入理解函数 文章目录Linux C编程一站式学习笔记 chap5 深入理解函数一.return语句习题二.增量式开发三.递归我猜有递归可视化工具,一搜果真有收获习题GCD(Greatest Common Divisor) 最大公约数Fibonacci相关资源、参考资料嘶&…

在linux中安排mysql

linux安装mysql 检测当前系统中是否安装Mysql数据库 rpm -qa rpm -qa|grep mysql rpm -qa|grep mariadb没有输出就是没有安装 我的这里显示mariadb是安装了的(会与mysql冲突) 卸载已经安装的软件 rpm -e --nodeps 软件名称 rpm -e --nodeps mariadb-li…

什么是执行董事

一、什么是执行董事执行董事,是指参与经营的董事。作为法定意义上的执行董事,是指规模较小的有限公司在不设立董事会的情况下设立的负责公司经营管理的职务。作为上市公司意义上的执行董事,执行董事并没有明确的法规依据。执行董事和非执行董…

偷偷理解Java和Scala中==和equals()的区别

君霸王,社稷定,君不霸王,社稷不定🥽 目录 Java总结 Scala总结 Java中和equals() ---------------------------------------------------------------------------------------------------------------------------------------…

【人工智能原理自学】卷积神经网络:图像识别实战

😊你好,我是小航,一个正在变秃、变强的文艺倾年。 🔔本文讲解卷积神经网络:图像识别实战,一起卷起来叭! 目录一、“卷”二、LeNet-5网络一、“卷” 这节课我们来看如何把卷积运算融入到神经网络…

【青训营】Go语言的基本语法

一、 配置Go语言及其开发环境 Mac配置:http://t.zoukankan.com/zsy-p-6685889.html https://wenku.baidu.com/view/8aeec92b15fc700abb68a98271fe910ef12daeaf.html?wkts1673764660043&bdQuery%E5%A6%82%E4%BD%95%E9%85%8D%E7%BD%AEgopathmac 二、基础语法 p…

避免用Apache Beanutils进行属性的copy。why?让我们一起一探究竟。

在实际的项目开发中,对象间赋值普遍存在,随着双十一、秒杀等电商过程愈加复杂,数据量也在不断攀升,效率问题,浮出水面。 问:如果是你来写对象间赋值的代码,你会怎么做? 答&#xf…

05 |「链表」刷题

前言 前言:链表面试高频题。 文章目录前言一. 基础回顾二. 高频考题1. 例题1)题目链接(LeetCode 206 反转链表)2) 算法思路3)源码剖析4)时间复杂度2. 习题一. 基础回顾 参考上一讲: …

线性代数[向量]

系列文章目录 第一章 线性代数[初等变换(一)] 第二章 线性代数[初等变换(二)] 第三章 线性代数[初等变换(三)] 第四章 线性代数[矩阵的秩] 提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 一.引入 二.向…

计网必会:运输层概述、网络层介绍、TCP、UDP、多路复用、多路分解

文章目录运输层概念回顾TCP 和UDP概述介绍网络层TCP UDP网络层的联系多路复用和多路分解多路复用和多路分解的中国话理解TCP的多路复用和多路分解与UDP的区别HTTP 会话Web服务器和TCPUDP的多路复用和多路分解源端口号的用处的中国话理解UDP套接字无连接运输UDP 的优势运输层概念…

【C语言进阶】指针进阶(详细版)

目录 一、字符指针 二、指针数组 三、数组指针 1、数组指针的定义 2、&数组名和数组名的区别 3、数组指针的使用 四、数组传参和指针传参 1、一维数组传参 2、一级指针传参 3、二维数组传参 4、二级指针传参 五、函数指针 1、函数指针的定义 2、函数指针的使用 六、…

如何与他人交流

上期我们讲了打破预期,顺应主体,我的别人交流,只有在不把别人当成对象(工具人),而是把对方当成主体的情况下(让别人感受到尊重),这是相互尊重的终极本质,也是唯一方法.把别人当人看.认同对方,对方也会认同你.自信从何而来自信本意为相信自己,所以自信本应该是由内而外的事物,但…

【MySQL进阶】MySQL事务详解

序号系列文章5【MySQL基础】字符集与校对集详解6【MySQL基础】MySQL单表操作详解7【MySQL基础】运算符及相关函数详解8【MySQL基础】MySQL多表操作详解文章目录前言1,事务概念2,事务四大特性2.1,原子性2.2,一致性2.3,隔…

ORB SLAM3 ubuntu18.04 ROS 运行 段错误 (核心已转储) 踩坑及解决

问题猜测及解决:opencv版本兼容性 项目版本:ORB SLAM3 V1.0版本 CPU:13600K (大小核架构不知是否会影响) 电脑环境:ubuntu18.04 ROS运行 相机:D435 i opencv版本:3.2 and 4.6 前提:编译无报错&a…

Java 23种设计模式(3.创建者模式-原型模式)

1.概述 用一个已经创建的实例作为原型,通过复制该原型对象来创建一个和原型对象相同的新对象。 2.结构 原型模式包含如下角色: 抽象原型类: 规定了具体原型对象必须实现的的 clone() 方法。 具体原型类: 实现抽象原型类的 clon…

多线程(5)

文章目录前言 :常见锁策略了1.悲观锁 VS 乐观锁2. 轻量级锁 VS 重量级锁3.自旋锁 VS 挂起等待锁4. 读写锁 VS 普通的互斥锁5. 公平锁 和 非公平锁6. 可重入锁 VS 不可重入锁CAS1. CAS 的应用场景2. CAS 的典型问题 : ABA 问题synchronized 原理1.锁升级 / 锁膨胀2.锁…

Ae 效果详解:发光

效果/风格化/发光Effects/Stylize/Glow发光 Glow效果可找到图像中的较亮部分,然后使那些像素和周围的像素变亮,以创建漫射的发光光环。可以创建两种颜色(颜色 A 和颜色 B )之间的渐变发光,并可通过复制发光效果以创建更…

RESTful开发风格 与 SpringMVC跨域访问

RESTful REST:表现层状态转换,资源在网络中以某种表现形式进行状态转移RESTful 是基于 REST理念 的一套开发风格,是具体的开发规则,如果一个架构符合REST 原则,就称为 RESTful 架构。 RESTful 开发规范:…

【leetcode】学了栈和队列却觉得无用武之地?试试这几道题目吧!

目录 0.写在前面 1.leetcode.20 有效的括号 2.leetcode.225 用队列实现栈 3.用栈实现队列 4.设计循环队列 0.写在前面 这些题目所用语言为C语言,由于C语言未提供栈和队列的数据结构,所以需要我们手动实现栈和队列。此外熟练掌握栈和队列的性质对解…

【C++】从0到1入门C++编程学习笔记 - 实战篇:职工管理系统

文章目录一、需求分析二、创建项目2.1 创建新项目2.2 添加文件三、创建管理类3.1 创建文件3.2 头文件实现3.3 源文件实现四、菜单功能4.1 添加成员函数4.2 菜单功能实现4.3 测试菜单功能五、退出功能5.1 提供功能接口5.2 实现退出功能5.3 测试功能六、创建职工类6.1 创建职工抽…