偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

編程一萬小時的反思

開發(fā) 前端
Matt Rickard 是在谷歌從事 Kubernetes 開源工作的開發(fā)者,主要負(fù)責(zé)構(gòu)建和維護(hù) Kubernetes 開發(fā)者工具,例如 minikube 和 skaffold。此外他還作為 Kubeflow 項目的維護(hù)者負(fù)責(zé)機(jī)器學(xué)習(xí)管道方面的工作。

Matt Rickard 是在谷歌從事 Kubernetes 開源工作的開發(fā)者,主要負(fù)責(zé)構(gòu)建和維護(hù) Kubernetes 開發(fā)者工具,例如 minikube 和 skaffold。此外他還作為 Kubeflow 項目的維護(hù)者負(fù)責(zé)機(jī)器學(xué)習(xí)管道方面的工作。

根據(jù) Matt 的介紹,他已刻意投入了一萬小時用于訓(xùn)練編程技能。Matt 擁有大約 15 年的編程經(jīng)歷,目前在谷歌 Kubernetes 和私募股權(quán)公司 Blackstone 擔(dān)任專業(yè)軟件工程師。在此之前,Matt 在大學(xué)的大部分時間都在圖書館為自己的項目編寫程序。而在更早之前,他嘗試過各種各樣的事——在 RuneScape 上運行一個僵尸網(wǎng)絡(luò)、為 iPhone 編寫一個拉丁語翻譯應(yīng)用、編寫自己的配置語言、創(chuàng)建一個網(wǎng)絡(luò)剪輯器,或者深度定制自己的桌面環(huán)境。

在這一萬小時的編程訓(xùn)練中,Matt 最近的工作與分布式系統(tǒng)相關(guān),但他曾經(jīng)編寫過許多技術(shù)棧的代碼。編程語言方面使用過 PHP, JavaScript, Go, Ruby, Python, C#, Java, Swift,技術(shù)領(lǐng)域曾涉獵過前端、后端、移動端、內(nèi)核、云、運維等。他還曾參與過像 Kubernetes 這樣的大型開源項目,并維護(hù)過子項目。

對于編程一萬小時的反思,Matt 強(qiáng)調(diào)這次的總結(jié)是純粹的關(guān)于編程的思考,不會討論技術(shù)管理、職業(yè)發(fā)展相關(guān)的話題。

以下就是 Matt 編程一萬小時后的 31 條反思:

  • 閱讀源代碼常常會比在 Stack Overflow 上更快找到答案
  • 大多數(shù)情況下,如果你正在做的事情無法在互聯(lián)網(wǎng)上找到答案,那么這通常意味著這個問題很難或者很重要,或者兩者都是
  • 盡可能多地刪除代碼
  • 語法糖通常是不好的
  • 簡單往往是最難的
  • 擁有各種各樣的工具,并知道該用哪些工具來完成工作
  • 了解最常用的工具的內(nèi)部結(jié)構(gòu),如 git 和 bash
  • 為重復(fù)的工作流程構(gòu)建自己專用的工具
  • 從最好的資料中進(jìn)行學(xué)習(xí)(這里 Matt 舉例稱他在學(xué)習(xí) Go 時閱讀了標(biāo)準(zhǔn)庫)
  • 如果代碼看起來很丑,那很可能是一個嚴(yán)重的錯誤
  • 如果必須編寫不是文檔字符串 (docstring) 的注釋,則應(yīng)該考慮對這段代碼進(jìn)行重構(gòu)
  • 如果不了解所編寫的程序是如何在生產(chǎn)環(huán)境中運行的,那就說明不了解程序本身。優(yōu)秀的工程師知道他們的程序在各種環(huán)境中是如何運行的
  • 上面這條經(jīng)驗對于構(gòu)建管道也適用
  • 謹(jǐn)慎使用他人的代碼
  • 互聯(lián)網(wǎng)上找到的代碼大多數(shù)都很糟糕,有時候自己寫一個更好的版本會更容易
  • 永遠(yuǎn)不要直接依賴自己可以輕松重寫的小型庫,或本應(yīng)很小的大型庫
  • 知道什么時候該打破規(guī)則。對于“不要重復(fù)自己”這種規(guī)則,有時候重復(fù)比使用依賴要好
  • 將代碼組織成模塊、包和函數(shù)很重要。了解 API 的邊界位置是一門藝術(shù)
  • 大多數(shù)情況下應(yīng)選擇最有效的工具,但也要選擇自己所知道的。Arch Linux 是現(xiàn)代開發(fā)者最高效的操作系統(tǒng)嗎?對我來說,是的,但對大多數(shù)人來說,可能不是
  • 避免圈復(fù)雜度 (Cyclomatic complexity)
  • 避免多層嵌套條件
  • 正確命名變量,這也是一門藝術(shù)
  • 雖然很少見,但有時報錯可能確實是編譯器的問題
  • 謹(jǐn)慎使用深奧的語言特性,但在應(yīng)該使用的時候還是要使用
  • 技術(shù)的傳播并不均衡對等。例如,前端開發(fā)者可以從負(fù)責(zé)底層技術(shù)的工程師那里學(xué)到許多東西,云工程師可從 JavaScript 開發(fā)者身上學(xué)到用戶體驗和可用性方面的知識。但反過來卻未必成立
  • 因此,不同類型的工程師看待世界的方式是不同的
  • 部分程序員的效率是其他程序員的 10 倍
  • 成為 10 倍程序員與 10 倍員工這兩者之間沒有相關(guān)性(或許是負(fù)相關(guān))
  • 好的 API 易于使用且難以誤用
  • 配置七邊形(Matt 自創(chuàng)的術(shù)語)從硬編碼值開始,到環(huán)境變量、CLI Flag、配置文件、模板化配置文件、DSL、通用 bash 腳本,再到硬編碼值。開發(fā)者應(yīng)了解這個七邊形中的各個位置。

  • 所有抽象層都是可改變的。如果遇到了根本性的問題,有時答案就是往下再抽象一層,不要局限于表面

本文轉(zhuǎn)自O(shè)SCHINA

本文標(biāo)題:編程一萬小時的反思

本文地址:https://www.oschina.net/news/154219/reflections-on-10000-hours-of-programming

資訊來源:https://matt-rickard.com/reflections-on-10-000-hours-of-programming/

責(zé)任編輯:未麗燕 來源: 開源中國
相關(guān)推薦

2016-10-28 11:55:10

2011-08-04 09:50:11

編程

2020-02-26 11:11:50

運維微盟系統(tǒng)故障

2021-12-21 10:26:39

交付項目Jira開發(fā)

2012-06-05 00:26:58

程序員

2016-01-18 10:06:05

編程

2015-12-03 09:02:22

掌握新事物100小時

2019-09-24 08:16:14

Reactor響應(yīng)式編程

2012-05-16 09:53:56

2012-08-03 09:51:55

程序員編程

2015-03-30 11:21:27

編程編程反思

2015-05-11 10:38:50

程序員編程問題

2019-05-09 14:42:41

安吉智能倉庫

2018-12-20 09:13:39

Linux服務(wù)器高并發(fā)

2020-03-02 11:14:32

技術(shù)周刊

2014-03-14 10:07:09

極限編程敏捷開發(fā)

2022-06-22 15:11:05

開發(fā)

2012-07-06 13:54:59

JavaScript

2012-02-07 11:20:50

360App Store

2012-03-22 15:15:58

微軟
點贊
收藏

51CTO技術(shù)棧公眾號