版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第Spring三級(jí)緩存解決循環(huán)依賴這樣拿到A的對(duì)象之后,B的屬性填充完畢,B初始化完成,方法return到DefaultSingletonBeanRegistry#getSingleton的重載方法時(shí),調(diào)用DefaultSingletonBeanRegistry#addSingleton方法,將B對(duì)象放入一級(jí)緩存,并將B從二三級(jí)緩存中移除(雖然已經(jīng)沒(méi)有了)。
這樣在return回A的流程,第11步,將A依賴的B屬性填充完整,此時(shí)A也填充完畢,初始化完成,方法繼續(xù)return到A流程的DefaultSingletonBeanRegistry#getSingleton的重載方法時(shí),調(diào)用DefaultSingletonBeanRegistry#addSingleton方法,將A對(duì)象放入一級(jí)緩存,并將A從二三級(jí)緩存中移除(此時(shí)只有二級(jí)緩存中有)。
這樣A和B就初始化完成了。
如果A或者B存在AOP,需要返回代理對(duì)象,這操作是在第9步的AbstractAutowireCapableBeanFactory#getEarlyBeanReference中完成的,B嘗試獲取A的時(shí)候,觸發(fā)了這個(gè)方法,如果A需要被代理,則是在這個(gè)方法中執(zhí)行的,這個(gè)方法最終返回了一個(gè)代理對(duì)象,并將這個(gè)對(duì)象以A的名義放入了二級(jí)緩存。
打完收工。
源碼
AbstractApplicationContext#refresh#finishBeanFactoryInitialization入口類方法刷新上下文,初始化BeanFactory,完成工廠初始化。
DefaultListableBeanFactory#preInstantiateSingletons準(zhǔn)備實(shí)例化單例對(duì)象
@Override
publicvoidpreInstantiateSingletons()throwsBeansException{
if(logger.isTraceEnabled()){
logger.trace("Pre-instantiatingsingletonsin"+this);
//Iterateoveracopytoallowforinitmethodswhichinturnregisternewbeandefinitions.
//Whilethismaynotbepartoftheregularfactorybootstrap,itdoesotherwiseworkfine.
ListStringbeanNames=newArrayList(this.beanDefinitionNames);
//Triggerinitializationofallnon-lazysingletonbeans...
for(StringbeanName:beanNames){
RootBeanDefinitionbd=getMergedLocalBeanDefinition(beanName);
if(!bd.isAbstract()bd.isSingleton()!bd.isLazyInit()){
if(isFactoryBean(beanName)){
Objectbean=getBean(FACTORY_BEAN_PREFIX+beanName);
if(beaninstanceofFactoryBean){
FactoryBeanfactory=(FactoryBean)bean;
booleanisEagerInit;
if(System.getSecurityManager()!=nullfactoryinstanceofSmartFactoryBean){
isEagerInit=AccessController.doPrivileged(
(PrivilegedActionBoolean)((SmartFactoryBean)factory)::isEagerInit,
getAccessControlContext());
else{
isEagerInit=(factoryinstanceofSmartFactoryBean
((SmartFactoryBean)factory).isEagerInit());
if(isEagerInit){
getBean(beanName);
else{
getBean(beanName);
//Triggerpost-initializationcallbackforallapplicablebeans...
for(StringbeanName:beanNames){
ObjectsingletonInstance=getSingleton(beanName);
if(singletonInstanceinstanceofSmartInitializingSingleton){
StartupStepsmartInitialize=this.getApplicationStartup().start("spring.beans.smart-initialize")
.tag("beanName",beanName);
SmartInitializingSingletonsmartSingleton=(SmartInitializingSingleton)singletonInstance;
if(System.getSecurityManager()!=null){
AccessController.doPrivileged((PrivilegedActionObject)()-{
smartSingleton.afterSingletonsInstantiated();
returnnull;
},getAccessControlContext());
else{
smartSingleton.afterSingletonsInstantiated();
smartInitialize.end();
AbstractBeanFactory#getBean(java.lang.String)獲取bean對(duì)象
@Override
publicObjectgetBean(Stringname)throwsBeansException{
returndoGetBean(name,null,null,false);
AbstractBeanFactory#doGetBean實(shí)際執(zhí)行獲取bean對(duì)象
*Returnaninstance,whichmaybesharedorindependent,ofthespecifiedbean.
*@paramnamethenameofthebeantoretrieve
*@paramrequiredTypetherequiredtypeofthebeantoretrieve
*@paramargsargumentstousewhencreatingabeaninstanceusingexplicitarguments
*(onlyappliedwhencreatinganewinstanceasopposedtoretrievinganexistingone)
*@paramtypeCheckOnlywhethertheinstanceisobtainedforatypecheck,
*notforactualuse
*@returnaninstanceofthebean
*@throwsBeansExceptionifthebeancouldnotbecreated
@SuppressWarnings("unchecked")
protectedTTdoGetBean(
Stringname,@NullableClassTrequiredType,@NullableObject[]args,booleantypeCheckOnly)
throwsBeansException{
StringbeanName=transformedBeanName(name);
ObjectbeanInstance;
//Eagerlychecksingletoncacheformanuallyregisteredsingletons.
ObjectsharedInstance=getSingleton(beanName);
if(sharedInstance!=nullargs==null){
if(logger.isTraceEnabled()){
if(isSingletonCurrentlyInCreation(beanName)){
logger.trace("Returningeagerlycachedinstanceofsingletonbean'"+beanName+
"'thatisnotfullyinitializedyet-aconsequenceofacircularreference");
else{
logger.trace("Returningcachedinstanceofsingletonbean'"+beanName+"'");
beanInstance=getObjectForBeanInstance(sharedInstance,name,beanName,null);
else{
//Failifwe'realreadycreatingthisbeaninstance:
//We'reassumablywithinacircularreference.
if(isPrototypeCurrentlyInCreation(beanName)){
thrownewBeanCurrentlyInCreationException(beanName);
//Checkifbeandefinitionexistsinthisfactory.
BeanFactoryparentBeanFactory=getParentBeanFactory();
if(parentBeanFactory!=null!containsBeanDefinition(beanName)){
//Notfound-checkparent.
StringnameToLookup=originalBeanName(name);
if(parentBeanFactoryinstanceofAbstractBeanFactory){
return((AbstractBeanFactory)parentBeanFactory).doGetBean(
nameToLookup,requiredType,args,typeCheckOnly);
elseif(args!=null){
//Delegationtoparentwithexplicitargs.
return(T)parentBeanFactory.getBean(nameToLookup,args);
elseif(requiredType!=null){
//Noargs-delegatetostandardgetBeanmethod.
returnparentBeanFactory.getBean(nameToLookup,requiredType);
else{
return(T)parentBeanFactory.getBean(nameToLookup);
if(!typeCheckOnly){
markBeanAsCreated(beanName);
StartupStepbeanCreation=this.applicationStartup.start("spring.beans.instantiate")
.tag("beanName",name);
try{
if(requiredType!=null){
beanCreation.tag("beanType",requiredType::toString);
RootBeanDefinitionmbd=getMergedLocalBeanDefinition(beanName);
checkMergedBeanDefinition(mbd,beanName,args);
//Guaranteeinitializationofbeansthatthecurrentbeandependson.
String[]dependsOn=mbd.getDependsOn();
if(dependsOn!=null){
for(Stringdep:dependsOn){
if(isDependent(beanName,dep)){
thrownewBeanCreationException(mbd.getResourceDescription(),beanName,
"Circulardepends-onrelationshipbetween'"+beanName+"'and'"+dep+"'");
registerDependentBean(dep,beanName);
try{
getBean(dep);
catch(NoSuchBeanDefinitionExceptionex){
thrownewBeanCreationException(mbd.getResourceDescription(),beanName,
"'"+beanName+"'dependsonmissingbean'"+dep+"'",ex);
//Createbeaninstance.
if(mbd.isSingleton()){
sharedInstance=getSingleton(beanName,()-{
try{
returncreateBean(beanName,mbd,args);
catch(BeansExceptionex){
//Explicitlyremoveinstancefromsingletoncache:Itmighthavebeenputthere
//eagerlybythecreationprocess,toallowforcircularreferenceresolution.
//Alsoremoveanybeansthatreceivedatemporaryreferencetothebean.
destroySingleton(beanName);
throwex;
beanInstance=getObjectForBeanInstance(sharedInstance,name,beanName,mbd);
elseif(mbd.isPrototype()){
//It'saprototype-createanewinstance.
ObjectprototypeInstance=null;
try{
beforePrototypeCreation(beanName);
prototypeInstance=createBean(beanName,mbd,args);
finally{
afterPrototypeCreation(beanName);
beanInstance=getObjectForBeanInstance(prototypeInstance,name,beanName,mbd);
else{
StringscopeName=mbd.getScope();
if(!StringUtils.hasLength(scopeName)){
thrownewIllegalStateException("Noscopenamedefinedforbean′"+beanName+"'");
Scopescope=this.scopes.get(scopeName);
if(scope==null){
thrownewIllegalStateException("NoScoperegisteredforscopename'"+scopeName+"'");
try{
ObjectscopedInstance=scope.get(beanName,()-{
beforePrototypeCreation(beanName);
try{
returncreateBean(beanName,mbd,args);
finally{
afterPrototypeCreation(beanName);
beanInstance=getObjectForBeanInstance(scopedInstance,name,beanName,mbd);
catch(IllegalStateExceptionex){
thrownewScopeNotActiveException(beanName,scopeName,ex);
catch(BeansExceptionex){
beanCreation.tag("exception",ex.getClass().toString());
beanCreation.tag("message",String.valueOf(ex.getMessage()));
cleanupAfterBeanCreationFailure(beanName);
throwex;
finally{
beanCreation.end();
returnadaptBeanInstance(name,beanInstance,requiredType);
AbstractAutowireCapableBeanFactory.javacreateBean、doCreateBean、getEarlyBeanReference
@Override
protectedObjectcreateBean(StringbeanName,RootBeanDefinitionmbd,@NullableObject[]args)
throwsBeanCreationException{
if(logger.isTraceEnabled()){
logger.trace("Creatinginstanceofbean'"+beanName+"'");
RootBeanDefinitionmbdToUse=mbd;
//Makesurebeanclassisactuallyresolvedatthispoint,and
//clonethebeandefinitionincaseofadynamicallyresolvedClass
//whichcannotbestoredinthesharedmergedbeandefinition.
ClassresolvedClass=resolveBeanClass(mbd,beanName);
if(resolvedClass!=null!mbd.hasBeanClass()mbd.getBeanClassName()!=null){
mbdToUse=newRootBeanDefinition(mbd);
mbdToUse.setBeanClass(resolvedClass);
//Preparemethodoverrides.
try{
mbdToUse.prepareMethodOverrides();
catch(BeanDefinitionValidationExceptionex){
thrownewBeanDefinitionStoreException(mbdToUse.getResourceDescription(),
beanName,"Validationofmethodoverridesfailed",ex);
try{
//GiveBeanPostProcessorsachancetoreturnaproxyinsteadofthetargetbeaninstance.
Objectbean=resolveBeforeInstantiation(beanName,mbdToUse);
if(bean!=null){
returnbean;
catch(Throwableex){
thrownewBeanCreationException(mbdToUse.getResourceDescription(),beanName,
"BeanPostProcessorbeforeinstantiationofbeanfailed",ex);
try{
ObjectbeanInstance=doCreateBean(beanName,mbdToUse,args);
if(logger.isTraceEnabled()){
logger.trace("Finishedcreatinginstanceofbean'"+beanName+"'");
returnbeanInstance;
catch(BeanCreationException|ImplicitlyAppearedSingletonExceptionex){
//Apreviouslydetectedexceptionwithproperbeancreationcontextalready,
//orillegalsingletonstatetobecommunicateduptoDefaultSingletonBeanRegistry.
throwex;
catch(Throwableex){
thrownewBeanCreationException(
mbdToUse.getResourceDescription(),beanName,"Unexpectedexceptionduringbeancreation",ex);
protectedObjectdoCreateBean(StringbeanName,RootBeanDefinitionmbd,@NullableObject[]args)
throwsBeanCreationException{
//Instantiatethebean.
BeanWrapperinstanceWrapper=null;
if(mbd.isSingleton()){
instanceWrapper=this.factoryBeanInstanceCache.remove(beanName);
if(instanceWrapper==null){
instanceWrapper=createBeanInstance(beanName,mbd,args);
Objectbean=instanceWrapper.getWrappedInstance();
ClassbeanType=instanceWrapper.getWrappedClass();
if(beanType!=NullBean.class){
mbd.resolvedTargetType=beanType;
//Allowpost-processorstomodifythemergedbeandefinition.
synchronized(mbd.postProcessingLock){
if(!mbd.postProcessed){
try{
applyMergedBeanDefinitionPostProcessors(mbd,beanType,beanName);
catch(Throwableex){
thrownewBeanCreationException(mbd.getResourceDescription(),beanName,
"Post-processingofmergedbeandefinitionfailed",ex);
mbd.postProcessed=true;
//Eagerlycachesingletonstobeabletoresolvecircularreferences
//evenwhentriggeredbylifecycleinterfaceslikeBeanFactoryAware.
booleanearlySingletonExposure=(mbd.isSingleton()this.allowCircularReferences
isSingletonCurrentlyInCreation(beanName));
if(earlySingletonExposure){
if(logger.isTraceEnabled()){
logger.trace("Eagerlycachingbean'"+beanName+
"'toallowforresolvingpotentialcircularreferences");
addSingletonFactory(beanName,()-getEarlyBeanReference(beanName,mbd,bean));
//Initializethebeaninstance.
ObjectexposedObject=bean;
try{
populateBean(beanName,mbd,instanceWrapper);
exposedObject=initializeBean(beanName,exposedObject,mbd);
catch(Throwableex){
if(exinstanceofBeanCreationExceptionbeanName.equals(((BeanCreationException)ex).getBeanName())){
throw(BeanCreationException)ex;
else{
thrownewBeanCreationException(
mbd.getResourceDescription(),beanName,"Initializationofbeanfailed",ex);
if(earlySingletonExposure){
ObjectearlySingletonReference=getSingleton(beanName,false);
if(earlySingletonReference!=null){
if(exposedObject==bean){
exposedObject=earlySingletonReference;
elseif(!this.allowRawInjectionDespiteWrappinghasDependentBean(beanName)){
String[]dependentBeans=getDependentBeans(beanName);
SetStringactualDependentBeans=newLinkedHashSet(dependentBeans.length);
for(StringdependentBean:dependentBeans){
if(!removeSingletonIfCreatedForTypeCheckOnly(dependentBean)){
actualDependentBeans.add(dependentBean);
if(!actualDependentBeans.isEmpty()){
thrownewBeanCurrentlyInCreationException(beanName,
"Beanwithname'"+beanName+"'hasbeeninjectedintootherbeans["+
StringUtils.collectionToCommaDelimitedString(actualDependentBeans)+
"]initsrawversionaspartofacircularreference,buthaseventuallybeen"+
"wrapped.Thismeansthatsaidotherbeansdonotusethefinalversionofthe"+
"bean.Thisisoftentheresultofover-eagertypematching-considerusing"+
"'getBeanNamesForType'withthe'allowEagerInit'flagturnedoff,forexample.");
//Registerbeanasdisposable.
try{
registerDisposableBeanIfNecessary(beanName,bean,mbd);
catch(BeanDefinitionValidationExceptionex){
thrownewBeanCreationException(
mbd.getResourceDescription(),beanName,"Invaliddestructionsignature",ex);
returnexposedObject;
protectedObjectgetEarlyBeanReference(StringbeanName,RootBeanDefinitionmbd,Objectbean){
ObjectexposedObject=bean;
if(!mbd.isSynthetic()hasInstantiationAwareBeanPostProcessors()){
for(SmartInstantiationAwareBeanPostProcessorbp:getBeanPostProcessorCache().smartInstantiationAware){
exposedObject=bp.getEarlyBeanReference(exposedObject,beanName);
returnexposedObject;
DefaultSingletonBeanRegistry.java三級(jí)緩存
publicclassDefaultSingletonBeanRegistryextendsSimpleAliasRegistryimplementsSingletonBeanRegistry{
/**Cacheofsingletonobjects:beannametobeaninstance.一級(jí)緩存*/
privatefinalMapString,ObjectsingletonObjects=newConcurrentHashMap(256);
/**Cacheofsingletonfactories:beannametoObjectFactory.三級(jí)緩存*/
privatefinalMapString,ObjectFactorysingleton
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 充填回收工安全規(guī)程競(jìng)賽考核試卷含答案
- 硅油及乳液生產(chǎn)工安全應(yīng)急強(qiáng)化考核試卷含答案
- 油脂及脂肪酸加氫操作工安全理論評(píng)優(yōu)考核試卷含答案
- 玻璃制品機(jī)械成型工班組考核強(qiáng)化考核試卷含答案
- 中藥灸熨劑工崗前安全知識(shí)競(jìng)賽考核試卷含答案
- 薄膜電阻器制造工崗前技術(shù)規(guī)范考核試卷含答案
- 九年級(jí)開(kāi)學(xué)第一課主題班會(huì)課件
- 安全文明施工保證措施
- 交通應(yīng)急預(yù)案制定與演練制度
- 吊車保險(xiǎn)培訓(xùn)課件大全
- 化工工藝安全管理與操作手冊(cè)
- 規(guī)范外匯交易管理制度
- 2026年美麗中國(guó)全國(guó)國(guó)家版圖知識(shí)競(jìng)賽考試題庫(kù)(含答案)
- 高考英語(yǔ)讀后續(xù)寫(xiě)技巧總結(jié)
- 2025年下半年河南鄭州市住房保障和房地產(chǎn)管理局招聘22名派遣制工作人員重點(diǎn)基礎(chǔ)提升(共500題)附帶答案詳解
- 維修事故協(xié)議書(shū)
- 2025ESC+EAS血脂管理指南要點(diǎn)解讀課件
- 2025至2030外周靜脈血栓切除裝置行業(yè)調(diào)研及市場(chǎng)前景預(yù)測(cè)評(píng)估報(bào)告
- 矛盾糾紛排查化解課件
- 2026年人力資源共享服務(wù)中心建設(shè)方案
- JJG(交通) 141-2017 瀝青路面無(wú)核密度儀
評(píng)論
0/150
提交評(píng)論