1.Bean スコープ
1.1 変更された Bean のケース
理由: Bean のデフォルトのスコープはシングルトン モードです。全員が同じオブジェクトを使用することを意味します。以前にシングルトン モードを学んだとき、シングルトンを使用するとパフォーマンスが大幅に向上することは誰もが知っていたため、Spring の Bean のスコープもデフォルトでシングルトン シングルトン モードになります。
@Component public class Users { @Bean public User user1(){ User user = new User(); user.setId(1); user.setName("Java"); return user; } }
@Component public class Bean1 { @Autowired private User user; public User getUser(){ System.out.println("Bean1对象未修改name之前 : "+user); user.setName("C++"); return user; } }
@Component public class Bean2 { @Autowired private User user; public User getUser(){ return user; } }
public class App { public static void main(String[] args) { ApplicationContext context = new ClassPathXmlApplicationContext("spring-config.xml"); Bean1 bean1 = context.getBean("bean1",Bean1.class); System.out.println(bean1.getUser()); Bean2 bean2 = context.getBean("bean2",Bean2.class); System.out.println(bean2.getUser()); } }
1.2 デフォルトのスコープとしてシングルトン モードを使用する理由
スペースを節約するために同じリソースのコピーを 1 つだけ作成する
オブジェクトの作成や破棄を過剰に行う必要がなくなり、実行速度が向上します。
1.3 スコープ
スコープは一般に、次のように理解されます。プログラム内の変数はスコープと呼ばれます。または、変数が定義されているソース コード内の特定の領域はスコープと呼ばれます。
⽽Bea
のスコープは、singleton## など、
Spring のフレームワーク全体における
Bean の特定の動作パターンを参照します。単一インスタンスのスコープは、
ということを意味します。
Bean は
Spring 全体でコピーが 1 つだけあり、グローバルに共有されます。その後、他の人がこの値を変更すると、別の ## が行われます。 # person reads は変更された値です。
1.4 Bean の 6 つのスコープ
- singleton:
単一インスタンスのスコープ
- prototype:
プロトタイプ スコープ (複数インスタンス スコープ)
- request:
リクエスト スコープ
- セッション:
セッションスコープ
##アプリケーション: - グローバルスコープ
- HTTP WebSocket スコープ
最後の 4 つは SpringMVC に限定されているため、この段階では最初の 2 つだけを学習します。
@Scope を使用(ConfigurableBeanFactory.SCOPE_PROTOTYPE)
@Scope を使用 ( "prototype")
#2. Spring の実行プロセスと Bean のライフサイクル
ps
2.1 Bean のライフ サイクル
Bean のライフ サイクルは次の 5 つの部分に分かれています:
1. Bean のインスタンス化 (Bean にメモリ領域を割り当てます) )
- 2. プロパティの設定 (Bean インジェクションとアセンブリ)
- 3. Bean の初期化
- BeanNameAware、BeanFactoryAware、ApplicationContextAware インターフェース メソッドなど、さまざまな Aware 通知メソッドを実装します。たとえば、Spring が Bean を初期化するとき、Bean に ID (名前) を割り当てる必要があります。 beanName が正常に設定された場合は、beadNameAware 通知が生成されます。BeanPostProcessor 初期化プレメソッドを実行します (このメソッドがオーバーライドされていない場合は、ソース コードに従ってください)。依存関係注入後に実行される @PostConstruct 初期化メソッドを実行します。操作; 自分で指定した init を実行する -method メソッド (指定されている場合) は Spring の Bean タグで指定されたメソッドです;
この初期化メソッドは上記のものとは異なりますinit は XML 時代の産物であり、@PostConstruct はアノテーション時代の産物です。優先度:Liang氏のメソッドが同時に存在する場合、アノテーションが先に実行され、次にinitが実行されてBeanPostProcessorの初期化ポストメソッドが実行されます(このメソッドがオーバーライドされていない場合はソースコードに従います)。
- 5. Destroy Bean コンテナを破棄するためのさまざまなメソッド (@PreDestroy、DisposableBean インターフェイス メソッド、destroy- など)方法 。
@PreDestroy和destroy-method的关系和初始化方法的两个关系差不多
优先级:@ProDestroy > 重写的DisposableBean接口方法 > destroy-method
执行流程图如下:
ps:
实例化和初始化的区别:实例化
就是 分配内存空间。初始化
,就是把我们一些参数,方法的具体实现逻辑给加载进去。
2.1.1生命周期演示
xml配置如下:
Bean
public class BeanLifeComponent implements BeanNameAware { @PostConstruct public void PostConstruct(){ System.out.println("执行@PostConstruct"); } public void init(){ System.out.println("执行bean-init-method"); } public void use(){ System.out.println("正在使用bean"); } @PreDestroy public void PreDestroy(){ System.out.println("执行@PreDestroy"); } public void setBeanName(String s){ System.out.println("执行了Aware通知"); } }
启动类
public class App2 { public static void main(String[] args) { ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("spring-config.xml"); BeanLifeComponent beanLifeComponent = context.getBean(BeanLifeComponent.class); beanLifeComponent.use(); context.destroy(); } }
xml配置
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:content="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd"> <content:component-scan base-package="com.beans"></content:component-scan> <bean id="1" class="com.beans.BeanLifeComponent" init-method="init"></bean> </beans>
2.1.2 为什么要先设置属性,在进行初始化
@Controller public class TestUser { @Autowired private Test test; public TestUser(){ test.sayHi(); System.out.println("TestUser->调用构造方法"); } }
如果这段代码先执行了初始化,也就是其构造方法,会用到test对象,此时还没有设置属性,test就为null,会造成空指针异常。因此必须先设置属性,在进行初始化。
以上がJava SpringにおけるBeanのスコープとライフサイクルは何ですかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、Javaプロジェクト管理、自動化の構築、依存関係の解像度にMavenとGradleを使用して、アプローチと最適化戦略を比較して説明します。

この記事では、MavenやGradleなどのツールを使用して、適切なバージョン化と依存関係管理を使用して、カスタムJavaライブラリ(JARファイル)の作成と使用について説明します。

この記事では、カフェインとグアバキャッシュを使用してJavaでマルチレベルキャッシュを実装してアプリケーションのパフォーマンスを向上させています。セットアップ、統合、パフォーマンスの利点をカバーし、構成と立ち退きポリシー管理Best Pra

この記事では、キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPAを使用することについて説明します。潜在的な落とし穴を強調しながら、パフォーマンスを最適化するためのセットアップ、エンティティマッピング、およびベストプラクティスをカバーしています。[159文字]

Javaのクラスロードには、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを備えた階層システムを使用して、クラスの読み込み、リンク、および初期化が含まれます。親の委任モデルは、コアクラスが最初にロードされ、カスタムクラスのLOAに影響を与えることを保証します

この記事では、分散アプリケーションを構築するためのJavaのリモートメソッドの呼び出し(RMI)について説明します。 インターフェイスの定義、実装、レジストリのセットアップ、およびクライアント側の呼び出しを詳述し、ネットワークの問題やセキュリティなどの課題に対処します。

この記事では、ネットワーク通信のためのJavaのソケットAPI、クライアントサーバーのセットアップ、データ処理、リソース管理、エラー処理、セキュリティなどの重要な考慮事項をカバーしています。 また、パフォーマンスの最適化手法も調査します

この記事では、カスタムJavaネットワーキングプロトコルの作成を詳述しています。 プロトコルの定義(データ構造、フレーミング、エラー処理、バージョン化)、実装(ソケットを使用)、データシリアル化、およびベストプラクティス(効率、セキュリティ、メンテナ


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

メモ帳++7.3.1
使いやすく無料のコードエディター

ドリームウィーバー CS6
ビジュアル Web 開発ツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

ホットトピック



