V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  lesismal  ›  全部回复第 24 页 / 共 64 页
回复总数  1264
1 ... 20  21  22  23  24  25  26  27  28  29 ... 64  
2023-08-24 09:57:43 +08:00
回复了 voidmnwzp 创建的主题 程序员 一个有意思的现象: 关于逻辑运算符的求值顺序
@voidmnwzp 是的。go 和 c 的编译器还不是特别智能,如果是 cpp 编译器、很多不这么明显的逻辑也会优化得更屌
2023-08-23 23:56:12 +08:00
回复了 voidmnwzp 创建的主题 程序员 一个有意思的现象: 关于逻辑运算符的求值顺序
表达式里含有子表达式这种,通常是要先计算子表达式吧,如果多个子表达式、c 里好像是不规定多个子表达式的先后顺序而是依赖编译器厂商实现。
go 的表达式规则我没细看,但是 OP 这段代码如果按照先计算子表达式,并且编译器推断那就是对比 a==a ,所以编译器直接可以优化了,看下反汇编的代码就优化掉了的:
https://gist.github.com/lesismal/71a96904de3a878c6ff27dd36e8fd4af
明明是 golang 的 if err 更适合错误处理、鲁棒性,一帮习惯了 java 的人喷 golang if err 。
2023-08-13 17:56:28 +08:00
回复了 SoftTime 创建的主题 程序员 六年 c++游戏后端的迷茫与转行求建议
也可以转 go ,游戏行业也有不少团队用 go ,关键是 go 转 web 开发、cloud 、devops 各种都比较方便。

继续深挖 cpp 也可以,看运气了
2023-08-13 17:55:19 +08:00
回复了 SoftTime 创建的主题 程序员 六年 c++游戏后端的迷茫与转行求建议
@zerone0086 我猜 1 楼是知道你说的措辞技巧的,因为他已经用 “有个朋友” 开局了 😄
他 git 提交的 username 是 zhaoxiaojiebj01
他 github 用户名是 zhaoxiaojie0415

Contributors 是按照 git 提交的 username 统计,两个不一样、而且 github 上没有 zhaoxiaojiebj01 ,所以不行

linus 喷 github 这个好像不只一次了。随便伪造个 xx 的提交
2023-08-05 23:08:31 +08:00
回复了 sinxccc 创建的主题 Vim VIM 的作者 Bram Moolenaar 过世了
R.I.P
2023-08-04 23:23:50 +08:00
回复了 wkong 创建的主题 程序员 两个人, 8 年时间打磨,算工匠吗
之前 op 反馈就回踩 star 了
8 年不容易,赞!
2023-08-03 00:09:26 +08:00
回复了 lcingOnTheCake 创建的主题 程序员 2009 年至今,我技术进步的 3 个阶段
> 如果做技术主程到顶了。除非去做制作人,但是制作人大多数是策划

如果是游戏公司的 Java 服务端技术栈,那确实主程差不多到顶了,Java 能做的游戏类型是有限的。
2023-08-03 00:04:42 +08:00
回复了 tlerbao 创建的主题 程序员 几乎不用的腾讯 CDN 也被刷,欠费 200 块。
我当初就图便宜买了些国内云的节点,一些节点上什么服务都没部署,然后收到了被攻击的报警、建议购买它们的高防服务。
所以别以为是被“别人”刷了,刷你的人很可能就是服务于你的人。
2023-07-31 14:17:05 +08:00
回复了 sloknyyz 创建的主题 程序员 10k+ star 的项目也搞假开源
> 前端 10k star 不算 s 好,但也 z 很不算多。后端 star 可比这难获得得多了。

-> 前端 10k star 不算少,但也不算很多。后端 star 可比这难获得得多了。
2023-07-31 14:16:33 +08:00
回复了 sloknyyz 创建的主题 程序员 10k+ star 的项目也搞假开源
前端 10k star 不算 s 好,但也 z 很不算多。后端 star 可比这难获得得多了。

不要一竿子打死所有国内搞开源的啊,我们后端或者其他非前端领域很多人没拿开源搞收费挣钱这种啊
2023-07-26 22:41:18 +08:00
回复了 dog82 创建的主题 Java 安全 QA 说只允许 POST/GET 请求,其它的都不安全?
学了那么多年复杂的 CS 理论,反倒是连基本逻辑都越来越乱了,而且越来越像孔乙己。
真是,哎,可惜,可惜了
2023-07-26 22:36:53 +08:00
回复了 dog82 创建的主题 Java 安全 QA 说只允许 POST/GET 请求,其它的都不安全?
@Slurp

> 写个 C++ 写个 Rust 不会,复杂点的概念理解不能,学了个 Go 所谓「大道至简」天天的在这里怼天怼地怼空气。

看样子你不只是没教养,连逻辑都混乱。我都好奇了,我十几年前就在写 c/c++,因为它俩开发效率低产出慢,等你写完功能上线了市场都被别人占领完了才来搞 go ,怎么就不会 c++了。你这个逻辑推理能力是真的好强啊!

> 😁 喷个 b 人都能说我没教养,那后面还有更难听的呢。

你随口说别人是 b 人,并且表情还这么欢乐戏谑,那正好证明我说你没教养的逻辑是正确的呀。后面还有什么你尽管讲出来好了,我也乐于见识一下你素质到底有多低

> FrankHB 这种起码有点乐子

幻 他活在自己的语言律师的乐子里,这是他的自由。但是我可从没见他像你这样随口管别人叫 b 人。先抛开技术不谈,单就幻的素质教养就比你高出很多的。至于技术,他是偏学院也好理论也好,你是什么派别也好,我这种是实践派,技术不只是你对哪些语言语法达到多高的理解就有多高的社会贡献或者价值,你要是真造了什么牛逼语言造福一个领域和一大片程序员那也是你的丰功伟绩,但如果不是,可能还不如实践派的大伙对社会贡献来得实在。

而且既然看你口气也都是老年人了,那我也用因为觉得后辈不可期对未来失望而跟你在这生气了,最多你就是个顽古不化自以为是能玩弄一点编程语言艺术的小丑罢了,因为毕竟我没听说过哪位讲中文的大佬对某个编程语言领域做出了什么超凡脱俗的巨大贡献或者开拓。

所以也别扯犊子那些虚头八脑的,比如你可能喜欢像跟幻讨论问题的那些话题,我是实践派,要真论什么语言语法,那你牛逼我不懂那么多,我说的那些个也不是语言本身的,懒得跟你浪费口舌😁

> 反反复复 if err 是哪个语言。

天下也不是只有异常系统或者 rust 的那个什么来着或者其他一些这几种姿势是唯 N 审美,你不喜欢 if err ,喜欢的人多了去了,我只见 go 越来越多人喜欢,越来越多业务交给 go 做。
最简单的一点,那么多大厂搞它替换其他很多语言,合着你天下第一、别人那些大厂的技术大佬都不如你呗?那请你继续活在你自己的世界里自娱自乐吧,这样挺好的

偶尔出来像这样咬一口别人也没关系,我不介意


> 😁 你要喷设计模式,那我请你在 Go 里不用 Visitor 模式实现一下解析 AST 。
> 😁 你要喷 FP ,那我请你了解一下 Algebraic Effects 。
> 😁 你要喷 TCP ,那你先解决一下中国运营商阻塞 UDP 的问题。

这逻辑就更混乱了呀,如果一个东西是垃圾,还要让我去花更多时间去深入学习理解它,这不更是在浪费我的时间吗?
你门口遇到一坨狗屎,单观其形状颜色甚至临近被它气味熏到时就知道它是不好的了,难道你还真要上去吃几口深入研究下为什么它不好?

我这个人非常工程实践实用主义,我只原意把时间花在那些有利于工程实践的事情上。
所以拜托你不要以为自己读了点什么垃圾,就一定要别人也要学会这些垃圾然后再跟你讨论问题,太狭隘,太逻辑混乱!
简直莫名其妙,十分搞笑!

送你个词,沉没成本效应:沉没成本效应(Sunk Cost Effects)是指为了避免损失带来的负面情绪而沉溺于过去的付出中,选择了非理性的行为方式。
因为听你的口气,自是学了不少 CS 的知识,因为投入的太多舍不得放弃,所以在那自嗨得不行。

有这个能读明白那些垃圾知识(虽然垃圾,但毕竟也挺复杂)的智力水平,至少也是上过不错的学校,自己读瞎了却不自知,可惜了你还有和你类似的一种人了。

😁 😁 😁
2023-07-26 21:38:32 +08:00
回复了 dog82 创建的主题 Java 安全 QA 说只允许 POST/GET 请求,其它的都不安全?
@Slurp

这是我两个库:
https://github.com/lesismal/nbio
nbio 这个,截至目前 go 社区 poller 框架唯一支持 tls/http1.x/websocket ,poller 框架里性能也基本是不比其他任何一个低

https://github.com/lesismal/arpc
arpc 这个是我的 go rpc 框架,功能不只是 rpc 、支持的业务类型比 rpc 广泛得多,至于性能,你可以去看三方评测:
https://colobu.com/2022/07/31/2022-rpc-frameworks-benchmarks

我好奇你这种还有给你点赞的小子们都是什么技术水平和技术审美,你们回复这些内容时候自己把问题想明白了吗,你们觉得我这种是属于 b 人 的时候,你们自己对我说的那些垃圾理解到位了吗?

本来说了不再回复这个帖子了,一上来就看到个 b 人,真是后辈可期!
2023-07-26 21:31:35 +08:00
回复了 dog82 创建的主题 Java 安全 QA 说只允许 POST/GET 请求,其它的都不安全?
> 看到 Go 社区都是这种 b 人我就放心了

@Slurp 小子嘴巴放干净点。即使是讨论技术,你可以用观点来反驳,张嘴管别人叫 b 人 是从小家里大人不管教学校也不教吗?

另外,你技术是有多屌?你敢保证你自己喜欢的那些东西就是好的美丽的?
我上面提到的一众都是垃圾的东西,我都能喷出个所以然、为什么这些东西垃圾,只是喷了很多次懒得每次再打字说一遍罢了。

既然我不喜欢的那些东西看样子你都挺喜欢,那目测你只是个搬砖的罢了。

技术或者技术审美差也就算了,还没教养,而且还有好几个点赞的,真是一丘貉。
2023-07-26 00:10:15 +08:00
回复了 dog82 创建的主题 Java 安全 QA 说只允许 POST/GET 请求,其它的都不安全?
@Nazz 之前的帖子喷了不少,浪费时间,这个帖子我不继续回复了
https://www.v2ex.com/t/816040#reply90
https://www.v2ex.com/t/816040?p=2#L151
2023-07-25 23:48:34 +08:00
回复了 dog82 创建的主题 Java 安全 QA 说只允许 POST/GET 请求,其它的都不安全?
@Nazz
TCP 握手和断开、HTTP1.0 和 2.0 、Restful 、Actor 、函数式编程、设计模式。。。
这一大堆玩意的主要内容没一个好东西,都是垃圾
2023-07-10 22:13:14 +08:00
回复了 dyingfire 创建的主题 Go 编程语言 对于 go 来说,如何设计一个优雅的链式操作?
链式不直观清晰,不容易理解,链式本身就很丑。

总结:OP 什么破品味!少制造这种辣鸡封装!
2023-07-01 13:52:34 +08:00
回复了 Richard14 创建的主题 Go 编程语言 Go 语言学习中遇到的问题
挑几个来说

## 语言设计相关

> 3. defer 的概念非常有趣,也很符合 Go 的设计主旨,不知道 Go 语言中是否有类似 Python 中上下文管理器的工具(即实现打开文件时确保其使用后被关闭,上锁时确保使用后会开锁等操作)

既然知道 defer ,defer close/unlock 就可以了,不应该还有这种疑问。不同语言提供不同的东西,也没必要非得别人有啥就要 go 有同样的东西。
另外,比如 os.File 这种,即使不 defer close ,gc 时也会自动 close 、不至于泄露,只是可能不太及时,或者如果你的代码泄露了没有 defer 也没有 gc 才会副作用:
https://github.com/golang/go/blob/master/src/os/file_unix.go#L239

> 4. 从原理角度,如何理解 channel 的调用开销。使用 channel 传递数据究竟是一种廉价操作,还是昂贵操作,其究竟是否依赖锁?按我的理解它依赖于事件循环,每次激活后才会唤醒依赖它的协程,应该是无锁的,但是书里写它其实是有锁的,我不是很懂。

直接看源码吧,也可以配合一些别人的文章来看源码,比这种问答要认识的更清晰:
https://github.com/golang/go/blob/master/src/runtime/chan.go#L160
https://github.com/golang/go/blob/master/src/runtime/chan.go#L457

5. 如果 channel 有锁,通道通信相较于内存共享的优越性体现在哪里?

channel 适合业务层简单逻辑:你把它当成进程内的消息队列就可以了,与锁的区别主要是带容量、可以把逻辑串行化并去锁,用于异步、解耦之类的比较好。但简单的队列数据结构同步,channel 性能是不如锁的、而且用锁可以在当前上下文继续进行剩下的穿行逻辑,放到 channel 后则需要其他地方去异步从护理了,未必就是 channel 方便。
性能需要的场景,比如基础设施领域,锁仍然是主力,不能被 channel 替代。

> 6. 对于 string 的处理方式。我们都知道 string 通常是比看上去更复杂的数据结构,教学视频中看到的所有赋值和参数调用基本都是直接传值,实际情况是否如此,这是否意味着如果不加优化通常效率会很低?

你说的 string 传值只是 string 结构体定义的这个小结构体:
https://github.com/golang/go/blob/master/src/runtime/string.go#L232

并不是需要深拷贝 string 的 payload 然后再传值,所以相比于传指针开销并不算大

## 多线程调度相关

> 2. Go 的调度模型下,单个协程应该是很省的,但是如果我有一万个协程同时对一个 map 进行交互,此种情况下应该如何进行优化?(或者说 Go 应对此种场景时也并无特殊优势?)

1) 减小锁粒度:无非就是多加点 shard/bucket ,减小每个 map 元素数量,从而减小锁粒度
2) 提高并发度:1 )中处理后,就可以去多协程去搞每个 shard/bucket 的 foreach 了,典型的如广播场景,广播优化主要就几个点:避免写阻塞,降低锁粒度,提高并发度,批次发送

## 最佳实践相关

> 1. 通常情况下,Go 语言调查未知对象内部属性和方法的最佳实践是什么?

设计者应该根据需要设计数据结构,除了三方互接并且对方乱搞,为什么一定要依赖调查?绝大多数正常的业务领域,脑子拧巴的实现者才喜欢去猜、让自己或者让别人用奇淫巧计去实现需求
避免使用反射。

那些不理解甚至嘲讽 go 的大道至简的人,其实就是花了很多时间学会了很多其他语言的奇淫巧计,沉没成本效应,让这部分人舍不得放弃以前学的那些糟粕思维,然后惯性地用那些思维来思考 go ,然后才会有这些垃圾问题和需求。当然,我不否认少数时候 go 里也需要奇淫巧计,我自己也用。


其他问题好像多数偏于垃圾问题,不答了
1 ... 20  21  22  23  24  25  26  27  28  29 ... 64  
关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   878 人在线   最高记录 6679   ·     Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 · 31ms · UTC 20:33 · PVG 04:33 · LAX 12:33 · JFK 15:33
Developed with CodeLauncher
♥ Do have faith in what you're doing.