この記事はWeChatの公開アカウント「プログラマーの成長」から転載したもので、著者はプログラマーの成長です。この記事を転載する場合は、プログラマーの成長公開アカウントまでご連絡ください。 この記事を始める前に、JVM がオブジェクトを作成し、メモリ アドレスを割り当てるプロセスを理解しており、JVM のメモリ分割も知っていることを前提とします。人道的な観点から、参考までに写真を投稿します。 JVM メモリ構造 ヒープメモリパーティション構造 ヒープ領域にメモリを割り当てるときに、マルチスレッドの安全性の問題はありますか?A: 存在するかもしれません。 新しいオブジェクト(); 上記の操作では、最終的にはヒープ メモリ内にメモリ領域の一部を開く必要があることは誰もが知っています。そこで、この質問について考えてみましょう。ヒープ領域はすべてのスレッドによって共有されます。では、JVM が頻繁にオブジェクトを作成する場合、同時実行時にヒープ メモリのスペースを空けるとセキュリティ上の問題が発生するのでしょうか? この問題を解決するために、まず考えられるのはロックですが、ロックにはパフォーマンスに影響を与えるという問題があります。 TLAB が表示されます (スレッド ローカル割り当てバッファ)上記の問題に基づいて、TLAB が導入されます。強制変換はスレッドローカル割り当てバッファです。まず、写真を見てみましょう ステートメント: ヒープ メモリにスペースを割り当てるときは、古い世代に直接割り当てられるのではなく、最初に Eden 領域に割り当てられます。メモリ割り当てが完了した後、GC が実行されるたびに、オブジェクトがリサイクルされない場合は、その生存カウントが +1 になります。この回数が 15 回に達すると、オブジェクトは古い世代に昇格されます。 オブジェクトの割り当てはまず eden 領域で実行されることがわかったので、上の図を理解するのは難しくありません。私たちはエデンエリア内の領域を分割し、これを TLAB と呼びます。各 TLAB はプライベートなので、オブジェクトを同時に作成する場合、実際にはロックなどの操作を実行する必要がなく、セキュリティの問題が解決されます。 割り当てられた TLAB スペースが使い果たされた場合、またはオブジェクトに必要なメモリ スペースが TLAB が提供できるスペースよりも大きい場合、メモリ スペースはパブリック エデン領域または古い世代にのみ割り当てることができます。 要約する
この問題から別の疑問も推測できます。ヒープ領域はスレッドによって厳密に共有されるわけではありません。 |
<<: エッジコンピューティングとデータストレージ: インダストリー4.0の主要テクノロジー
>>: 分散システムにおける「スプリットブレイン」とは一体何でしょうか?
検索エンジン最適化(SEO)は10年前から中国にひっそりと導入されてきました。検索エンジンは小規模か...
Android プラットフォームに対する外部開発者の関心は薄れている (写真提供: Tencent ...
[[420235]]これは、Kafka に関するシリーズ「Mastering MQ」の 4 番目の記...
今日の急速に変化する世界では、最先端技術のシームレスな統合がイノベーションの基盤となっています。その...
Weiboはますます人気が高まり、今日のインターネット上で欠かせないコミュニケーションツールとなって...
2月1日、百度は2013年中国ウェブサイト発展動向レポートを発表し、中国の現在のウェブサイト生態環境...
今日は、Meng Feiyang が、良いタイトルの書き方、良いキーワードの書き方、良い説明の書き方...
北京時間9月15日、海外メディアの報道によると、多くのユーザーが、Googleで検索した後、多くのウ...
Hostdare は、一昨日、zenlayer (c3 コンピュータ ルーム) の KVM シリーズ...
クラウド コンピューティングは、インターネット プロトコルに基づいて IT サービスを追加、使用、配...
オリジナルのウェブサイト コンテンツは、疑似オリジナルまたは直接コピーされたコンテンツよりも確実に優...
近年、同社の事業は急速に発展し、数多くのビジネスシーンで画像、文書、音声、動画などの非構造化データが...
現在、多くの最適化担当者はウェブサイトの最適化について誤解しており、キーワードのランキングに過度に注...
著者: Yu Leichun、PaaS 製品部門、中国モバイル クラウド機能センター前回の記事では、...
ウェブサイトにはホームページのみが含まれています。多くのウェブマスターがこのような問題に遭遇したと思...