源碼看不懂
❶ 怎樣才能看懂網頁的源代碼
可用HTML語言理解網頁源代碼。
通常用來編寫網頁的計算機語言有如下三種:
1、HTML語言:最常用最基本的語言,在網頁中不可或缺。網頁的標題、框架、背景、字體、超鏈接、顏色和其他元素的設置是用HTML語言完成的。Html是VB和jav的載體,網頁的後綴名一般為「.HTM」或者「.HTML」。
2、VB語言,又稱visual basic語言,可以進行HTML語言在網頁中無法完成的計算、效果、調用各種數據亂物御庫等。它屬於一種相對高級的語言螞搏,賦予網頁以靈魂,豐富了網頁,使用HTML和VB語言共同編寫的網頁的後綴名一般為「.ASP」。
3、java語言,Java語言的功能與VB語言幾乎相同,但它的功能更強大,其效果可能是壓倒性的。現在大多數動態網頁都是用HTML和Java語言編寫的,後綴名一般為「.ASP」或者「.JSP」。
(1)源碼看不懂擴展閱讀:
HTML語言編輯方式:
HTML其實是文本,它需要瀏覽器的解釋嘩岩,它的編輯器大體可以分為以下幾種:
基本的文本和文檔編輯軟體可以使用微軟自己的記事本或寫字板來編寫,當然,如果使用WPS,你也可以,但是,保存磁碟時,請使用,HTM或,HTML作為擴展,使瀏覽器能夠識別和直接解釋執行。
半所見即所得軟體,如:fck編輯器、e-webedit和其他在線網頁編輯器;特別推薦:Sublime文本代碼編輯器(由Jon Skinner開發,Sublime text2收費,但可以無限期試用)。
❷ 如何高效閱讀源代碼
下面是之前寫的一篇文章:《如何快速閱讀源碼》
本文探討在需要了解一個開源項目時,如何快速的理清開源項目的代碼邏輯!
以下是個人認為行之有效的方法:
本文以Mybatis為例來進行演示!
先「跑起來」程序界有個老傳統,學習新技術時都是從「Hello World」開始的!無論是學習新語言時,列印「Hello World」;還是學習新框架時編寫個demo!那為什麼這里的「跑起來」要打個引號呢?
實際上,當你想要閱讀一個開源項目的源碼時,絕大部分情況下,你已經能夠使用這個開源項目了!所以這里的「跑起來」就不是寫個「Hello World」,也不是能跑起來的程序了!而是能__在你的腦子里「跑起來」__!什麼意思?
Mybatis你會用了吧?那麼請問Mybatis是如何執行的呢?仔細想想,你能否用完整的語句把它描述出來?
這里是Mybatis的官方入門文章!你是如何看這篇文章的?讀一遍就行了嗎?還是跟著文章跑一遍就夠了嗎?從這篇文章里你能獲得多少信息?
我們來理一下:
回答出了上面這些問題!你也就基本能在腦子里把Mybatis「跑起來」了!之後,你才能正真的開始閱讀源碼!
當你能把一個開源項目「跑起來」後,實際上你就有了對開源項目最初步的了解了!就像「 書的索引 」一樣!基於這個索引,我們一步步的進行拆解,來細化出下一層的結構和流程,期間可能需要深入技術細節,考量實現,考慮是否有更好的實現方案!也就是說後面的三步並不是線性的,而是__不斷交替執行__的一個過程!最終就形成一個完整的源碼執行流程!
自頂向下拆解繼續通過Mybatis來演示(限於篇幅,我只演示一個大概流程)!我們現在已經有了一個大概的流程了:
雖說每個點都可以往下細化,但是也分個輕重緩急!
很明顯,sqlSession去執行 sql才是Mybatis的核心!我們先從這個點入手!
首先,你當然得先下載Mybatis的源碼了(請自行下載)!
我們直接去看SqlSession!它是個介面,裡面有一堆執行sql的方法!
這里只列出了一部分方法:
SqlSession就是通過這些方法來執行sql的!我們直接看我們常用的,也是Mybatis推薦的用法,就是基於Mapper的執行!也就是說「SqlSession通過Mapper來執行具體的sql」!上面的流程也就細化成了:
那SqlSession是如何獲取Mapper的呢?Mapper又是如何執行sql的呢?
深入細節我們來看SqlSession的實現!SqlSession有兩個實現類SqlSessionManager和DefaultSqlSession!通過IDE的引用功能可以查看兩個類的使用情況。你會發現SqlSessionManager實際並沒有使用!而DefaultSqlSession是通過DefaultSqlSessionFactory構建的!所以我們來看DefaultSqlSession是如何構建Mapper的!
它直接委託給了Configuration的getMapper方法!
Configuration又委託給了MapperRegistry類的getMapper方法!
在MapperRegistry類的getMapper中:
在這里knowMappers是什麼?MapperProxyFactory又是什麼?mapperProxyFactory.newInstance(sqlSession)具體做了什麼?
其實很簡單,knowMappers是個Map,裡麵包含了class與對應的MapperProxyFactory的對應關系!MapperProxyFactory通過newInstance來構建對應的Mapper(實際上是Mapper的代理)!
快接近真相了,看mapperProxyFactory.newInstance(sqlSession)里的代碼:
這里幹了什麼?
最終實際還是委託給了sqlSession去執行具體的sql!後面具體怎麼實現的就自行查看吧!
延伸改進現在我們的流程大概是這樣的一個過程:
現在我們大概知道了:
那麼,
這個問題列表可以很長,可以按個人需要去思考並嘗試回答!可能最終這些問題已經和開源項目本身沒有什麼關系了!但是你思考後的收獲要比看源碼本身要多得多!
再循環一輪結束後,可以再次進行:
不斷的拆解->深入->改進,最終你能__通過一個開源項目,學習到遠比開源項目本身多得多的知識__!
最重要的是,你的流程是完整的。無論是最初的大致流程:
還是到最終深入的細枝末節,都是個完整的流程!
這樣的好處是,你的時間能自由控制:
而不像debug那樣的方式,需要一下子花費很長的時間去一步步的理流程,費時費力、收效很小,而且如果中斷了就很難繼續了!
總結本文通過梳理Mybatis源碼的一個簡單流程,來講述一個個人認為比較好的閱讀源碼的方式,並闡述此方法與傳統debug方式相比的優勢。
閱讀源碼是每個優秀開發工程師的必經之路,那麼這篇文章就來講解下為什麼要閱讀源碼以及如何閱讀源碼。
首先來說下為什麼要讀源碼,有學習源碼的必要嗎?
為什麼要閱讀源碼?
關於為什麼閱讀和學習源碼,我個人認為可能有以下幾點:
(一)吊打面試官,應對面試
為了找到更好的工作,應對面試,因為在面試中肯定會問到源碼級別的問題,比如:為什麼 HashMap 是線程不安全的?
如果你沒有閱讀過源碼,面試官可能會對回答的結果不滿意,進而導致面試結果不太理想,但如果你對源碼有所研究,並能夠很好地問答面試官的問題,這可能就是你的加分點,可以形成自己獨特的競爭力,吊打面試官,升職加薪不是夢。
(二)解決問題(bug)
在開發過程中,我們或多或少會遇到 bug,比如:在 foreach 循環里進行元素的 remove/add 操作,為啥有可能會報 異常?
我們可以先在 Google、Stack Overflow 以及對應項目的 Issues 里看有沒有類似問題以及解決辦法,如果沒有的話,我們只能通過閱讀源碼的方式去解決了。如果我們對相關源碼有所涉獵,就可以快速定位到問題所在。
(三)提升編程能力
和閱讀一本好書一樣,閱讀源碼就是和編程大牛面對面交流的機會,在許多優秀的開源項目中,它們的編碼規范和架構設計都是很棒的,另外在設計上也使用了大量的設計模式,通過閱讀和學習源碼,能夠快速提升我們的編碼水平,以及對設計模式有更深的理解。
同時,在我們閱讀完一個源碼後,可以觸類旁通,能夠快速地對其他框架的源碼進行閱讀和學習,減少時間成本。
除了上述提到的原因之外,可能還有許多,在這里就不一一贅述了,那麼在確定了要閱讀源碼之後,就讓我們看下如何閱讀源碼吧!
如何閱讀源碼?
如何閱讀源碼取決於你為什麼要讀源碼,比如:
下面大概說下閱讀源碼的幾點建議:
在閱讀之前,可以先從開源項目的官網上看它的架構設計和功能文檔,了解這個項目的 整體架構、模塊組成以及各個模塊之間的聯系 。
如果沒有對應的項目文檔,可以根據代碼的模塊進行梳理,以形成對項目的初步了解,或者 查看已有的源碼解析文章或者書籍 ,在閱讀源碼之前,了解項目的架構和思路會使閱讀源碼事半功倍。
在了解一個類的時候,可以使用 ctrl+F12 來查看類中的成員變數和方法。
可以通過 IDEA 的 Diagrams 功能去了解一個類的繼承關系。
多打 斷點調試 ,斷點追蹤源碼是很好的閱讀源碼的方式,可以先通過 debug 了解下調用邏輯,都和哪些類有關聯,有大致了解後再通過 debug 了解整體代碼的功能實現,各個類都起到了什麼作用,有沒有涉及到設計模式等。
另外,優秀的開源項目中肯定會有許多地方應用到了 設計模式 ,建議在閱讀源碼之前,需要對常用的設計模式有大致的了解,不然閱讀源碼的效率會大大降低。
如果遇到讀不懂某部分源碼的時候,可以先跳過,之後再回來看,如果屬於搞不懂這部分就茶不思飯不想的人,可以在網上找是否有該部分源碼的解析或者文檔,也可以自己通過 源碼注釋和測試用例 去閱讀學習。
一般優秀的開源項目都會有 單元測試 ,可以通過對應類的單元測試去了解方法的含義和用法,加深對源碼邏輯的理解。
在閱讀源碼的時候,可以在代碼上加上 注釋和總結 ,同時還可以畫出 時序圖和類圖 ,這樣對閱讀源碼有很大的幫助,可以很清楚地知道類之間的調用關系和依賴關系,也方便以後回顧,重新閱讀。
在這里推薦大家一個 IDEA 插件 SequenceDiagram,可以根據源碼生成調用時序圖,便於閱讀源碼。
剛開始閱讀源碼,不建議直接看框架源碼,可以先從 jdk 源碼看起:
jdk 源碼也是非常龐大的,可以分模塊來閱讀,下面是建議的閱讀順序:
其他包下的代碼也可以做下了解,JDK源碼閱讀筆記:https://github.com/wupeixuan/JDKSourceCode1.8
再有了一定的源碼閱讀經驗後,可以再去學習 Spring、Spring Boot、Dubbo、Spring Cloud 等框架的源碼。
總結主要介紹了為什麼讀源碼以及如何讀源碼,供大家參考,每個人都有適合自己的閱讀源碼的方式,希望可以在學習中去摸索出一套屬於自己的方式。
閱讀源碼不是一蹴而就的,這是持久戰,只要你能夠堅持下來,肯定受益匪淺。閱讀源碼的過程比較枯燥,可以在社群里一起討論學習,這樣可能效率更高些。
沒看過源代碼,都不好意思出來說了,最近剛好在看一些,來說一個。
先看使用 https://element.eleme.cn/#/zh-CN/component/installation
先看一下這個庫是做什麼用的,然後提供了哪些功能。
看GitHub https://github.com/elemefe
一般會看下項目最新的情況,然後沒有關閉的issue,看下wiki,大家在討論什麼。
再看代碼
clone 一份到本地,然後先看下目錄結構,然後根據文檔看幾個簡單的組件的時候,一邊看掘金上的分析,一邊自己看下實現。
e le
餓了么這個框架代碼結構還是很清楚的,基本上每個組件都是分開的,所以你只要看其他的一個文件夾就行。然後一些工具的都在src文件夾。
要學會看issue,一般開源的項目都有人會來提建議,有些是bug,有些是功能,你可以看看自己是否有能力去解決,如果可以的話,你可以去fork代碼,然後自己修改,再提pr。
我最近恰好找摸索出一個梳理遺留系統架構的技巧:自底向上 找到一個典型的切面 沿著調用和回調的路徑 在代碼中添加結構化注釋(比如eclipse中加//TAG 流程A1.1 甲->>乙),這樣便得到了一個code地圖,並且在tasks視圖中看起來很直觀(看起來跟書的目錄一樣)可快速跳轉。將目錄到有道雲筆記的markdown序列圖中 就自動生成了一個序列圖。
我覺得這基本上就是可縮放的可視化架構地圖了,對維護一個比較亂和龐大的遺留系統非常有幫助,定位代碼 修改維護都方便多了。
1、需要過硬的基礎知識,這個前提。不然基本語法、常用的模式都不曉得怎麼讀。
2、多參考 歷史 版本和更新變化,好的源碼都是反復迭代出來的精華,開始就讀精華是很不明智的,所以看看版本更新說明,版本的 歷史 演變。就想人一樣是怎樣進化過來的。
3、參考別人閱讀注釋,想必在你讀源碼之前也有人讀過了源碼,並且總結,注釋。和分享原理,可供你參考,畢竟每個人讀一篇文章,理解的東西是有差異化的。
4、直接買書,有些作品直接出書就是源碼精解
5、找個大神給你慢慢分析,這個最快。娓娓道來,直接面授比啥都強。缺點是,你容易跟著他的思維走下去。
我覺得閱讀代碼就不應該高效,而應該像看小說一樣,看的過程就像是在和作者交流,有趣才是看代碼的動力。
畫圖,看數據走向,邏輯走向
先弄清楚這些代碼實現了哪些功能,然後從主線開始往下看,好的代碼光看變數和介面名稱就能明白是什麼意思?扒出源碼實現的整體框架邏輯,然後再對自己感興趣的模塊進行剖析,還是從整體把握,細節深入,慢慢地整個框架就被豐滿了。
接下來是思考為什麼要如此設計,這樣設計的好處是什麼?如果是你來做應該怎麼設計,把你覺得源碼缺點的地方進行仔細研究,了解裡面是否包含自己不清楚的細節,避免遺漏。
接下來就是根據代碼改造或者是調試錯誤,對於源碼中遇到的不理解的地方一定要弄明白,有的確實是畫蛇添足,有的有獨特的作用。
多多學習,對每一種主流框架銘記於心,對主流設計模式了如指掌,萬變不離其宗,源碼看多了,跟看一個電視機遙控器的操作說明一樣。
1、一邊閱讀代碼一邊寫注釋。這是我用過的最好的方法,對代碼理解得更深入,看一些重要代碼或者特別難懂的代碼時挺有用。更何況,注釋也是一種文檔嘛。
2、一邊閱讀代碼一邊繪制UML。這個方法適用於類之間的關系較復雜和調用層次較深的情況,我一般都是先繪制順序圖,然後為順序圖中的類繪制關系圖。
3、通過Debug來跟蹤程序的主要執行過程,這樣就可以分清主次了,閱讀的時候更有針對性。
4、類的快速閱讀。先弄清楚它在繼承鏈中的位置,看看它的內部狀態,也就是成員變數,一般來說,類的對外介面都是對成員變數的訪問、加工、代理等,然後看看它的對外介面,也就是公有成員函數,識別核心的一個或多個函數,這時候你應該可以大概了解這個類的職責或作用了。可能這個類是某個設計模式中的一個組成部分,所以,設計模式的掌握對代碼的快速閱讀也是很有幫助的。
5、帶著問題去閱讀。比如想了解android中的消息機制,那麼看看Looper、Handler、MessegeQueue這幾個類就可以了,其他的不要去看,要不然就跑題了。
下面列幾個閱讀源碼時所處的情景,在特定場景下用哪些方法: 不太熟悉業務邏輯,還不是很清楚它是幹啥的,可以用3、5。 代碼量很大,有幾十萬行,甚至百萬行,可以用2、3、5。 你無法看見程序的運行過程,比如沒有用戶界面,也有可能是無法運行的,可以用3、5。 設計復雜,用了大量的設計模式,調用鏈很深,可以用1、2、3、4、5。 時間有限,沒有那麼多時間讓你看源碼,可以用3、5。
畫出邏輯流程圖,先了解整體流程,再詳解具體函數
❸ stl源碼剖析什麼水平能看懂
高水平。蘆緩STL是步進觸點指令SequentialFunctionChart的簡稱,是PLC命令,用來作順序功能圖。是一種很很復雜的源碼,在沒有學習過的情況下是看不懂的,因此是很高水平的才能看懂源碼剖析。此種命令可以讓我們程式設消毀計人員在程式規劃時,能夠像平時寫流程圖一樣,對於程式的步序更為清楚,更具有可拿嘩備讀性。
❹ 代碼小白,想要把php網頁中的某處文字內容做修改,但是在源碼後台看不懂啊,請技術大神幫忙,謝謝。
你需要下載一個notepad++,然後打開這個目錄里任意一個文件。
然後按ctrl+H
也可以直接使用在文件中替換,你只需要在替換為輸入框里寫入目標文字比如'LO萌娘社區'。
❺ 我很想學編程,但看不懂編程代碼怎麼辦
我也在自學當中,起初是看不懂的,看了犯困是常事,首先,我覺得應該給自己定一個理想吧,你要真的喜歡上它,因為它真的具有魔法,可以改變現實。其次,可以先做有意思的事,產生興趣,比如在網上跟著教程做一款小游戲。最後是認准方向,花時間,精力,投入熱情,看書,文檔,教程,小時候我們也不懂古詩是什麼意思,當年紀大一些就理解了,你發現你已經會背誦很多年了,加油??,堅持也是一種魔力。???
1.確定你要幹嘛然後在學,不要想搞設置學java,想做web學python,想搞人工智慧學js.
2.選定目的後,選擇語言.
3.選定語言後,google相關的語言,然後去辛苦的備戰吧
-1.把官方文檔看熟悉,搞清楚大脈絡,如果是高級語言,應該離不開,類,函數,繼承,數據類型,裝飾器巴拉巴拉
-2.去163study或者bilibili隨便找一個教程,做一些你喜歡的事情.
-3.等你把你想做的事情做成之後,拿著你的成果去面試吧,多面試失敗幾次你就大概懂了這行了
-4.失敗無數次後你就成為了我一個程序猿天天爬樹,盪來盪去,挺好玩的.
我本人也是一個編程愛好者,以下以我的個人見解,提出個人的一些橘讓看法和建議。
我認為這個問題問得本身就顯得有點矛盾,想學卻擔心自己看不懂代碼學不來,試問哪個編程人員不是從零開始的。
1、堅定信念
我認為學習是一種從心開始的過程,圓絕局想學就說明有學習的心,有心之後就是行動。很多人開始有學習的心是受到外界因素的影響,比如說看別人學習編程可以自己編寫一些小程序、APP之類的很酷,然後自己就滋生想學習編程的想法,又或者是看到別人、聽別人說學習編程日後就業好、工資好、可以做副業等等之類的好處萌生學編程的想法,但真正把心落地,拿起編程書,看編程視頻,開始接觸代碼時,發展學習編程並沒有自己想像中的那麼簡單,又開始打退堂鼓了,覺得自己不行,學不來編程等等,開始對編程產生排斥心理,這樣自然也就不可能學會編程。我認為學習編程,必須要有堅定的學習編程的信念。
2、從零開始
學習編程是一個逐漸積累、不斷提升的過程。剛接觸編程就得從最最基礎的知識學習,磚頭是蓋成摩天大廈的基礎,沒有堅實的基礎哪會有大廈。學習編程初期從零開始學習編程基礎理論知識,記憶編程代碼,有了初步的編程認知後,簡單實操感受編程的魅力。有了基礎以後就是提升,多看實例,學習編程的編程方法,看多了自然也就會了,同時融匯貫通形成自己的編程手法,這需要時間的積累、沉澱,正所謂沒有量變怎麼會有質變出現。
以上是我的個人見解,希望對你有所幫助,謝謝!
本人就是一個半路出家的程序猿,說一下自身的經歷吧!當決定要去學編程的時候,首先是在網上找了一些相關的課程視頻!了解一些基本的知識,對於一個小白來說,不建議上來就去看專業的編程數據!因為確實是看不懂,然後就會對自己產生質疑,是不是自己不是學這行的料,然後就放棄了,看視頻的好處相對於書來說,更有吸引力一些。更有利於自己的堅持。然後就是報培訓班的問題,報班的好處在於有一個很好的學習氛圍,身邊都是志同道合之人,這樣不會半途而廢,畢竟現在的培訓班都不便宜,一旦報了培訓班,就沒有了退路,這樣自宏基己只能一往無前的去學習!我在培訓的時候,中途也想過放棄,到一想到自己交了這么多錢,花了這么多時間,就咬牙堅持了下來!最後就是培訓出來後慢慢找工作!總之對於想學編程的朋友一定要考慮清楚,畢竟現在這個行業競爭真的很激烈,需要始終保持學習,不然說不定那天就被淘汰了,一旦想好,去一條道走到黑了
你出現這問題的原因,不是編程太難。是你基礎都不了解就跑去看源碼。還有就是你不是天才,才看不懂代碼。
輸入輸出,變數聲明,循環結構,分支結構看過嗎?ide,運行環境配置好了么。
凡事不要急於求成,踏踏實實的慢慢學。代碼不難,是人太笨,想法上有問題。去b站上學習吧。路子沒找對,覺得難,其實很簡單。
聲明:我也是編程愛好者。這是我的原創回答!非搬運工!手工一個字一個字碼出來的!答案往下看。
自學編程可以啊!方便透露下年齡,還有英語方面程度?還有你要做什麼軟體?我只能猜測個大概,作出如下表述。建議補全想法。好有針對性。
根據你所說的情況,結合我學編程的經歷,建議如下
推薦使用「易語言」編程,因為是中文編程軟體,不需要記英文!比起其他編程語言C、C++、Delphi等容易上手!重點來了,好多外G作者都是用易語言的。某些病毒也是易語言寫的。
所以,建議你先從易語言著手,打好基礎!再學別的!學易語言任何年齡段都能上手!
附:易語言最新版本5.9。自行搜索下載即可。這里就不貼出具體下載地址啦。
題外話,很好奇問答的答案為何非要湊字數??普遍是一堆廢話。我用手機打字半小時,只是表達一個重點:請先從「易語言」學起!!保證立馬見效果!附圖是易語言官網截圖。
除非你是天才,否則沒有學過和有基礎的前提下,你不太可能看懂,編程還是比較燒腦的,有興趣做,有毅力做下去,且需要長期的學習和實踐,這些你都能接受後,那就開始從基礎學習吧,網上的各種教程,免費的,收費的,按照學習路線前進
你好,我是一個大學的任課老師,現在就是帶學生軟體編程的相關課程,每個初學編程都會有你這樣的感受,學習軟體編程是一個一點一滴積累的過程,沒有誰開始就能懂得程序代碼,他是一個循環漸進一步步邊學習邊理解的過程,需要時間去積累經驗和理解的過程,隨著學習的深入,慢慢的對於以前不理解的問題或者編碼過程以及思想也就會慢慢理解的,不要著急,知識的沉澱需要一個過程,你要做的就是努力。加油
首先為你這個愛好點贊(?ò?ó?),編程又分好多種,
編寫電腦軟體c語言,要是個人寫的玩易語言都可以。
手機呢你就關注華為那個鴻蒙系統學那個就好
網站又phphtm5..等
其實都很簡單,多年以前我也這樣暈??。工作用到一點就學一點知道就行。時間和精力有限不能浪費的就千萬不要浪費。
都是從淺入深,確定了方向就努力學習吧??加油(???_??)?
"