去年7月定下的一年之内學會自由泳的目标終于實作了,特來還願。
ABAP和Java, 蛙泳和自由泳。前面的組合是Jerry用來掙錢養家的技術,後者是Jerry花了大量業餘時間和金錢苦練的技能。或許有的朋友覺得這兩組概念風馬牛不相及,然而在Jerry眼中,ABAP之于Java, 相當于蛙泳之于自由泳。
文章目錄
- ABAP和Java的相同點
**1\. 語言特性** **2\. 開發架構,工具和生态圈**
- 蛙泳和自由泳的相同點
- ABAP(蛙泳)和Java(自由泳)的不同點
****1. "Java(自由泳)的環境搭建(遊進)比ABAP(蛙泳)麻煩"**** ******2. "ABAP(蛙泳)的調試(換氣)比Java(自由泳)簡單"****** ******3. "ABAP(蛙泳)和Java(自由泳)哪一個上手更容易?"******
-
- *
1. 語言特性
這個公衆号有很多關注者是學生朋友,是以還是有必要簡單介紹下ABAP。ABAP(Advanced BusinessApplication Programming)是SAP設計,實作并維護的一門進階程式設計語言,其關鍵字和虛拟機(ABAP Runtime)基于C/C++實作。同Java一樣,ABAP也是一門支援面向對象,強類型的靜态語言。可以說SAP之是以過去40年能在企業管理軟體領域裡取得輝煌成就,ABAP功不可沒,因為大多數SAP成功的傳統産品,比如SAP ERP, SAP Business Suite, 還有2015年推出的S/4HANA, 都基于ABAP。
ABAP和Java并沒有躺在過去的功勞簿上睡大覺,各自也都在不斷進化着。
ABAP 從7.40版本開始,增加了很多新的關鍵字和文法,使得用ABAP寫出來的代碼更加緊湊和簡潔。Table Expression,變量的内聯聲明,類型自動推斷,更強大的鍊式調用等新的語言特性,使得實作同樣的需求,用7.40後的ABAP編碼,代碼量通常是7.40之前的50%甚至更少。
ABAP也在不斷吸收一些其他程式設計語言的特性。比如支援函數式程式設計思想的JavaScript和Clojure中的reduce操作,在ABAP 7.40之後也作為一個關鍵字得到支援了。具體例子可以看我的部落格:
Functional Programming – Try Reduce in JavaScript and in ABAP
https://blogs.sap.com/2017/02/27/functional-programming-try-reduce-in-javascript-and-in-abap/另一方面,我的很多同僚戲稱:Java 9的很多特性都沒搞清楚,但在Java 9釋出僅僅幾個月後,Java 10又來了。這本身說明Java的進化速度非常快。和ABAP相比,網絡上關于Java最新特性介紹的文章多得多,Jerry這裡就不再重複了。
2. 開發架構,工具和生态圈
兩種語言都有各自數目衆多的開發架構和繁榮的生态圈。隻是從生态圈的規模來說,ABAP生态圈内開發者的絕對數量不如Java開發者。
SAP有很多基于ABAP的開發架構,平台層面的架構有例如基于ABAP的MVC開發架構ABAP WebDynpro和WebClient UI,OData Service開發架構,Web Service開發架構,Business Object的開發架構BOPF等等。從應用層面來說,架構的數量就更多了。即使在其他公司的開發人員眼中一個很簡單的需求,SAP也很可能采取了一個微型架構(Mini Framework)來實作。這種大量引入架構實作應用需求的思路,一方面展現了德國人考慮需求時追求嚴謹完備的習慣,另一方面,通過将實作需求的複雜度和工作量轉移到SAP标準應用開發上來的方式,減少或者避免了Partner和客戶進行二次開發的工作量,使得很多非标準功能僅僅通過在這些微型架構上做配置就能實作。
任何一個基于ABAP的SAP傳統産品裡,都隐藏了很多有用的工具,比如各種報表或者事務碼,用于提供關于該産品的輔助功能,比如問題分析,日志檢視,性能檢測等等。我想即便大多數在一個産品裡深耕了10年的SAP顧問,恐怕也無法能夠100%肯定地說自己熟悉該産品裡所有的工具。
除了這些SAP提供的标準工具外,也存在一些ABAP開源愛好者貢獻的開源項目,比如ABAP Git用戶端,用于不同系統間離線傳輸ABAP資源的SAP Link,還有用ABAP操作Excel的abap2xls項目等等。
Java這麼多年一路走來,其層出不窮的開發架構更是早已深入人心。從早期經典的三駕馬車SSH,到近些年來随着微服務火起來而流行開來的Spring Boot和Spring Cloud等等,可以說無論打開任何一個Java技術社群,都能看到它們的身影。
得益于全球數量龐大的Java開發人員,Java生态圈的開發工具,庫檔案也是數不勝數。在Maven的遠端倉庫
http://repo1.maven.org/maven2裡,我們能找到許許多多公司釋出的庫檔案。
這是遠端倉庫上SAP庫檔案的根目錄:
同樣的,如果您對其他公司,比如Microsoft, Oracle,Salesforce釋出的Java庫檔案感興趣,那就到對應目錄去看看吧:
Jerry作為一個過來人,說說我對這兩種泳姿相同點的一些認識。
1. 都是遊泳初學者的入門泳姿。稍稍不同的是,在國内,蛙泳是最受推薦的入門泳姿,而國外的朋友學遊泳,通常都選擇了自由泳作為入門泳姿。
2. 初學者都會遇到兩個最大的瓶頸,即腿部動作和換氣。
腿部動作:很多成年人初學蛙泳,在水裡進行蛙泳腿部動作“收-翻-蹬夾”的“翻”這一步時,由于種種原因,無法将腳腕的翻腕動作做出來,這樣無法確定腳掌以最大面積推水,導緻泳者在水中感覺費了很大力氣蹬腿,但是前進速度緩慢。
同樣,自由泳初學者遇到的第一道坎就是打腿不前進。很多成年人初學打腿時,體會不到自由泳打腿的髋部發力(下圖黃圈所示部位),大腿帶動小腿,鞭狀發力的打腿形式,陷入打腿時水花四濺,但就是不前進的窘境。
換氣:這是很多遊泳初學者幾乎都會遇到的另一道坎。反正Jerry學蛙泳換氣和自由泳換氣時,都喝了足夠多的水才學會的。遊泳論壇裡很多同病相憐的朋友們都說學換氣就是一個将練習換氣時喝下去水的容量換算成經驗值的過程——當經驗值滿了後,自動解鎖換氣技能。Jerry想了想自己學會這兩種泳姿換氣的過程,好像還真是這樣。
3. 兩種泳姿都有各種各樣的變式(Variant)。
像前面介紹過的ABAP和Java擁有五花八門的工具一樣,蛙泳和自由泳也有着衆多變式。
蛙泳的不同種類:平蛙和波蛙
平蛙和波蛙是蛙泳的兩種主流姿勢(本文不讨論擡頭蛙)。
蛙泳初學者無一例外學的都是平蛙,因為比較簡單,對泳者上肢力量要求不高。雙手前伸時壓水擡頭即可換氣,擡起換氣的動作可以做得很慢。遊泳館裡很多蛙泳都是平蛙,這種泳姿遊起來輕松,省力,适合長遊。我自己的感受是平蛙有一半的時間在水裡都是處于完全放松狀态,哪怕一口氣遊1公裡,也不覺得累。
波蛙是蛙泳運動員采用的競技泳姿,頻率比休閑式平蛙快得多。比較一下:
平蛙:
波蛙:
波蛙為了減少蛙泳在高速前進過程中成倍增長的阻力,把整個上半身都提出水面,從空氣中前進。波蛙換氣和平蛙換氣相比,一個顯著的差別就是通過雙肩拱起到幾乎碰到耳朵的程度來減少阻力,看起來極具觀賞性,非常霸氣!
可惜對身體核心力量要求很高,不好學啊。。。
蛙泳早呼吸與晚呼吸
早呼吸:顧名思義,劃手的時候,手剛開始外劃就擡頭換氣。采用早呼吸可以給泳者提供充足的換氣時間,适合初學者。看看知乎遊泳大神易夢覺的早呼吸教學示範:
晚呼吸:外劃時頭部仍然注視池底,外劃結束手臂開始内收時迅速擡頭,雙手快速前伸。晚呼吸要求泳者上肢有一定的爆發力,換來的收益就是遊進速度快于早呼吸。
看下晚呼吸的動作:
蛙泳寬蹬腿與窄蹬腿
初學者和業餘蛙泳一般都是寬蹬腿,運動員比賽時都是窄蹬腿。寬蹬腿膝蓋張開的距離比窄蹬腿寬,蹬夾時劃過的圓弧周長大于窄蹬腿。
寬蹬腿具有明顯的蹬夾動作,如果在岸上觀察很多蛙泳初學者的動作,能清晰看到先蹬水後夾水的順序。而窄蹬腿,蹬夾幾乎一氣呵成而融為一體,很難嚴格區分開來。注意看這些運動員的窄蹬腿:
寬蹬腿由于橫截面過大,是以承受的水阻也大于窄蹬腿,是以競技比賽中的蛙泳都是窄蹬腿。然而窄蹬腿相對寬蹬腿對膝蓋壓力較大,如果您的膝蓋柔韌性不足,那還是老老實實去練寬蹬腿吧,以免膝蓋損傷。
自由泳劃手的前交叉,中交叉和後交叉
下圖右手露在水面即将入手開始自由泳的劃水動作,此時如果左手與水準面的夾角保持在30度以内,稱為前交叉。30度到60度範圍内為中交叉,大于60度成為後交叉。
采用前交叉,則右臂入水時,左臂正處于開始下劃階段,此時整個身體非常舒展,帶有一定的滑行速度,便于全身主要肌肉群發力。同時動作節奏相對較慢,适合業務愛好者和運動員長距離比賽使用。後交叉則是另一個極端,右手入水時,左手已經進入劃水的後半階段了。後交叉劃水頻率極高,需要泳者具有很強的爆發力,通常隻有短距離遊泳運動員才hold得住。
看看這個前交叉動作,是不是非常舒展?
自由泳的各種變式:二次腿和六次腿
二次腿:左右劃水各一次,劃一次水,打一次腿。手臂剛入水時,打異側腿。很多鐵三長距離自由泳的朋友都用的二次腿,因為省力,便于長遊。
六次腿:打腿産生的推進力大于二次腿。
兩門截然不同的程式設計語言,差異當然有很多了。這裡隻挑最顯著的聊。
1. "Java(自由泳)的環境搭建(遊進)比ABAP(蛙泳)麻煩"
Jerry和SAP開發顧問朋友們聊天時,經常談到這個話題。一個ABAP新手,隻要在電腦上裝個SAP GUI,連接配接上伺服器就可以開工了。而一個Java開發新手,如果要做企業級應用開發的話,開發人員通常都會拿到一個很長的清單,注明了開發環境搭建所需的長長的步驟:裝JRE和JDK,下載下傳Maven,安裝代碼版本控制工具,配置環境變量,配置本地資料庫等等。一般都會使用基于Java的各種架構比如Spring全家桶,那麼為了提高開發效率,還得去下載下傳這些架構基于某種IDE的插件并安裝。如果工作内容包含微服務開發,又得安裝一些基于指令行的微服務部署工具。
對于一個Java新手來說,在基于要求的開發環境内跑通一個Hello World應用之前,通常需要花大量的時間來搗鼓這些環境準備工作。更有可能發生的是在搭建過程中遇到各種各樣的錯誤,導緻搭建流程進行不下去。此時要麼求助組内有經驗的同僚,要麼根據錯誤消息到StackOverflow上去查找解決方案。
其實從ABAP開發的整個流程來看,仍然需要環境搭建這一步,即Netweaver伺服器的安裝和運維。隻是因為ABAP和Java存在的兩個差異,使得ABAP開發人員在環境搭建這個話題上,比Java開發人員輕松不少。
(1) 在絕大多數企業裡,ABAP Netweaver的搭建是由專職人員,即SAP Basis去負責的,不需要ABAP應用開發人員介入。ABAP開發人員登入到Netweaver伺服器上,在伺服器上進行開發。Netweaver伺服器既是ABAP開發環境,又是ABAP應用最終的運作環境,是以意味着ABAP代碼一旦開發完畢,能立即在伺服器上運作,省去了應用部署這一步驟。
而Java應用開發工作絕大多數情況都不會在伺服器端進行,而是在各個開發人員本地搭建好的環境中進行,待開發完成單元測試通過後通過git等工具将源代碼推送到遠端代碼倉庫,同時通過持續內建等工具将建構好的應用部署到伺服器上。
(2) Netweaver伺服器的特色之一,就是對ABAP開發和ABAP運作時提供了全局而統一的支援。Netweaver自帶了代碼版本控制工具,是以ABAP開發不需要Git;Netweaver提供了類似Maven倉庫的功能,在Netweaver裡叫Repository Information System,ABAP開發人員在計劃新寫一段代碼時,通常都會去RIS裡檢查是否已經有現成的類/函數實作了類似的功能。一個ABAP類要使用另一個ABAP類提供的API,可以直接調用,因為所有的類都存在于中央的RIS裡,而ABAP不存在Java裡的包通路權限的概念——一個類對伺服器裡的任何類都可通路,并且隻提供唯一的版本供外界通路(ABAP裡稱為Active版本)。是以ABAP也不像Java那樣需要通過Maven來進行項目依賴管理。ABAP提供了OPEN SQL,這些SQL語句通過Netweaver提供的資料庫接口自動轉換成Netweaver伺服器連接配接的資料庫提供商的原生SQL語句,是以ABAP開發也不需要自行安裝伺服器。
由此可見,很多Java開發人員需要在本地做的事情,其實在ABAP開發裡已經通過Netweaver伺服器統一提供了,是以從結果上看,顯得Java開發人員的環境搭建比ABAP要麻煩一些。
當然針對Java這種環境搭建之痛也存在一些解決方案。比如SAP内部的很多教育訓練,需要教育訓練人員上機做練習,那麼講師會事先将環境搭好,然後做成一個虛拟機鏡像,分發給學員。學員用虛拟機軟體加載這些鏡像,就能直接基于講師準備好的環境進行上機練習,省去了每位學員搭環境的時間。Jerry還了解到SAP成都研究院的某些團隊也在嘗試用Docker來解決類似問題。
從上面的讨論看出Java的環境搭建确實比ABAP麻煩,那麼自由泳遊起來确實比蛙泳麻煩麼?Jerry的個人意見:是!理由有四。
(1) 蛙泳時整個人俯卧于水中,雙手雙腳在任何時候都是呈左右對稱地運動。而自由泳的手腳為非左右對稱運動,在初學者還沒形成身體本能時,開始劃手時還要考慮應該打哪一側的腿。
(2) 蛙泳遊進時,蹬腿夾水結束後可以在水裡滑行一兩秒,身體得到充分休息。而自由泳行進過程中,手和腳都是不停地運動着,對初學者來說很難找到像蛙泳那樣可以通過滑行來休息的感覺。
(3) 自由泳相比蛙泳,身體在前進過程中還多了個轉體動作。
Jerry最開始學自由泳時,以為它和蛙泳一樣,身體始終是俯卧在水中前進的。後來才從教練那裡和網上的視訊學到,遊進過程中必須有一個轉體動作,如下圖所示。
(4) 自由泳的換氣比蛙泳麻煩。
這個太令我刻骨銘心了,需要單獨說。
2. “ABAP(蛙泳)的調試(換氣)比Java(自由泳)簡單
做軟體開發(遊泳)而不需要調試(換氣),幾乎是一件不可能的事情。
前面已經說過,對于ABAP來說,因為Netweaver伺服器既是ABAP開發環境,又是ABAP應用的執行環境。是以任何時候,需要調試,直接在源代碼上設斷點,啟動應用,斷點即觸發。
Java的伺服器端調試就沒這麼輕松了。首先需要給遠端伺服器的JVM加上debug參數來啟動伺服器:
-Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=
然後在本地IDE比如Eclipse裡做配置,通過jdwp(Java Debug Wire Protocol)連接配接遠端伺服器打開的監聽端口,本地調試程序和遠端伺服器程序之間通過socket實作資料傳輸。
蛙泳的換氣,因為整個遊進過程中身體始終保持俯卧狀态,是以動作非常自然,和人在陸地上的舉動幾乎沒有差別,從水中擡起頭來即可換氣。具體動圖參看前文早呼吸和晚呼吸部分。
自由泳的換氣,Jerry為了學會它是喝飽了水。作為陸地上生活的動物,人在水中換氣時,把頭擡高讓嘴遠離水面進行換氣是一種本能。然而學習自由泳的換氣,需要克服人的這種本能,正确的方式是靠行進時頭的推進、身體的翻轉在頭部形成的充滿空氣的小凹槽裡換氣。國外的教學視訊裡稱為Breathe into the air pocket。初學者練習這個動作,要麼由于害怕換不了氣頭擡得太高變為蛙泳換氣,要麼轉頭一張嘴,一大口水就喝進去了。
看清楚下圖裡的air pocket了麼?
從空氣袋裡換氣的标準姿勢:
3. "ABAP(蛙泳)和Java(自由泳)哪一個上手更容易?"
ABAP和Java,蛙泳和自由泳,到底誰比誰更容易學?
先說遊泳。國内的遊泳業餘教育訓練班大多是以10或12節課的速成班為主,在這種課時限制下,也隻有蛙泳這種最易上手的泳姿可供選擇了.其他三種對身體素質和水性的要求比蛙泳高。并且蛙泳學會後,踩水也就自然會了,踩水技能比較實用。
為什麼國外更多以自由泳作為入門泳姿?因為國外的遊泳教學多以長訓為主。參考知乎易夢覺大神的解答:
是以,Jerry認為,這個話題的準确回答應為:以10節課速成班為例,對大多數人來說,蛙泳比自由泳更容易學會。
ABAP和Java哪種語言更容易上手?如果不考慮本地搭建Netweaver伺服器的難度,那麼學會這兩門語言的基本文法難度差不多。然而學完了ABAP标準教程BC401等等并不意味着就具有了用ABAP開發SAP應用程式的能力。比如要開發CRM應用,還得去學CR100标準課程,掌握SAP CRM開發架構的用法。如果想用ABAP開發OData服務,還得學标準課程GW100以了解如何在SAP Gateway上做ABAP開發,以此類推。
同樣,在Eclipse裡列印出Hello World隻是萬裡長征走完了第一步。前面已經說過,根據您具體工作内容的不同,您還需要學習各種Java架構,庫檔案的使用。
從這個角度來說,ABAP和Java入門的難度差不多。能用這兩門語言寫一些簡單的小工具,就好比能用蛙泳和自由泳的姿勢遊個二三十米。ABAP和Java開發人員入門之後,接下來的漫漫長路,就在于如何精進能夠基于自己所學,去實作真實場景下客戶需求的技藝。而每一位真正的遊泳愛好者,想必心中都有下面這個心願:我的打腿像孫楊。
程式設計與遊泳,路漫漫其修遠兮,讓我們上下而求索。
更多閱讀
要擷取更多Jerry的原創技術文章,請關注公衆号"汪子熙"或者掃描下面二維碼: