V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
ufo5260987423
V2EX  ›  程序员

大家读的最好的技术文章是什么样的?

  •  
  •   ufo5260987423 ·
    ufo5260987423 · 2023-03-23 08:50:49 +08:00 · 6009 次点击
    这是一个创建于 615 天前的主题,其中的信息可能已经有所发展或是发生改变。

    最近打算写一系列博文从工程上介绍 type inference 的实现机制。 如果有熟悉这方面的朋友可能知道,这部分文章国内外要么是学术掉书袋,要么是梗概概括性质的。很少有从工程的直觉去写的,中文互联网有其少。

    基于此,我打算按照这样的逻辑去写: 1 、广泛引用我看过的“掉书袋”和“梗概”,按照他们可能的工程实现思路去组织文字,而不是按照他们使用的语言或者理论去组织。 2 、使用对比的方式,从多个层次指出实现机制在工程上的具体区别。 3 、让读者能够自行编码去尝试。这个方面由于我有一个开源项目scheme-langserver,可以让读者顺着我的项目去理解,甚至能够提交 request 实现读者想要的特性。

    因此,很重要的一个方面是:大家读过什么好的技术文章,请把网址发出来。最好同时说明它在什么方面的特点让你觉得印象深刻。

    31 条回复    2023-12-03 17:39:08 +08:00
    getadoggie
        1
    getadoggie  
       2023-03-23 09:02:41 +08:00 via iPhone   ❤️ 5
    记得看过 tailscale 官博写的内网穿透的原理文章,把内网穿透的原理从头到尾写的非常详细和完整,有条理,给我印象比较深刻,建议可以参考一下
    723X
        2
    723X  
       2023-03-23 09:10:33 +08:00 via Android   ❤️ 2
    iyzm.net

    openwrt 日常折腾,都是精选的教程,逻辑清晰,容易上手,大标题和分段看着舒服,而不是又臭又长,不过这个比较适合小白。
    boatrain1111
        3
    boatrain1111  
       2023-03-23 09:10:58 +08:00   ❤️ 3
    vivipure
        4
    vivipure  
       2023-03-23 09:18:44 +08:00
    vsitebon
        5
    vsitebon  
       2023-03-23 09:26:36 +08:00   ❤️ 2
    一种是技术文章: https://pomb.us/build-your-own-react/ 交互式教程
    一种是科普文章: https://ciechanow.ski/gps/ 我认为我看过的最好的科普文章(之一,因为这人写了好几篇介绍不同技术的文章)
    NessajCN
        6
    NessajCN  
       2023-03-23 09:27:23 +08:00
    archwiki
    ruoxie
        7
    ruoxie  
       2023-03-23 09:39:06 +08:00
    最近看的话,是 chatgpt 给的,因为全网根本搜不到,内容:整洁架构中如何使用 react-query
    Kontinue
        8
    Kontinue  
       2023-03-23 09:49:25 +08:00
    从头到尾能够连贯的讲清楚一个东西的就是好文章
    yunyuyuan
        9
    yunyuyuan  
       2023-03-23 10:19:01 +08:00
    谷歌有一篇关于写技术文章的教程 https://developers.google.com/tech-writing/overview
    zhuangjia
        10
    zhuangjia  
       2023-03-23 10:28:41 +08:00
    收藏了,虽然不一定会看。楼主提了一个好问题~
    jmc891205
        11
    jmc891205  
       2023-03-23 11:16:40 +08:00
    Inverse lithography technology: 30 years from concept to practical, full-chip reality, Journal of Micro/Nanopatterning, Materials, and Metrology, Vol. 20, Issue 3, 030901 (August 2021). https://doi.org/10.1117/1.JMM.20.3.030901
    assiadamo
        12
    assiadamo  
       2023-03-23 11:32:29 +08:00
    https://draveness.me/
    但好久没更新了
    getadoggie
        13
    getadoggie  
       2023-03-23 11:41:30 +08:00 via iPhone
    @boatrain1111 对,当时看的中文翻译版,有分块的目录
    tigerstudent
        14
    tigerstudent  
       2023-03-23 11:44:42 +08:00   ❤️ 2
    @getadoggie #13
    @boatrain1111 #3
    看来是这篇?
    https://arthurchiao.art/blog/how-nat-traversal-works-zh/
    sadfQED2
        15
    sadfQED2  
       2023-03-23 12:05:50 +08:00 via Android
    https://redis.io/docs/

    redis 官方文档,从算法复杂度到每个命令怎么用,没有任何废话,清晰明了一看就懂。基本上没遇到过其他哪个项目写这么清晰的文档
    wheat0r
        16
    wheat0r  
       2023-03-23 12:11:19 +08:00
    能把是啥、为啥、咋办说清楚就够了
    yuruizhe
        17
    yuruizhe  
       2023-03-23 12:17:32 +08:00
    很喜欢这篇文章
    个人理由:机器学习入门经典,由简入繁,深度合适,刚好够用
    感觉算是技术类文章,可能偏理论一点?
    https://zhuanlan.zhihu.com/p/24709748
    ho121
        18
    ho121  
       2023-03-23 12:19:42 +08:00 via Android
    我认为最好的是 man pages 和 msdn
    veike
        19
    veike  
       2023-03-23 12:31:39 +08:00 via Android
    @sadfQED2 还有 WordPress 文档,我感觉 WordPress 成功的因素之一就是详细的问题,没有文档的项目无人问津
    samin
        20
    samin  
       2023-03-23 12:33:06 +08:00
    AWS 官方相关产品指导文档
    阿里云官方相关产品指导文档
    mascteen
        21
    mascteen  
       2023-03-23 12:46:52 +08:00 via Android
    确定主题 确定结构 填充内容 反复修改
    ufo5260987423
        22
    ufo5260987423  
    OP
       2023-03-23 13:16:20 +08:00
    @yuruizhe #17 它们不是偏理论,它们只是没涉及工程直觉。
    或者这么说吧,它们的关注点是帮你补充知识的漏洞,是告诉你怎么做,而不是告诉你为什么这样做。笑。
    这是这类文章必然采取的形式,但是不是一种直接作用于工程上的好的形式。而我想要讨论的是后一种。
    getadoggie
        23
    getadoggie  
       2023-03-23 13:34:22 +08:00 via iPhone
    @tigerstudent 对的,就是这篇😂
    InkStone
        24
    InkStone  
       2023-03-23 13:57:30 +08:00
    我感觉最好从历史沿革开始写,讲清楚每个步骤引入之后的变化,但不要过多采用比喻之类的手段,还是要落实到实践上。

    同时把笼统的原理和过于具体的实现细节分开讨论。

    没有例子可以举,这是看别的体系的书得出的结论
    liuzhedash
        25
    liuzhedash  
       2023-03-23 14:00:22 +08:00
    vimtutor
    ufo5260987423
        26
    ufo5260987423  
    OP
       2023-03-23 14:14:51 +08:00
    @InkStone #24
    我提一点,不是从历史沿革开始写,而是抓住最根本的问题,从工程直觉开始写。这就有几点要抓住:

    1 、问题随时间演变,所以解决的方法也要变——但是工程直觉,所谓面多了加水水多了加面必须要写清楚,这样读者才能意识到,在直觉背后,自己缺少什么知识。

    2 、工程直觉不能直接解决的问题,更多的呈现为某种技巧。不能假设读者自我发明这些技巧,而是要假设读者如何通过其他领域的工程直觉层层累积最后捅破窗户纸——这就要在叙述上有重点地去叙述。

    3 、叙述上的重点包括应用场景、案例、以及思考过程的三个约束:逻辑链条长度,知识积累,和语言技巧。这里就响应了您关于“比喻”、“实践”和“细节”的问题。

    以上三点的关系在于要把直觉放到第一位,能把握住更多的直觉,就能够降低后面特别是第三点的难度。
    charlie21
        27
    charlie21  
       2023-03-23 16:04:45 +08:00
    “函数是一等公民”背后的含义
    https://blog.leapoahead.com/2015/09/19/function-as-first-class-citizen/
    直接聊清楚了纯函数为什么好测试(因为没有副作用),JavaScript 与函数式编程

    此外,它预测到在推广一个 library 的时候,如果它在突出自己的纯函数概念,那么这个库给人的感觉就是它会 “非常好学”:借由纯函数概念,它十分容易建立起一个十分简约的心智模型。这种 “简约” 的感觉仿佛写 java 者 见到 Stream API ,写 C# 者见到 LINQ:这些函数式编程的应用一旦出现在 SDK 里它会带来一种 “解放大脑” 的感觉。

    然而一个依赖纯函数概念而变得流行的库,这种 “流行” 即流行度的获得呢几乎是一种 “作弊” :纵使它所依托的纯函数概念十分精巧,但从根本上看,在观察(抽象的)函数式编程本身的时候(如上文所示),上文的结论之一就是任何纯函数本身几乎是没用的 —— 除了测试起来好测、因为没有副作用所以写起来爽、“听起来好听” 这种心理因素

    精妙但无用!
    软件工程本身的复杂度、如何控制复杂度,难道就能被一句 “纯函数没有副作用” 就能抹平的吗?做梦
    软件工程关注点在哪里,这是不变的,也是一个人不能逃避的。简言之,作弊的甜头是会让一个人退步的

    即使你用了纯函数主打的库,你也可以写出一个难以维护的项目:是的,这个库就是依托纯函数概念的 react.js 。或许可以这么说,正因为在进入一个纯函数主打的库的生态里(即 react.js 生态),所以一个难以维护的项目是更容易诞生的。

    而且 react.js 本身将会如何变得臃肿是难以想象的!按照函数式编程本身推算,函数式编程只适合写工具类,而那些函数式编程的应用 比如 Stream API 和 LINQ 也就仅仅是工具类,它们是好工具,好就好在它是死的。而 react.js 是还在不停推出新版本的,它想干什么?

    而如上文所示,如何管理状态 / 副作用 / 复杂度,本身已经不是纯函数编程关注的重点了。在那个氛围里绕了一圈的人们将会回到起点
    ufo5260987423
        28
    ufo5260987423  
    OP
       2023-03-23 17:54:28 +08:00
    @charlie21 #27
    1 、你跑题了;
    2 、你对于函数式编程的理解我持保留意见。
    LXGMAX
        29
    LXGMAX  
       2023-03-23 18:18:56 +08:00
    微软的.NET 文档,真的想教会我使用
    反之 Google Android kotlin 文档看得一头雾水
    FENebula
        30
    FENebula  
       360 天前
    @ufo5260987423 这里的“工程直觉”是不是可以理解为对问题及其外延,在一定程度上通用的 know-how ?
    ufo5260987423
        31
    ufo5260987423  
    OP
       360 天前
    @FENebula #30
    是 know-how-to-know
    或者用搞哲学的那帮人的话来说,是认识论。我们做工程的,即使有的东西不知道,但是根据我们的经验我们必将知道。
    wir muessen wissen, wir wuerden wissen.

    举个例子,我做 scheme-langserver ,写了一个 DSL 用来做类型推断——在这个过程中,我重新“发明”了 gradual typing,soft type 等技术——当然最近写文档发现,其实学术界早就有了。但是他们的过程和我是完全独立的。

    我在理论上有很多欠缺,但是不妨碍我在工程上有办法弥补,这种办法很多情况下就是靠直觉的。也就是靠我所说的“工程直觉”。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3878 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 10:26 · PVG 18:26 · LAX 02:26 · JFK 05:26
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.