在技術(shù)的世界里,有一類編程語言叫面向?qū)ο缶幊?,例如典型的面向?qū)ο笳Z言Java。說到面向?qū)ο?,不得不提的幾個概念是類、對象、抽象和實(shí)例。這些技術(shù)術(shù)語會經(jīng)常在工程師的討論中出現(xiàn),非技術(shù)背景的產(chǎn)品經(jīng)理該如何理解這些概念呢?接下來具體介紹這些技術(shù)術(shù)語分別代表什么意思。
首先介紹第一個概念“抽象”。我們說某一個概念聽起來非常抽象的意思是不具體的事物,對應(yīng)的反義詞是具象。抽象在技術(shù)術(shù)語里的意思是提煉出一個通用模板,然后基于模板做具象化的實(shí)現(xiàn)。例如,在現(xiàn)實(shí)世界中關(guān)于人的分類,會有男人、女人、老人和小孩,如果將這個具體的分類抽象出一個類別,得到的抽象結(jié)果就是人。所以,人就是一個抽象出來的分類,也就是技術(shù)術(shù)語里面的“類”。在編程語言的世界中,通過程序語言描述現(xiàn)實(shí)世界中的事物時,使用的就是抽象的方法,將一類事物抽象成一個類,就得出了程序世界中的一個基本模型。
有了基本模型后,可以基于抽象出來的模型(類)產(chǎn)生很多具體的實(shí)例,也就是基于類實(shí)例化的具體對象。例如,將“人”這個類實(shí)例化為兩個對象,分別是男人和女人,也可以實(shí)例化為其他對象,例如小孩和老人,甚至可以實(shí)例化為具體的人,例如Maggie和Ryan。這一系列的過程如圖所示。
從上述流程中可以看出,工程師做的工作就是根據(jù)產(chǎn)品需求將現(xiàn)實(shí)世界中的事物抽象成程序世界中的一個個類,然后根據(jù)需要實(shí)例化很多對象,不同對象間通過相互協(xié)作完成一個具體的產(chǎn)品功能。
非技術(shù)背景的產(chǎn)品經(jīng)理在工作中也可以試著以這種技術(shù)思維的方式定義產(chǎn)品需求,先從產(chǎn)品角色開始抽象出具體的類,然后分別定義這些角色在整個產(chǎn)品流程中需要完成哪些關(guān)鍵動作,從而定義出具體的對象。這樣既有利于明確需求和用戶角色,也能培養(yǎng)非技術(shù)背景產(chǎn)品經(jīng)理的技術(shù)思維。
在與工程師的配合中,你一定聽說過“打印”這個詞,通常場景是在調(diào)試產(chǎn)品問題或進(jìn)行開發(fā)測試時。工程師口中的“打印”和我們使用打印機(jī)打印文件究竟有什么區(qū)別呢?對非技術(shù)背景的產(chǎn)品經(jīng)理而言,聽到這個既熟悉又陌生的詞匯時,該如何理解呢?
首先,“打印”這個詞在大多數(shù)場景下是指我們將文件或圖片通過打印機(jī)從計算機(jī)世界輸出到現(xiàn)實(shí)世界中,意味著一種結(jié)果的輸出。工程師口中的“打印”一詞,表示的是一種結(jié)果輸出,只是這種結(jié)果并不會輸出到現(xiàn)實(shí)世界,只是將程序運(yùn)行的結(jié)果“打印”到命令控制臺上。
工程師在編寫程序代碼時,需要不斷測試程序片段運(yùn)行是否正確,例如編寫一個加法的程序片段,當(dāng)代碼編寫完成后,工程師需要測試加法程序是否運(yùn)行正確,所以會輸入兩個參數(shù)然后查看程序的運(yùn)行結(jié)果,程序運(yùn)行結(jié)果輸出到命令控制臺的過程就叫作“打印”。
工程師在調(diào)試問題程序的過程中,也會經(jīng)常用到打印技術(shù),將每一塊代碼的執(zhí)行結(jié)果輸出到控制臺,用來查看具體問題出在哪個環(huán)節(jié)。因?yàn)榇a的運(yùn)行過程是不可見的,所以通過“打印”的方式能讓代碼的運(yùn)行過程和結(jié)果可視化。
在與工程師討論產(chǎn)品需求或者工程師相互討論技術(shù)方案時,經(jīng)常會聽到“寫死”這個術(shù)語。“寫死”這個詞嚴(yán)格來說不算一個標(biāo)準(zhǔn)的技術(shù)術(shù)語,而是工程師用來描述一種技術(shù)實(shí)現(xiàn)方案的說法。
例如,要設(shè)計一個下拉選擇框用來切換不同的城市,這個產(chǎn)品需求在技術(shù)層面有兩種實(shí)現(xiàn)方案,第一種是將城市數(shù)據(jù)放在服務(wù)器端,客戶端通過請求數(shù)據(jù)接口將城市數(shù)據(jù)獲取回來再顯示在下拉列表中。第二種是將城市列表數(shù)據(jù)存放在客戶端,客戶端從本地讀取城市列表并展示在下拉列表中。
第一種方式是一種相對靈活的方案,當(dāng)城市數(shù)據(jù)有變化時,只需要調(diào)整服務(wù)端的數(shù)據(jù)內(nèi)容即可,客戶端不用做任何修改,但需要開發(fā)一個專門的數(shù)據(jù)接口獲取這部分?jǐn)?shù)據(jù)。第二種方式就是工程師所說的“寫死”,將數(shù)據(jù)集寫死在本地,這樣可以省去數(shù)據(jù)接口的開發(fā),也能快速實(shí)現(xiàn)想要的效果。
這兩種不同的實(shí)現(xiàn)方式在很多產(chǎn)品設(shè)計環(huán)節(jié)中都會體現(xiàn),例如一些客戶端的文案或者圖片會經(jīng)常變化,這時就不太適合將需要變化的數(shù)據(jù)“寫死”在本地,合理的方案是將變化的數(shù)據(jù)存儲在服務(wù)端,客戶端通過數(shù)據(jù)接口靈活地獲取這部分?jǐn)?shù)據(jù)。
當(dāng)然,也不是所有的數(shù)據(jù)都不適合“寫死”在本地,例如性別數(shù)據(jù),無非就是男和女,不必專門為了它開發(fā)一個數(shù)據(jù)接口,我們得根據(jù)具體需求和使用場景判斷哪些數(shù)據(jù)應(yīng)該寫死。
架構(gòu)和框架是工程師經(jīng)常提及的兩個技術(shù)概念,另外,在技術(shù)職能中還有架構(gòu)師這一崗位。對非技術(shù)背景的產(chǎn)品經(jīng)理而言,該如何理解和區(qū)分這兩個技術(shù)概念呢?通過一個例子就可以非常直觀地理解二者。在修建房屋時,會有一個總設(shè)計師負(fù)責(zé)設(shè)計整體藍(lán)圖和規(guī)劃,這個工作可以理解為是架構(gòu)師的工作,而房屋設(shè)計結(jié)構(gòu)和規(guī)劃本身是房屋的架構(gòu)。
架構(gòu)工作完成后就進(jìn)入具體的施工環(huán)節(jié),施工時可以選擇從頭開始一磚一瓦的加,也可以使用現(xiàn)有的房屋框架,基于成熟的房屋框架一層一層累加,后期只需要做整合和裝修工作即可使用現(xiàn)成的框架,既能降低施工難度,也能提高施工效率。
在技術(shù)領(lǐng)域,架構(gòu)這個詞是對系統(tǒng)的結(jié)構(gòu)設(shè)計和規(guī)劃,通常由經(jīng)驗(yàn)比較豐富的架構(gòu)師或者高級工程師完成,架構(gòu)的好壞直接決定了后期系統(tǒng)的穩(wěn)定性和可擴(kuò)展性??蚣軇t是指利用現(xiàn)有的成熟技術(shù)框架簡化開發(fā)過程,例如針對企業(yè)級應(yīng)用的開發(fā)框架J2EE,就提供了很多現(xiàn)成的組件來降低開發(fā)的復(fù)雜度,如今很多系統(tǒng)的開發(fā)都會使用一些比較成熟的開發(fā)框架替代純自主開發(fā),這樣既能保證系統(tǒng)質(zhì)量,也能提高開發(fā)效率。
任何一個網(wǎng)頁或者App產(chǎn)品都是由大量的輸入框、按鈕、文本展示框構(gòu)成的,產(chǎn)品中的這些最小界面元素組成單元就叫作控件。一個按鈕是一個控件,一個輸入框也是一個控件。如圖所示為幾個基本控件(輸入框、文本展示框和按鈕)。
組件是一種功能更全面的升級版控件,或者可以把組件理解成多個控件的組合。例如,Android和iOS開發(fā)中經(jīng)常使用的Tab組件,如圖所示。
大部分產(chǎn)品都設(shè)計為底部有幾個模塊,點(diǎn)擊不同的底部按鈕可以在不同的模塊之間切換,實(shí)現(xiàn)展示和切換的就是Tab組件,它包含了頁面容器展示、按鈕等一系列功能,將這些細(xì)粒度的控件組合到一起來完成復(fù)雜功能,這就是組件。
工作中經(jīng)常會聽到工程師討論進(jìn)程和線程。例如,涉及一些復(fù)雜功能的技術(shù)實(shí)現(xiàn)方案時,工程師會說現(xiàn)在已經(jīng)同時開了幾個線程在處理。進(jìn)程和線程究竟是什么?它們之間有什么關(guān)系呢?本節(jié)主要介紹進(jìn)程和線程的概念。
當(dāng)我們點(diǎn)擊手機(jī)屏幕上的一個App按鈕(啟動一個產(chǎn)品)時,系統(tǒng)會為這個產(chǎn)品的運(yùn)行分配系統(tǒng)資源(例如CPU和存儲空間),分配好資源后,產(chǎn)品會在這個資源區(qū)域運(yùn)行應(yīng)用程序。這里所說的運(yùn)行應(yīng)用程序就是進(jìn)程,也可以理解為每一個正在運(yùn)行的App都是一個進(jìn)程。
例如,我們在手機(jī)上使用微信或者微博,就有分別屬于微信和微博的系統(tǒng)進(jìn)程。一旦關(guān)閉應(yīng)用程序或因?yàn)橄到y(tǒng)資源緊張而自動關(guān)閉在后臺運(yùn)行的應(yīng)用程序,進(jìn)程就會被終止,同時對應(yīng)的進(jìn)程所占用的系統(tǒng)資源也會被釋放。
相比于進(jìn)程,線程是一個更小的執(zhí)行單元,一個運(yùn)行中的應(yīng)用程序是一個進(jìn)程,一個進(jìn)程中可以存在多個線程,每一個子任務(wù)都可以理解為是運(yùn)行中的一個線程。我們以微博為例,運(yùn)行中的微博是一個系統(tǒng)進(jìn)程,可以上傳照片發(fā)布微博,也可以上傳視頻發(fā)布微博。
用戶上傳照片的任務(wù)在一個獨(dú)立的線程中運(yùn)行,上傳視頻的任務(wù)也在一個獨(dú)立的線程中運(yùn)行,并且這兩個任務(wù)可以同時運(yùn)行互不影響,這種方式叫異步線程處理,即可以并行互不干擾完成各自的子任務(wù)。當(dāng)然,還有一種線程處理方式叫同步線程,即子任務(wù)是按照一定的順序完成的。
產(chǎn)品之所以能同時完成很多功能,就是因?yàn)榫€程的存在,尤其是涉及需要網(wǎng)絡(luò)請求的一些功能時,例如用戶在微信中發(fā)布朋友圈后有可能立馬去刷新朋友圈,這時可能剛剛發(fā)布的內(nèi)容還沒有上傳成功,所以在技術(shù)實(shí)現(xiàn)時會用兩個線程分別處理發(fā)布和獲取新信息的子任務(wù)。這樣做既能保證用戶體驗(yàn),也能保證系統(tǒng)資源被合理地分配和利用。
“腳本”這個詞在工程師口中出現(xiàn)的頻率比較高。當(dāng)需要對數(shù)據(jù)庫進(jìn)行批量處理時,工程師會說“跑一個腳本統(tǒng)一處理一下”;當(dāng)需要查詢某一數(shù)據(jù)報表時,工程師會說“用一個腳本批量查詢”。
腳本也是一種被計算機(jī)執(zhí)行的程序,為什么叫腳本呢?可以把腳本理解成拍戲用的劇本,劇本里會按照角色及對白把要拍的戲清晰地列出來,導(dǎo)演和演員會嚴(yán)格按照劇本表演。腳本就是一種面向計算機(jī)的劇本,是一個可被計算機(jī)執(zhí)行的文件,文件里是一系列計算機(jī)指令,這些指令會按照順序被計算機(jī)解析并執(zhí)行。
例如需要對數(shù)據(jù)庫中所有用戶數(shù)據(jù)添加一個數(shù)據(jù)項(xiàng),一個一個添加顯然是不可能的,通過一個批量操作一次性地完成是效率最高的做法,此時就會用到腳本。通過腳本寫一個新增數(shù)據(jù)項(xiàng)的命令,然后執(zhí)行腳本,所有的數(shù)據(jù)就會被批量執(zhí)行同樣的操作。圖14-4所示是在Mac電腦環(huán)境下使用命令行執(zhí)行的一個查詢某一文件夾下所有文件的命令。
在第3行執(zhí)行了一個名為“ls”的命令,這個命令的作用是列出當(dāng)前文件夾下的所有文件或子文件夾的名稱,第4行到第5行是當(dāng)前文件夾下所有文件或子文件夾的名稱。如果把“ls”命令單獨(dú)寫成一個文件,這個包含一條指令的文件就是一個腳本文件。實(shí)際應(yīng)用中,腳本文件通常會由多個指令組合而成,經(jīng)過計算機(jī)的解析和執(zhí)行來完成一個復(fù)雜的處理任務(wù)。
同步和異步是開發(fā)技術(shù)中的兩個概念,計算機(jī)通過解析和運(yùn)行程序完成相應(yīng)的操作。在程序執(zhí)行過程中會涉及同時處理多個任務(wù)或者同一時間只處理一個任務(wù)的情況。在前面的章節(jié)中我們介紹過什么是進(jìn)程和線程,一個進(jìn)程中包含多個執(zhí)行任務(wù)的線程。
以用戶登錄為例,登錄任務(wù)是在一個登錄線程中執(zhí)行的,登錄任務(wù)執(zhí)行過程中除了驗(yàn)證用戶名和密碼是否正確外,還需要處理其他子任務(wù),例如從服務(wù)器獲取用戶信息,更新本地緩存信息等。這些子任務(wù)通常會在新開辟的子線程里執(zhí)行。執(zhí)行登錄的線程可以稱為主線程,執(zhí)行獲取用戶信息的線程稱為子線程。
在一個登錄操作過程中分別執(zhí)行兩個任務(wù),這個過程就叫作異步處理。異步處理不會造成線程阻塞,相當(dāng)于各自處理各自的任務(wù)。如果所有的任務(wù)都在一個線程中處理,那就會出現(xiàn)資源占用過多和響應(yīng)時間過長的情況,例如我們在使用一些安卓APP時偶爾會出現(xiàn)應(yīng)用程序閃退的情況,這有可能是因?yàn)槌霈F(xiàn)了線程死鎖。
同步處理比較好理解,就是同一時間只執(zhí)行一個簡單任務(wù),任務(wù)處理完后再執(zhí)行第二個任務(wù),同步處理適用于一些順序執(zhí)行的任務(wù),例如流水線處理就是典型的同步處理,流水線上的一個環(huán)節(jié)處理完成后再處理下一個環(huán)節(jié)的任務(wù)。
填寫下面表單即可預(yù)約申請免費(fèi)試聽!怕錢不夠?可先就業(yè)掙錢后再付學(xué)費(fèi)! 怕學(xué)不會?助教全程陪讀,隨時解惑!擔(dān)心就業(yè)?一地學(xué)習(xí),可推薦就業(yè)!
?2007-2022/ m.lb577.com 北京漫動者數(shù)字科技有限公司 備案號: 京ICP備12034770號 監(jiān)督電話:010-53672995 郵箱:bjaaa@aaaedu.cc