您好,登錄后才能下訂單哦!
這篇文章主要講解了“super的工作原理是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“super的工作原理是什么”吧!
深扒源碼之前,一定要做好參考點,這里我們使用類圖來做一個參考。
super這個方法對應的代碼并不多,如果我們要去跟的話,只需要仔細一點,了解他的層級結構,基本問題不大。這里把所有源碼都拿出來了
public ClassPathXmlApplicationContext(ApplicationContext parent) { super(parent); } public AbstractXmlApplicationContext(@Nullable ApplicationContext parent) { super(parent); } public AbstractRefreshableConfigApplicationContext(@Nullable ApplicationContext parent) { super(parent); } public AbstractRefreshableApplicationContext(@Nullable ApplicationContext parent) { super(parent); } public AbstractApplicationContext(@Nullable ApplicationContext parent) { this(); this.setParent(parent); } public AbstractApplicationContext() { this.resourcePatternResolver = getResourcePatternResolver(); } protected ResourcePatternResolver getResourcePatternResolver() { return new PathMatchingResourcePatternResolver(this); } public PathMatchingResourcePatternResolver(ResourceLoader resourceLoader) { Assert.notNull(resourceLoader, "ResourceLoader must not be null"); this.resourceLoader = resourceLoader; } public void setParent(@Nullable ApplicationContext parent) { this.parent = parent; if (parent != null) { Environment parentEnvironment = parent.getEnvironment(); if (parentEnvironment instanceof ConfigurableEnvironment) { getEnvironment().merge((ConfigurableEnvironment) parentEnvironment); } } }
從我們的源碼上來看,結合我們的類圖,不難發現,其實super(parent)一直在調用父類的方法,直到AbstractApplicationContext,然后才有真正的操作代碼。
先來看看this(),this()實際就是我們當前類里面的無參構造方法,最終其實也是給我們初始化了一個ClassPathXmlApplicationContext。這一點我們可以跟一下初始化的代碼
public Resource getResource(String location) { return getResourceLoader().getResource(location); } public Resource getResource(String location) { Assert.notNull(location, "Location must not be null"); for (ProtocolResolver protocolResolver : getProtocolResolvers()) { Resource resource = protocolResolver.resolve(location, this); if (resource != null) { return resource; } } if (location.startsWith("/")) { return getResourceByPath(location); } else if (location.startsWith(CLASSPATH_URL_PREFIX)) { return new ClassPathResource(location.substring(CLASSPATH_URL_PREFIX.length()), getClassLoader()); } else { try { // Try to parse the location as a URL... URL url = new URL(location); return (ResourceUtils.isFileURL(url) ? new FileUrlResource(url) : new UrlResource(url)); } catch (MalformedURLException ex) { // No URL -> resolve as resource path. return getResourceByPath(location); } } }
最終是按照我們的路徑的開頭判斷返回哪種resource
setParent(parent);對應的代碼并不多,也是比較簡單明了的
public void setParent(@Nullable ApplicationContext parent) { this.parent = parent; if (parent != null) { Environment parentEnvironment = parent.getEnvironment(); if (parentEnvironment instanceof ConfigurableEnvironment) { getEnvironment().merge((ConfigurableEnvironment) parentEnvironment); } } }
這幾部代碼就做了一件事情:保存父容器,并將父容器的環境與當前容器環境合并。
感謝各位的閱讀,以上就是“super的工作原理是什么”的內容了,經過本文的學習后,相信大家對super的工作原理是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。