您好,登錄后才能下訂單哦!
小編給大家分享一下springboot獲取工具類bean過程的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
這次的實踐經驗的起因在于,在開發中,我想在工具類中使用配置文件的變量值。通常使用@value注解,這個只能在spring中管理的bean總獲取。之前我也很疑惑,為什么之前的開發人員會在SpringUtil類上加入@Component注解,今天又遇到這種情況,其原因完全理解了。
@Componentpublic class SpringUtil implements EnvironmentAware { private static Environment env; public static String getProperty(String key){ return env.getProperty(key); } @Override public void setEnvironment(Environment environment) { injectEnvironment(env); // 因為spring會創建這個接口的實現類的一個對象,所以實例方法調用靜態方法,只是目前這個類我們是看不到的 } public static void injectEnvironment(Environment env){ SpringUtil.env = env; // 這其實是實例方法調用靜態方法 }}
這個原理很簡單,就是實例方法調用靜態方法,所以還是生成了對象,只生產了一個工具類對象,而不是很多,這很java,很spring。相應的,@Service注解的也是單例(這應該是基于方法是天然并行的,每次調用方法,都會生成自己的數據棧),也可以看到,這spring中使用對象很合適,可以忽略創建對象的開銷。
學習spring,我們都知道spring的一個重要功能就是對象管理。那么一個重要的問題就是:我們如何獲取我們想要的Bean?spirng中有沒有一個靜態類,通過名字直接獲取對象。
很抱歉,這不是spring的正確打開方式,雖然使用靜態類是多么的直白,但是spring并沒這樣實現。通常的做法也是同上,就是通過spirng注入ApplicationContext對象,這就是一個bean容器,然后就可以獲得我們想要獲得的類了。很報謙,你也無法自己new 一個ApplicationContext對象,這也許是保持運行環境中只有一個ApplicationContext對象吧。
單例就是一種簡潔美。至于為什么使用單例而不使用靜態類,我覺得原因有二:
1.單例的創建和銷毀方遍,可以在不使用時節約資源
2.我們繼承的類,大多數是實例方法和實例變量(至于為甚是實例方法和實例變量,應該是很絕大多數類都要實例化,并且可能有多個對象),那么繼承的時候就是實例方法和實例變量,可以說這是面向對象編程風格在單例情況下的影響。單例的缺點可能就是生成對象的開銷,現在這已經不算什么了。
以上是“springboot獲取工具類bean過程的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。