統(tǒng)計

          留言簿(1)

          DB

          Others

          QA

          Tech Website

          閱讀排行榜

          評論排行榜

          【轉(zhuǎn)】Java學習的30個目標以及系統(tǒng)架構(gòu)師推薦的書


          我認為講得到不錯,但有點亂,有時間把它整理下
          ---

          第一階段 
          2.你需要學習JAVA語言的基礎(chǔ)知識以及它的核心類庫 (collections,serialization,streams,networking, multithreading,reflection,event,handling,NIO,localization,以及其他)。 
          5.你需要學習java數(shù)據(jù)庫技術(shù),如JDBCAPI并且會使用至少一種persistence/ORM構(gòu)架,例如Hibernate,JDO, CocoBase,TopLink,InsideLiberator(國產(chǎn)JDO紅工廠軟件)或者iBatis。 
          24.你應(yīng)該熟練掌握一種JAVAIDE例如sunOne,netBeans,IntelliJIDEA或者Eclipse。(有些人更喜歡VI或EMACS來編寫文件。隨便你用什么了:) 
          26.你需要熟悉一種單元測試體系(JNunit),并且學習不同的生成、部署工具(Ant,Maven)。 
          27.你需要熟悉一些在JAVA開發(fā)中經(jīng)常用到的軟件工程過程。例如RUP(RationalUnifiedProcess)andAgilemethodologies。 
          第二階段 
          1.你需要精通面向?qū)ο蠓治雠c設(shè)計(OOA/OOD)、涉及模式(GOF,J2EEDP)以及綜合模式。你應(yīng)該十分了解UML,尤其是class,object,interaction以及statediagrams。 
          3.你應(yīng)該了解JVM,classloaders,classreflect,以及垃圾回收的基本工作機制等。你應(yīng)該有能力反編譯一個類文件并且明白一些基本的匯編指令。
          6.你還應(yīng)該了解對象關(guān)系的阻抗失配的含義,以及它是如何影響業(yè)務(wù)對象的與關(guān)系型數(shù)據(jù)庫的交互,和它的運行結(jié)果,還需要掌握不同的數(shù)據(jù)庫產(chǎn)品運用,比如:oracle,mysql,mssqlserver。 
          7.你需要學習JAVA的沙盒安全模式(classloaders,bytecodeverification,managers,policyandpermissions, 
          codesigning, digitalsignatures,cryptography,certification,Kerberos,以及其他)還有不同的安全/認證 API,例如JAAS(JavaAuthenticationandAuthorizationService),JCE (JavaCryptographyExtension),JSSE(JavaSecureSocketExtension),以及JGSS (JavaGeneralSecurityService)。 
          第三階段 
          10.你需要學習如何使用及管理WEB服務(wù)器,例如tomcat,resin,Jrun,并且知道如何在其基礎(chǔ)上擴展和維護WEB程序。 
          8.你需要學習Servlets,JSP,以及JSTL(StandardTagLibraries)和可以選擇的第三方TagLibraries。 
            4.如果你將要 寫客戶端程序,你需要學習WEB的小應(yīng)用程序(applet),必需掌握GUI設(shè)計的思想和方法,以及桌面程序的SWING,AWT, SWT。你還應(yīng)該對UI部件的JAVABEAN組件模式有所了解。JAVABEANS也被應(yīng)用在JSP中以把業(yè)務(wù)邏輯從表現(xiàn)層中分離出來。(這條可有可 無) 

          9.你需要熟悉主流的網(wǎng)頁框架,例如JSF,Struts,Tapestry,Cocoon,WebWork,以及他們下面的涉及模式,如MVC/MODEL2。 
          14.你應(yīng)該學習如何利用JAVAAPI和工具來構(gòu)建WebService。例如JAX- RPC(JavaAPIforXML/RPC),SAAJ (SOAPwithAttachmentsAPIforJava),JAXB(JavaArchitectureforXMLBinding),JAXM(JavaAPIforXMLMessaging), JAXR(JavaAPIforXMLRegistries),或者JWSDP(JavaWebServicesDeveloperPack)。 
          15.你需要學習一門輕量級應(yīng)用程序框架,例如Spring,PicoContainer,Avalon,以及它們的IoC/DI風格(setter,constructor,interfaceinjection)。 
          20.你需要熟悉對不同有用的API和frame work等來為你服務(wù)。例如Log4J(logging/tracing),Quartz (scheduling),JGroups(networkgroupcommunication),JCache(distributedcaching), Lucene(full-textsearch),JakartaCommons等等。 
          25.JAVA(精確的說是有些配置)是冗長的,它需要很多的人工代碼(例如EJB),所以你需要熟悉代碼生成工具,例如XDoclet 
          第四階段 
          16.你需要熟悉不同的J2EE技術(shù),例如JNDI(JavaNamingandDirectoryInterface),JMS (JavaMessageService),JTA/JTS(JavaTransactionAPI /JavaTransactionService),JMX (JavaManagementeXtensions),以及JavaMail。 
          11.你需要學習分布式對象以及遠程API,例如RMI和RMI/IIOP。 
          12.你需要掌握各種流行中間件技術(shù)標準和與java結(jié)合實現(xiàn),比如Tuxedo、CROBA,當然也包括javaEE本身。 
          17.你需要學習企業(yè)級JavaBeans(EJB)以及它們的不同組件模 式:Stateless/StatefulSessionBeans,EntityBeans(包含Bean- ManagedPersistence[BMP]或者Container-ManagedPersistence[CMP]和它的EJB-QL),或者 Message-DrivenBeans(MDB)。 
          13.你需要學習最少一種的XMLAPI,例如JAXP(JavaAPIforXMLProcessing),JDOM(JavaforXMLDocumentObjectModel),DOM4J,或JAXR(JavaAPIforXMLRegistries)。 
          18.你需要學習如何管理與配置一個J2EE應(yīng)用程序服務(wù)器,如WebLogic,JBoss等,并且利用它的附加服務(wù),例如簇類,連接池以及分布式處理支援。你還需要了解如何在它上面封裝和配置應(yīng)用程序并且能夠監(jiān)控、調(diào)整它的性能。 
          第五階段(優(yōu)先級低 
          19.你需要熟悉面向方面的程序設(shè)計以及面向?qū)傩缘某绦蛟O(shè)計(這兩個都被很容易混淆的縮寫為AOP),以及他們的主流JAVA規(guī)格和執(zhí)行。例如AspectJ和AspectWerkz。 
          21.如果你將要對接或者正和舊的系統(tǒng)或者本地平臺,你需要學習JNI (JavaNativeInterface) and JCA (JavaConnectorArchitecture)。 
          22.你需要熟悉JINI技術(shù)以及與它相關(guān)的分布式系統(tǒng),比如掌握CROBA。 
          23.你需要JavaCommunityProcess(JCP)以及他的不同JavaSpecificationRequests(JSRs),例如Portlets(168),JOLAP(69),DataMiningAPI(73),等等。 
          28.你需要能夠深入了解加熟練操作和配置不同的操作系統(tǒng),比如GNU/linux,sunsolaris,macOS等,做為跨平臺軟件的開發(fā)者。 
          29.你還需要緊跟java發(fā)展的步伐,比如現(xiàn)在可以深入的學習javaME,以及各種java新規(guī)范,技術(shù)的運用,如新起的web富客戶端技術(shù)。 
          30.你必需要對opensource有所了解,因為至少java的很多技術(shù)直接是靠開源來驅(qū)動發(fā)展的,如java3D技術(shù)。

          ====================================================================

          附:

          JAVA系統(tǒng)架構(gòu)師應(yīng)該看的幾本書 
          Thinking in Java 
          Effective Java 

          UML基礎(chǔ)、案例與應(yīng)用 
          UML入門提高 

          軟件工匠
          設(shè)計模式——可復用面向?qū)ο筌浖幕A(chǔ) 

          重構(gòu)-改善既有代碼的設(shè)計 
          敏捷軟件開發(fā)-原則、模式、實踐 

          企業(yè)應(yīng)用架構(gòu)模式 
          Expert One-on-One J2EE Development without EJB 

          軟件工程——實踐者的研究方法 
          軟件領(lǐng)導--成功開發(fā)軟件的指導準則 

          后面的兩本書,其實已經(jīng)有點屬于項目經(jīng)理的范疇了,不過還不是很深入,看看對做成功的系統(tǒng)架構(gòu)師是很有好處。 

          企業(yè)應(yīng)用的系統(tǒng)架構(gòu)師應(yīng)該關(guān)注的幾個方面 (具體情況具體分析,以下未必準確,只是參考)

          先來一些基礎(chǔ)面試題,您答得出么?

          1、說說JVM原理?內(nèi)存泄露與溢出區(qū)別,何時產(chǎn)生內(nèi)存泄露? 
          2、用java怎么實現(xiàn)有每天有1億條記錄的DB存儲?mysql上億記錄數(shù)據(jù)量的數(shù)據(jù)庫如何設(shè)計? 
          3、mysql支持事務(wù)嗎?DB存儲引擎有哪些? 
          4、mvc原理,mvc模式的優(yōu)缺點,如果讓你設(shè)計你會怎么改造MVC? 
          5、hibernate支持集群嗎?如何實現(xiàn)集群? 
          6、tomcat 最多支持并發(fā)多少用戶? 
          7、map原理,它是如何快速查找key的?map與set區(qū)別? 
          8、描術(shù)算法,如何有效合并兩個文件:一個是1億條的用戶基本信息,另一個是用戶每天看電影連續(xù)劇等的記錄,5000萬條。內(nèi)存只有1G??? 
          9、在1億條用戶記錄里,如何快速查詢統(tǒng)計出看了5個電影以上的用戶? ----可以參考 位圖索引的原理 
          10、Spring如何實現(xiàn)IOC與AOP的,說出實現(xiàn)原理?

          數(shù)據(jù)持久層的設(shè)計 
          在Spring和Hibernate,ibatis出來以前,幾乎每家公司都有自己的一套方法和架構(gòu),而架構(gòu)師的50%的精力也會集中到這上面,EJB只是增加架構(gòu)師的負擔。在Spring出來以后,基本上,大多數(shù)的架構(gòu)師都從重復設(shè)計這個輪子的無用功中解脫出來了。Rod的輪子太好用了,基本上,大家只要套上去就行了,或者,剩下最重要的事情,是選擇一個合適的數(shù)據(jù)庫連接池的開源項目吧 

          MVC架構(gòu)的具體設(shè)計 
          MVC只是個概要的概念,具體如何實現(xiàn)的具體技術(shù)很多,根據(jù)項目設(shè)計最恰當?shù)募軜?gòu) 

          大并發(fā)性訪問 
          太多了,包括從廣域網(wǎng)到服務(wù)器到業(yè)務(wù)層再到架構(gòu)再到程序、數(shù)據(jù)庫的各種調(diào)優(yōu),如使用緩存,靜態(tài)化,靜動態(tài)server分離,在數(shù)據(jù)量達到一定程度時,使用集群技術(shù),優(yōu)先考慮利用服務(wù)器的集群,其次是硬件集群,最后才是應(yīng)用本身加入集群功能 

          超大數(shù)據(jù)量返回結(jié)果 
          緩存命中率,分頁,優(yōu)化SQL語句,循環(huán)處理數(shù)據(jù)時盡可能共用對象,只保留關(guān)鍵數(shù)據(jù),及時釋放內(nèi)存占用 

          超大文件的讀取和生成 
          盡可能快的讀取大文件,并進行分析。寫入大文件時,如何及時釋放內(nèi)存。學會適當利用操作系統(tǒng)的命令行資源來更快完成任務(wù)。這方面經(jīng)驗比較少,以后有空研究

          多線程的應(yīng)用和管理 
          線程池的管理和監(jiān)控,線程的啟動(包括定時啟動),結(jié)束,回收,線程資源的釋放 ,這句話太簡單了,待深入研究

          用戶界面可用性設(shè)計 
          平衡速度和可用性,恰當?shù)氖褂卯惒胶屯郊夹g(shù),展現(xiàn)關(guān)鍵數(shù)據(jù)為重點 

          分布式的數(shù)據(jù)交流和集成 
          選擇恰當?shù)臄?shù)據(jù)交互方式,從最泛濫低效的Web Service到最實用的文件共享 

          群集系統(tǒng)的管理 
          如何確保緩存的同步?如何確保對象唯一性?如何保證各臺機器的同步? 
          是否采用EJB?如何利用J2EE的特性(例如JNDI) 

          復雜的業(yè)務(wù)規(guī)則 
          規(guī)則引擎和工作流引擎場景和應(yīng)用 

          其實,作為一個真正的系統(tǒng)架構(gòu)師,不應(yīng)該局限于企業(yè)應(yīng)用的系統(tǒng),這種系統(tǒng)往往有數(shù)據(jù)庫的局限性,有時候,應(yīng)該考慮是否可以橫向跨越,直接對其它系統(tǒng)做一些架構(gòu)考慮,在沒有豐富的實戰(zhàn)經(jīng)驗的前提下,而只是看了其它人的系統(tǒng)和代碼,就能夠給出有效的設(shè)計指導。 

          例如對于一個下載軟件,可以有如下考慮: 

          1. 未明和非法url的檢驗,已經(jīng)下載失敗的容許,信息記錄 
          2. 多線程下載一個文件,文件的切分和拼合,部分切片丟失的拼合可能性 
          3. 下載線程管理 
          4. 服務(wù)器或者P2P的機器之間的通訊協(xié)議 
          5. 速度監(jiān)控和限制 
          6. 下載進度的監(jiān)控和顯示 

          作為一個在線播放軟件,可以做如下考慮 

          1. 播放速度的保證 
          機器的問題基本不存在了,關(guān)鍵是網(wǎng)絡(luò)問題。如何在檢測網(wǎng)絡(luò)速度,根據(jù)影片的質(zhì)量,并緩沖足夠多的內(nèi)容,保證播放一直盡可能順利的完成。 

          2. 播放質(zhì)量的保證 
          如何利用DirectX等技術(shù),最快的進行渲染,是自己寫底層,還是利用已有的API 

          由于沒做過類似的項目,可以寫的東西還是少很多了。 

          系統(tǒng)架構(gòu)師應(yīng)該有的素質(zhì): 
          1、 實際的編程經(jīng)驗 
          最少2年吧,多了就不說了,其實從大學就開始鉆研的話, 

          2、 書面表達能力和口頭交流能力 
          綜合利用架構(gòu)圖,UML圖,文字和代碼片斷,表達自己設(shè)計思想,至于是Word還是ppt,應(yīng)該通吃 

          在開發(fā)人員中發(fā)現(xiàn)架構(gòu)師的最有價值標準是有效的溝通。您需要技術(shù)嫻熟、經(jīng)驗豐富的開發(fā)人員,這樣的人員需要有就項目中的業(yè)務(wù)相關(guān)問題進行溝通的經(jīng)歷。架構(gòu)師經(jīng)常必須對理解方面的差距進行預計,然后才能有所貢獻。他們必須愿意克服困難來確保技術(shù)和業(yè)務(wù)觀點的融合。他們并不必對意見交換工作進行計劃和協(xié)調(diào);這仍然主要是項目經(jīng)理的工作。他們的任務(wù)是確定表述系統(tǒng)設(shè)計時的最佳工具和構(gòu)件,以促進有效的意見交換。他們必須能夠判斷當前方法顯得不足而需要采用新方法的情況。寫作技能也非常重要,還需要具有制作草圖的技能或使用制圖軟件的能力。 

          3、 自覺主動;積極解決設(shè)計問題 
          架構(gòu)師的日常工作目標經(jīng)常并不明確。很多開發(fā)人員直接參考功能規(guī)范來列出任務(wù)清單。架構(gòu)師通常則是向這些開發(fā)人員提供所需結(jié)構(gòu)的人員,以便盡可能提高工作效率。好的候選者不僅進行溝通方面的工作,而且也會預計各種設(shè)計問題并加以解決——通常在沒有任何具體指示的情況下自覺進行。無論所分配的職責如何,積極參與項目的開發(fā)人員都有機會從一起工作的人員中脫穎而出。 

          4、 抽象思維能力和總結(jié)能力 
          架構(gòu)師,顧名思義,在系統(tǒng)未搭建好之前,就要能夠有一個草圖在心。而如果是對現(xiàn)有系統(tǒng)的改造,那么能在看過系統(tǒng)的文檔(如果有的話)和代碼后,就能總結(jié)出系統(tǒng)的架構(gòu)特點。 
          架構(gòu)師必須能夠理解表述模糊的概念并將其變成相關(guān)各方能夠理解的項目構(gòu)件。他們必須能夠理解抽象概念,并以具體的語言對其進行溝通。開發(fā)人員中好的候選者經(jīng)常要求或自己主動解釋開發(fā)生命周期中容易混淆的問題。他們能迅速評估各種想法并將其納入后續(xù)工作的操作建議中。 

          開發(fā)人員經(jīng)常具有很強的數(shù)學能力,而好的架構(gòu)師則傾向于表現(xiàn)出更強的口頭表達能力。管理人員經(jīng)常說開發(fā)人員具有“工程意識”,而這是一個用于評估架構(gòu)師的非常有意義的方面。架構(gòu)師應(yīng)該具有很強的解決技術(shù)問題的能力,但還必須能夠準確獲知更為全面的人員如何與技術(shù)交互的信息。這要求具有某種形式的抽象思維(而不再是代碼的細節(jié)),這種思維能力可能較難形成。 

          5、 全面的技術(shù)資訊吸收能力和選擇鑒別能力 
          作為開發(fā)人員出身,對于某一個具體問題的研究能力(雖然很多人總結(jié)為google能力),已經(jīng)相當具備了。但是對技術(shù)資訊的全面接受和選擇性深入了解能力,并且做出正確的判斷,那些技術(shù)無非是廠家的噱頭,而那些技術(shù)是真正可以用到項目,提高項目質(zhì)量的好技術(shù),這種能力確實至關(guān)重要的。



          posted on 2011-06-18 15:25 XXXXXX 閱讀(692) 評論(1)  編輯  收藏 所屬分類: Programing

          評論

          # re: 【轉(zhuǎn)】Java學習的30個目標以及系統(tǒng)架構(gòu)師推薦的書 2011-06-22 10:36 海賊_路飛

          技術(shù)不是說你學了多少 而是說你用了多少 理解了多少   回復  更多評論   

          主站蜘蛛池模板: 宿迁市| 甘南县| 金门县| 惠州市| 绵阳市| 资阳市| 武川县| 抚松县| 新龙县| 寿阳县| 稻城县| 尼玛县| 河池市| 弥勒县| 若尔盖县| 渭源县| 潞城市| 通化市| 化德县| 辽源市| 张家川| 井陉县| 安义县| 北川| 西林县| 泰宁县| 开远市| 汶川县| 北辰区| 阳朔县| 平罗县| 万州区| 富裕县| 虞城县| 波密县| 岐山县| 仲巴县| 汉阴县| 中卫市| 额敏县| 当雄县|