⑴ java開發都需要學什麼
首先要明確後端包括哪些職業:DBA(資料庫維護優化專家),Developer(程序猿),Architect(構架師),Scrum master及類似(敏捷開發專家),Project Manager(產品狗),Maintenance&IT support(通訊和伺服器相關),當然這只是一個大致的分類,並沒有一個清晰的界限。
按程序猿內功而言:關系型資料庫,領域驅動設計(Domain-Driven Design),設計模式Design Pattern,演算法Algorithm,面向對象編程OOP(SOLID),線程安全,事件驅動,測試驅動開發,依賴注入框架,等等。
對於初學Java並且有志於後端開發的同學來說,需要重點關注以下幾個部分:
基礎:比如計算機系統、演算法、編譯原理等等
Web開發: 主要是Web開發相關的內容,包括HTML/CSS/js(前端頁面)、 Servlet/JSP(J2EE)以及MySQL(資料庫)相關的知識。它們的學習順序應該是從前到後,因此最先學習的應該是HTML/CSS/JS(前端頁面)。
J2EE:你需要學習的是Servlet/JSP(J2EE)部分,這部分是Java後端開發必須非常精通的部分,因此這部分是這三部分中最需要花精力的。關於Servlet/Jsp部分視頻的選擇,業界比較認可馬士兵的視頻。
最後一步,你需要學會使用資料庫,mysql是個不錯的入門選擇,而且Java領域里主流的關系型資料庫就是mysql。這部分一般在你學習Servlet/Jsp的時候,就會接觸到的,其中的JDBC部分就是資料庫相關的部分。你不僅要學會使用JDBC操作資料庫,還要學會使用資料庫客戶端工具,比如navicat,sqlyog,二選一即可。
開發框架:目前比較主流的是SSM框架,即spring、springmvc、mybatis。你需要學會這三個框架的搭建,並用它們做出一個簡單的增刪改查的Web項目。你可以不理解那些配置都是什麼含義,以及為什麼要這么做,這些留著後面你去了解。但你一定要可以快速的利用它們三個搭建出一個Web框架,你可以記錄下你第一次搭建的過程,相信我,你一定會用到的。還要提一句的是,你在搭建SSM的過程中,可能會經常接觸到一個叫maven的工具。這個工具也是你以後工作當中幾乎是必須要使用的工具,所以你在搭建SSM的過程中,也可以順便了解一下maven的知識。在你目前這個階段,你只需要在網路上了解一下maven基本的使用方法即可,一些高端的用法隨著你工作經驗的增加,會逐漸接觸到的。
因此,你需要去看一些JDK中的類的源碼,也包括你所使用的框架的源碼。這些源碼能看懂的前提是,你必須對設計模式非常了解。否則的話,你看源碼的過程中,永遠會有這樣那樣的疑問,這段代碼為什麼要這么寫?為什麼要定義這個介面,它看起來好像很多餘?由此也可以看出,這些學習的過程是環環相扣的,如果你任何一個階段拉下來了,那麼你就真的跟不上了,或者說是一步慢步步慢。而且我很負責的告訴你,我在這個階段的時候,所學習的東西遠多於這里所羅列出來的。
總而言之,這個階段,你需要做的是深入了解Java底層和Java類庫(比如並發那本書就是Java並發包java.concurrent的內容),也就是JVM和JDK的相關內容。而且還要更深入的去了解你所使用的框架,方式比較推薦看源碼或者看官方文檔。
⑵ 程序員叫程序猿,產品經理叫產品狗,工程叫攻城獅,那麼設計師和測試叫什麼
設計叫設計獅;測試其實也需要寫代碼的,寫測試腳本,如果做白盒測試的還得會看開發的代碼,也可以叫程序猿。但男性叫程序猿,女生就好一些了,叫程序媛。
⑶ 程序員加班最狠的一次是什麼情況,有多辛苦
我自己的高強度加班有2次,都是自己創業
當時這是個社區平台,有過千萬用戶了,一個核心系統升級,然後出了點問題,不能降級,沒辦法只能停了這個系統加班加點修改。
改了4天3夜,中途還接了用戶近200個電話,好多是凌晨,用戶還很驚訝,說那個時間還有人接電話。
最終解決了,用戶也沒有流失,睡了好幾天補覺。
這是一個 游戲 接入項目,因為對方是一個大平台,用戶量特別大,要上一個流量平台,一堆 游戲 cp搶著上,所以你不搶肯定趕不上第一波,而第一波絕對是資源最足的。當時開發團隊分在3個城市,我來統一指揮,還需要跑去平台那邊,相當於是4個地方,最終也是趕上了。雖然 游戲 沒賺到錢,不過這個加班是太狠了。
當然,對方平台公司更誇張,為了他們流量平台項目,整體沒日沒夜加班3個月,每天到凌晨3點,早上還早早9點就到公司了,具體公司就不說了,我們對比他們簡直算是早九晚五了。
另外從業20年,總結:
短期沖刺加班趕節點還是有點用,長期加班的項目成功概率太低了
遇上長期的,趕緊換公司走人
其他程序員怎麼加班我確實不太清楚,就我個人的經歷,最狠的一次加班是在2009年1月1日。
直到現在,我都清晰的記得當時的情況。那是的我還是一個普普通通程序員,2008年的年末,我們接手了一個新的項目,是和蘇州公司合作的一個項目,因此,蘇州公司派了一名項目經理全程參與。
我還記得第一天項目啟動會的時候,這位項目經理說:「我希望大家能夠通力合作,完成項目。放心,我不會把大家當牛當媽的使喚的。」當時,我以為這是一句玩笑話。但是後來我明白,他果然沒有把我們當牛馬,都快要豬狗不如了。
2008年12月底,由於項目快完成是產生了需要和設計的變化,而需求和設計的變化不小,導致代碼改動很大,但是項目研發階段的deadline臨近,本來之前就加了不少班,大家就怨聲載道了,現在更是只變需求不給時間,大家就更是不開心了。Teamleader和項目經理是因為這個問題直接懟上了,最後,項目經理很不厚道的把「我們完不成任務」的情況匯報給了集團的高級總裁。
這件事也就不可收拾了,我們這里分公司的總經理扛不住,只有要求Teamleader按照項目經理的要求完成,如果完不成就提前說,咱們就換人。
最後,自然就定下了一個目標,1月7日前完成所有的調整,保證質量的情況下進入集成測試階段。
於是,慘無人道的7天生活就開始了。
2009年1月1日,元旦節,我們在公司加班到了凌晨1點多,到處都沒有人了,就連對面的華為(當時華為的園區還沒有修好,所以就在我們公司對面)也沒人了。我們大概10人左右的小分隊就到了附近的燒烤攤,吃了頓燒烤,然後3點左右回到公司繼續幹活。到了凌晨5點多的時候,扛不住趴著睡了一下,9點多又起來接著干。
2009年1月2日,其他項目繼續放假,我們接著干,中午的時候休息一下,下午開始又一直弄到完成11點多,然後回家。
2009年1月3日,整個公司還是只有我們這一個小分隊,9點多到公司後開始幹活,一直干到了晚上9點多,然後讓一些女同事先回家了,畢竟女孩子要是一個人的話,太晚回家還是有安全上的風險。我們幾個男同胞又接著干,到凌晨3點多,然後收工回家。
2009年1月4日,公司正常上班了,我們也按時到了公司,這時候項目其實基本是趕工的成果,功能沒有全部改完,也沒有經過驗證,風險很大。但是,集成測試前,有一個UT和Checklist是必須完成的,這個至少需要留一天時間,也就是留給研發的時間只有不到3天了。
於是,1月4日這天又忙到了凌晨3點多,還是有很多問題沒有解決。無奈,大部分人都快要扛不住了,還是回家吧。
2009年1月5日,我大概9點多到的公司,然後繼續開始了趕工之路,時間已經不多了,這天結果一直到了晚上2點多,還是有很多未完成的內容,Teamleader帶著大家出去覓食,結果便利店都關門了,只有無奈返回,繼續幹活。一干就干到了1月6日下午5點多。這個時候,大部分的問題都基本處理了,只剩下一些零散的內容。所以,到了晚上8點多,大家就撤了。
2009年1月7日,對整個系統進行了自測,遇到問題處理問題,由於根本沒有時間做UT用例,所以都是想當然的進行了驗證,按照Checklist的內容一一跑了一下。最終,在晚上9點多的時候完成了所有的測試並進入了集成測試階段。
終於,我們算是按照要求達到了目標,不過也度過了慘無人道的7天。什麼凌晨4點的街道,什麼凌晨5點的朝陽,呵呵。
那肯定是連續通宵加班啊,趕項目就是這樣,沒辦法,干工程的人員應該都有體會!
分享最近的一次加班經歷吧,多狠倒是不至於,也沒覺得有多麼的苦逼,反而很有成就感。
就是這次疫情期間發生的事情,很多公司都停工停產,不過也有行業很早就開啟了遠程辦公模式,我們公司也也不例外,甚至我們在春節假期期間,就已經開啟了加班模式了。
針對這次疫情,我們公司推出了一款新產品(線上),具體內容就不詳細說了,反正也算是做了一件利國利民的事情,所有收入都捐給了武漢,而這款新產品的開發,讓一個團隊上百個夥伴,連續工作了三天三夜。但是產品上線後遇到了一個比較嚴峻的考研,就是業務量比較大,一個老介面已經超過了現有系統的承受能力,所以需要一個系統提供一個介面,現有業務遷移到新的介面上。
我是那天晚上起點多接到了領導們的微信語音,了解到這件事兒的前因後果,並且領導給出的提測時間點:第二天早上。
苦逼么?別人系統做了幾天還是幾周開發出來的東西,需要第二天重構出來。
其實一點兒都不苦逼,反倒覺得非常有挑戰,似乎有一些熱血澎湃。
討論完需求的具體細節之後,我安安穩穩吃完了晚飯,然後:
20:40 沐浴更衣,准備大幹一場。
21:00 點坐在了電腦前,VPN 連到了公司的電腦;
22:00 總體的架構就搭建起來了;
02:00 四個小時把細節全部實現;
03:00 一個小時自己進行調試,修改,再調試 ... 通過;
03:30 花了半個小時完善了註解和文檔;
提交代碼,打完收工,貌似提前完成了工作;
測試團隊(全流程)測試,第二天下午上線,上線後效果不錯,抗住了壓力。
感覺自己像一個拯救了世界的英雄。
我將持續分享Java開發、架構設計、程序員職業發展等方面的見解,希望能得到你的關注。
作為一名老程序員,職業生涯經歷過很多次加班趕進度的情況,這在這個行業里是再所難免的,偶爾的加班其實還都可以接受,怕就怕持續性的加班。
基本上對於大公司來說每次大促活動、大版本發布都需要經歷一段時間突擊,當然,像大促活動上線這種情況即便你工作完成了,在上線前後你都需要隨時待命,一般像雙十一這種規模的活動,基本上都是徹夜守候在電腦前,保障系統穩定性和及時解決出現的問題。這種加班其實並不是工作量的累了,而是真正的精神壓力了,一個小問題都有可能引起大故障。但在這種情況下後勤保障還是挺完善的,各種小吃飲品滿足你需求,緊張的心情伴著「節日」氛圍,事後釋懷了回想起來讓人也是感覺成就感滿滿的。
我曾經半夜三點被主管喊起來開車拉我到公司解決線上Bug,也曾因為接到了一個自己完全不熟悉的領域連續加班5天到2點,但這不是常態,如果成為常態那果斷離職吧。
在這里也建議各位程序員加強身體鍛煉,畢竟身體是革命的本錢。
我聽朋友說的,他是在公司做HR,有一次她早上來上班,正常的和同事說話,可能聲音比較大,把項目經理吵醒了,發現項目經理一夜都在公司,基本熬個通宵。
有的時候為了趕項目,確實要加班很晚,但也不全是這種狀況,要是平時速度快的話,肯定是不用加班的。
程序員加班其實沒有最狠,只有更狠。從不同的領域細分,一般互聯網企業加班是最厲害的,然後是一些頭部的私企,具體是哪家就不說了。有的創業公司加班也比較厲害,但不一定。
很難從總體上說是什麼情況,說說自己從業十幾年的經歷吧。
L公司
剛畢業的時候去的L公司,號稱是國企的IT公司。到了沒多長時間就碰上新項目,由於工期緊,領導帶著做封閉開發。基本上是每天凌晨3點睡覺,早上8點多起床。最後加班都加惡心了。
H公司
然後去了H公司,H公司是一個私企。加班本來就是家常便飯,但是我參與的又是線上的業務,出了問題要馬上搞定。記得最厲害的一次應該是搞了一個通宵,然後第二天正常上班接著搞。
倒是沒有連續搞多個通宵的情況。沒有在互聯網公司呆過,聽說那裡加班更加厲害。有過類似經歷的同學可以在下面分享一下。
你知道凌晨四點的杭州西湖是什麼樣子嗎?
每個公司不一樣,部門不一樣,加班的原因也不一樣。像我,很多大型活動的時候都需要研發值班過晚上12點,2、3點下班。比如618,雙十一,雙十二,雙「蛋」。一年也就那麼幾次,沒那麼頻繁,不然誰都受不了。
但是這不是最苦逼的,因為第二天可以調休,值夜班中間也沒啥事,還有公司統一發放的夜宵,同事之間吃吃喝喝,說說笑笑,還是很嗨皮。
最苦逼的是半夜三更被電話叫起來,應急處理某些重大線上bug。只有你一人孤軍奮戰,從天黑干到天亮。還得正常上班,開一天的會向領導匯報情況,精神一直處於高度緊綳狀態。最後還吃力不討好,成為背鍋俠。後面幾天晚上都睡不好,從身體到心理上都覺得苦逼。
總結下,bug無法避免,我們程序員個人能做的是什麼呢?除了提高技術能力之外,就是保存良好心態,和擁有強健體魄。隨著年紀增長,越發的理解前輩的話,能夠倒頭就睡第二天被上班鬧鍾叫醒真的很幸福!
我記得那是上班的第二年,在移動的一個項目上,當時真的是年輕,精力充沛。當時是年底組巡,為了應對檢查,通宵兩個晚上去核查數據,基本連續兩個晚上沒睡,到了第三天下班才正常回家補覺。
後來年紀大了,真的熬不起了,奉勸年輕人還是不要這樣,提高工作效率是關鍵,沒有產出的加班是一種無能的表現。
最狠的一次加班也就是連續半個月在公司待到凌晨一兩點左右吧。那時候為了完成一個項目所有同事都一直忙到很晚才回去,自己我住的離公司很近,其實也不算多麼的辛苦吧,畢竟就算不加班自己也是要一點左右才睡覺的。每次加完班走在回去的路上,反而有一種病態的滿足感,感覺自己過的很充足 。感覺每天和一群同事努力的去完成一件事情,特別是最後圓滿完成的時候有一種小小的成就感。其實做了五年的程序員,平時很少加班的,因為沒有加班費所以公司也不提倡加班。如果不是特殊的情況,一般都是朝九晚五的節奏,很少有在公司待到一兩點的。很多人提到程序員就是加班,什麼九九六,什麼零零七,其實正常的公司為沒有這么變態了,一般只是一些特殊的情況才會偶爾加一次。