主頁 > 軟體設計 > 漫談:一個作業兩年半的程式員的人生感悟

漫談:一個作業兩年半的程式員的人生感悟

2020-09-23 05:03:07 軟體設計

前言

從2018年畢業之后,到今天2020年9月19日,不知不覺間我已經作業了兩年零三個月了,先后入職了兩家公司,在這兩段作業經歷中,能夠感覺自己獲得了極大的成長,這個成長不僅僅是技術上的,更多的是學習到了一個職場人應具備的心理素質和軟實力,

初出學校時的學生氣

剛畢業那會,別人一眼就能看出我是一個初出學校的人,當時還沾沾自喜,覺得自己長得還挺年輕的,哈哈哈哈,

可是,“像是一個學生”真的是對你的褒獎嗎?其實不然,盡管這只是別人隨口說說,可是“學生”這個詞對于一個職場人而言,恰恰說明了這個人的專業性不足,給別人的第一印象就是“這人剛畢業,沒什么經驗,還不能獨當一面,”

其實大多數剛畢業的人,身上都帶著一股學生氣,和有著一兩年作業經驗的人,除了衣著打扮上的區別外,這種“學生氣”更能體現兩者的區別,

何為學生氣?就是仍保持著學生的思維來思考與做事,舉個簡單的例子,當一個學生遇到一個Bug之后,第一時間想到的就是詢問老師,這是在十幾年的學生生涯中被養成的習慣,作為學生,我們總是被鼓勵著去問,老師也樂意解答,可是,在職場中,不是不能問,而是不能像學生一樣去問,

什么叫“不能像學生一樣去問”呢?

在我加過一些技術群里,經常看到里面有很多技術小白在提問,但是他們的提問往往得不到解答,或者說得到的都是相同水平的人的解答,為什么呢?因為他們的問題要么太籠統,要么太簡單,要么就直接貼個報錯上來問這個報錯時怎么回事,這就叫不會問問題,

比如這樣:

正確的提問應該是在自己經過思考,有了一定的見解,并排除了一些可能后,仍無法解決問題時,將自己的排錯程序與猜想以及結果拋出來,

比如,我在之前的一份作業中遇到了一次openstack集群多個虛擬機檔案系統損壞,如果是剛畢業的時候可能會這么問:“x哥,集群虛擬機好多機器都開不了機了,不知道什么情況,幫我看看唄,”

作業了一個月之后可能會這么問:“x哥,集群虛擬機開不了機了,報錯好像是檔案系統損壞了,怎么修復檔案系統呀?”

作業了三個月之后可能會這么問:“x哥,集群虛擬機檔案系統損壞了,修復檔案系統之后能夠開機了,可是關機之后又報出檔案系統損壞,嘗試過將這部分虛擬機備份快照,并從快照中重建虛擬機,這個問題就解決了,但是不知道為什么會這樣?”

當能夠獨當一面時:“x哥,集群虛擬機檔案系統損壞了,修復檔案系統后嘗試排錯,查看集群運行日志,發現前陣子有一臺主機由于網路波動脫離集群,但是沒有宕機,經過對ceph和openstack的排查,發現不是存盤的問題,而是部分虛擬機同時運行在了兩個節點上,估計是在那臺主機脫離集群之后,集群觸發了熱遷移,將原先運行在那臺節點上的實體在其他節點上啟動了,但是啟動后,脫離集群的節點恢復正常,但是虛擬機實體沒有被kill掉,導致一個虛擬機在兩個節點上同時運行,同時讀寫磁盤,所以將檔案系統寫壞了,目前已經修改了熱遷移觸發的間隔時間,修改后可能會導致節點宕機后虛擬機的恢復時間邊長,”

從一個人提問的問題就可以看出這個人的水準,過于低級的問題或者未經思考就提問的問題,很容易引起別人的反感,而且也未必有人愿意回答,所以,在向別人提問前,先做兩件事:一、嘗試自己解決,二、將問題描述清楚,

責任感與成長

在我剛作業的時候,常常因為一些事情沒有解決完,而不吃午飯,最長的一次是一個人通宵一晚上,仍不耽誤第二天上班,如此忙碌不僅僅是因為作業任務重,更多的原因是當時確實菜,一個問題要解決好久,

隨著自己能力增長,現在已經不怎么需要加班了,但是每天仍然很忙碌,不僅僅是因為作業,而是為了自己,

現在每天晚上基本都會再學習兩三個小時,有時是翻譯一下一些框架的官方檔案,有時是看一兩本書(技術性或非技術性),有時是看看最新技術的應用,有時是刷一兩道力扣題,通常上床睡覺的時候已經是12點了,

我一直認為,作業的程序,不應該僅僅是對公司的輸出,也要有對自己的輸入

在作業初期,往往沒有作業經驗,人的成長和對公司的產出是成正比的,此時做了什么,就學到了什么,可是大部分作業的內容往往是重復單調的,除了少部分作業外,其余的無論什么作業,只要找個靠譜的人教上半年左右,都可以勝任,在適應了作業之后,就很難再在作業中繼續學到什么東西了,而隨著作業能力提高,在作業上的壓力會有所減少,對于如何安排自己的業余時間,就是如何對自己負責,

都說程式員吃的是年輕飯,其實是吃學習能力的飯,在我畢業之初,很多公司的JD上寫的只有hive、spark,要求再高點就加個Hbase,而現在hive已經不怎么用了,spark是基礎,高點的要求也變成了Flink、ClickHouse、Kudu、Hudi、Impala等等,,,短短兩年半,對于大資料開發的技術點要求多了這么多,所以如果想保持自己的職場競爭力,不斷的學習新技術是不可或缺的,

但是,由于程式員的兩大職業特點:接觸的人少,思維固化,沒錯,就是思維固化,一個對技術沉迷到極致的程式員,其思維必然固化,變得死板,他可能在編程上可以編出花來,貪心演算法,DFS,分治法,回溯法,線性規劃網路流,,,等等演算法可能掌握的如火純青,但是,讓他說服一個不懂技術的人來使用他的產品時,你可以看到他在眉飛色舞地侃侃而談,然后對面的表情可能是這樣的:

所以,業余時間學習是必然的,但是也不能只學技術,一個優秀的好青年,必定是德智體美勞全面發展的,

如何看待自己的價值

大多數程式員都有一種優越感,確實,大部分程式員朋友們也都有這個優越的資本:學歷高、薪資高、能力高,

現在大部分公司的門檻都是本科學歷,目前全中國本科學歷的人大概在5%左右,盡管現在每年都在擴招,也就是說,大部分程式員朋友們在學歷上已經打敗了全國95%的人了,

今年年初,某人說全中國還有至少六億的人月薪在1000元左右,2019年上海的平均薪資是9580,而大部分程式員的薪資都是過萬的,也就是說,程式員的薪資至少在上海能夠在平均數以上,

作為業務部門與服務器之間的翻譯官,程式員在作業中能夠實作業務部門提出的種種需求,還要好言好語(不要BUG)地將這些需求說給機器聽,至少在這方面的能力不能說低,

可是,這三高真的是程式員優越感的本質嗎?

非也,

就拿大資料這門技術來說,資料是企業的重要資產,但是資料的價值是通過賦能業務體現的,比如,長久以來,很多企業的重大決策都是基于領導的經驗和直覺做出的,而有了大資料技術之后,領導者可以通過資料進行理性客觀地決策;又比如,通過對手機到的每個客戶的資料挖掘出他們的喜好和訴求,將對消費者的觸達從過去的“大水漫灌”到以“千人千面”為代表的精準營銷,這些都屬于資料的價值,而非大資料開發工程師的價值,作為一個大資料開發,是SQL難學?還是框架難以理解?都不是,那為什么大資料開發的工資要高于其他開發?是因為資料的價值高于其他開發所帶來的產業價值

所以,作為一個程式員,我們的價值是體現在能為業務帶來多大幫助,而不是技術本身,輕業務而重技術的程式員是走不遠,走不高的,

如何看待35歲危機

正如之前所說,程式員是一個吃學習能力的職業,而隨著年齡的上升,學習能力也會下降,業內盛傳的三十五歲危機也不是空穴來風,

其實我也只是剛畢業兩年多的小毛孩子,對于三十五歲危機,其實沒有多大話語權,因為暫時還不能切身領悟到,

可是在我身邊的架構師、專案經理、技術總監們,沒有一個是三十歲以下的;三十五歲左右的開發工程師也見過,薪資也可觀;但是也確實有些公司在招人的時候明確表示要求年齡在三十歲以下,且能夠接收長時間加班,

所以對于三十五歲危機,我不發表太多意見,只能說提前打算,未雨綢繆吧,在三十五歲之前多學習技術知識,過幾年轉崗架構師或其他技術性管理崗位;要么扎根某一行業,學習業務知識,結合技術,在這個行業做一個技術應用專家;要么回老家拿著這幾年的積蓄創業搏一搏,

如何與PM相處

在兩年作業中,遇見過三個PM:

第一個是剛畢業時的領導,不懂技術,但是對于專案管控了如指掌,對我說的最多的一句話就是“你先放手去做,如果在dead line前幾天覺得完成不了再跟我說,我來安排,”但是一般我都能夠完成,對于這樣的PM,基本能夠作業地很順利,

第二個和第三個是在現在公司里的,準確來說是一個架構A,和一個專案經理B,兩人性格和風格完全不同,

A做事不緊不慢,一個預計三個月周期的專案,可能他會到最后半個月的時候才安排任務,和這種PM合作,必須自己管控好專案的進度,不然專案極有可能無法按時完成,

B做事相對A來說就顯得很急躁了,比如她提一個需求,你預估三天完成,她會催一催你,讓你兩天完成;你預估明天完成,她就會讓你今天下班前做完,對于這種喜歡討價還價的PM,必須在預估時間時盡量寬松一點,比如你認為三天能完成的任務,就預估五天,反正都會被壓縮周期,最后還是三天完成,當然,這不是在劃水,恰恰相反,這是對專案負責,一個被無故壓縮周期完成的開發,要是出了BUG,就要花更多的時間去解決,從效率上來說,就得不償失了,

總的來說,PM的風格各不相同,但是PM不是敵人,而是和程式員一起完成專案的伙伴,與PM相處時,要保持良好的溝通,如果對于確實無法相處的PM,也不要撕破臉皮,重要的是完成專案,有時耍耍心眼也是必須的,

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/109290.html

標籤:其他

上一篇:初入職場的我,如果懂得這 8 條建議,早就是大神了

下一篇:CSS 實作 圖片滑鼠懸停折疊效果

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more