Soumettre la recherche
Mettre en ligne
超先取りShenandoahGC
•
Télécharger en tant que PPTX, PDF
•
1 j'aime
•
2,645 vues
Yohei Oda
Suivre
JJUG CCC 2016 fall のセッションスライドです。 アップロード用に追記あり。
Lire moins
Lire la suite
Technologie
Signaler
Partager
Signaler
Partager
1 sur 22
Télécharger maintenant
Recommandé
Molecule入門
Molecule入門
Hiroki Uchida
20140301ハッカーズチャンプルー告知lt
20140301ハッカーズチャンプルー告知lt
Koichiro Nishijima
How to customize redmine public
How to customize redmine public
Hirotaka Nishimiya
困らない程度のJDK入門
困らない程度のJDK入門
Yohei Oda
BtoCでバインド変数
BtoCでバインド変数
Yoshito Ueki
20141108 俺のエンジニアリング #devlove
20141108 俺のエンジニアリング #devlove
Takao Oyobe
私がドメイン駆動設計をやる理由
私がドメイン駆動設計をやる理由
増田 亨
2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot
Marius Sescu
Recommandé
Molecule入門
Molecule入門
Hiroki Uchida
20140301ハッカーズチャンプルー告知lt
20140301ハッカーズチャンプルー告知lt
Koichiro Nishijima
How to customize redmine public
How to customize redmine public
Hirotaka Nishimiya
困らない程度のJDK入門
困らない程度のJDK入門
Yohei Oda
BtoCでバインド変数
BtoCでバインド変数
Yoshito Ueki
20141108 俺のエンジニアリング #devlove
20141108 俺のエンジニアリング #devlove
Takao Oyobe
私がドメイン駆動設計をやる理由
私がドメイン駆動設計をやる理由
増田 亨
2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot
Marius Sescu
AWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdf
AWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdf
FumieNakayama
デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)
デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)
UEHARA, Tetsutaro
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NTT DATA Technology & Innovation
業務で生成AIを活用したい人のための生成AI入門講座(社外公開版:キンドリルジャパン社内勉強会:2024年4月発表)
業務で生成AIを活用したい人のための生成AI入門講座(社外公開版:キンドリルジャパン社内勉強会:2024年4月発表)
Hiroshi Tomioka
モーダル間の変換後の一致性とジャンル表を用いた解釈可能性の考察 ~Text-to-MusicとText-To-ImageかつImage-to-Music...
モーダル間の変換後の一致性とジャンル表を用いた解釈可能性の考察 ~Text-to-MusicとText-To-ImageかつImage-to-Music...
博三 太田
クラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdf
クラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdf
FumieNakayama
CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?
CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?
akihisamiyanaga1
自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer
自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer
Yuki Kikuchi
TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案
TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案
sugiuralab
Everything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPT
Expeed Software
Product Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage Engineerings
Pixeldarts
How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental Health
ThinkNow
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
marketingartwork
Skeleton Culture Code
Skeleton Culture Code
Skeleton Technologies
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024
Neil Kimberley
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)
contently
How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024
Albert Qian
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
Kurio // The Social Media Age(ncy)
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024
Search Engine Journal
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary
SpeakerHub
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd
Clark Boyd
Getting into the tech field. what next
Getting into the tech field. what next
Tessa Mero
Contenu connexe
Dernier
AWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdf
AWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdf
FumieNakayama
デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)
デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)
UEHARA, Tetsutaro
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NTT DATA Technology & Innovation
業務で生成AIを活用したい人のための生成AI入門講座(社外公開版:キンドリルジャパン社内勉強会:2024年4月発表)
業務で生成AIを活用したい人のための生成AI入門講座(社外公開版:キンドリルジャパン社内勉強会:2024年4月発表)
Hiroshi Tomioka
モーダル間の変換後の一致性とジャンル表を用いた解釈可能性の考察 ~Text-to-MusicとText-To-ImageかつImage-to-Music...
モーダル間の変換後の一致性とジャンル表を用いた解釈可能性の考察 ~Text-to-MusicとText-To-ImageかつImage-to-Music...
博三 太田
クラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdf
クラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdf
FumieNakayama
CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?
CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?
akihisamiyanaga1
自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer
自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer
Yuki Kikuchi
TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案
TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案
sugiuralab
Dernier
(9)
AWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdf
AWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdf
デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)
デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
業務で生成AIを活用したい人のための生成AI入門講座(社外公開版:キンドリルジャパン社内勉強会:2024年4月発表)
業務で生成AIを活用したい人のための生成AI入門講座(社外公開版:キンドリルジャパン社内勉強会:2024年4月発表)
モーダル間の変換後の一致性とジャンル表を用いた解釈可能性の考察 ~Text-to-MusicとText-To-ImageかつImage-to-Music...
モーダル間の変換後の一致性とジャンル表を用いた解釈可能性の考察 ~Text-to-MusicとText-To-ImageかつImage-to-Music...
クラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdf
クラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdf
CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?
CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?
自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer
自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer
TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案
TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案
En vedette
Everything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPT
Expeed Software
Product Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage Engineerings
Pixeldarts
How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental Health
ThinkNow
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
marketingartwork
Skeleton Culture Code
Skeleton Culture Code
Skeleton Technologies
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024
Neil Kimberley
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)
contently
How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024
Albert Qian
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
Kurio // The Social Media Age(ncy)
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024
Search Engine Journal
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary
SpeakerHub
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd
Clark Boyd
Getting into the tech field. what next
Getting into the tech field. what next
Tessa Mero
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Lily Ray
How to have difficult conversations
How to have difficult conversations
Rajiv Jayarajah, MAppComm, ACC
Introduction to Data Science
Introduction to Data Science
Christy Abraham Joy
Time Management & Productivity - Best Practices
Time Management & Productivity - Best Practices
Vit Horky
The six step guide to practical project management
The six step guide to practical project management
MindGenius
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
RachelPearson36
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...
Applitools
En vedette
(20)
Everything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPT
Product Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage Engineerings
How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental Health
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
Skeleton Culture Code
Skeleton Culture Code
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)
How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd
Getting into the tech field. what next
Getting into the tech field. what next
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search Intent
How to have difficult conversations
How to have difficult conversations
Introduction to Data Science
Introduction to Data Science
Time Management & Productivity - Best Practices
Time Management & Productivity - Best Practices
The six step guide to practical project management
The six step guide to practical project management
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...
超先取りShenandoahGC
1.
超先取り ShenandoahGC Yohei Oda @JJUG CCC
2016 Fall
2.
今日のトピック 絶賛開発中 http://openjdk.java.net/projects/shenandoah/
3.
CMS,G1,Shenandoah 回収アルゴリズム 並行性 コンパクション CMS
スイープ ◯ ☓(断片化放置) G1 コピー ☓(STW) ◯ Shenandoah コピー ◯ ◯
4.
やりたいこと あるリージョンの生存オブジェ クトだけを別のリージョンに移 動(退避)して元の領域を解放 したい ただし退避はアプリケーション を止めずに行う
5.
一般的な退避 A’ B C A 1.退避させたいオブジェクトAのコピーA’を空き リージョンに作る 2.Aへの参照をA’に向けるようにする 3.これをリージョン内の全生存オブジェクトに対して 行ったら、リージョンを解放できる Javaスレッド 退避対象リージョン 空きリージョン 退避対象外リージョン
6.
並行退避の問題 A B C A’ Aを参照するオブジェクトは複数ある(B,C)ため、 BとCがA’を参照するようになるタイミングにはラ グができる。 このタイミングでオブジェクトが更新されると、 同じオブジェクトであるはずのAとA'のデータが ずれてしまい、参照経路によって取り出されるデ ータが変わってしまう。 = ? 参照/更新されるのがAかA’か不定なのはダメ B経由、C経由のどちらの経路でもA'にアクセスできる仕組みが必要
7.
BrooksPointer(間接参照) Object pointer field field • オブジェクトごとに一つポインタ(BrooksPointer)をセットで作成する • 普段はBrooksPointerは同時に作られたオブジェクトへのポインタになっている •
オブジェクトのフィールドには参照するオブジェクトのBrooksPointer のアドレスが入る
8.
BrooksPointerを使った退避 A CB A’ AのBrooksPointerをA'に向けておくと、 B or
C → A の参照が更新されていない状態でも、 BrooksPointerを経由して A’ にアクセスさせる ことができる
9.
BrooksPointer切り替え時の問題 A CB A’を作ってからBrooksPointerをA'に切り替えるまでの間に Aが更新された場合、その更新内容は消えてしまう 退避処理と更新処理が独立して行われているのが問題 これらの処理の前後関係を規定する必要がある A CB A’ A CB A’
10.
ライトバリア または A A’A Aに対して更新処理が行われると、アプリケーションは更新処理の前に Aの退避(コピーとBrooksPointerの切り替え)を行うようにする。 のとき 1
0 1 0例えば、 のとき「0を1に変更したい」のであれば である。 なお、JavaスレッドやGCスレッドのBrooksPointer切り替えが競合しないよう、 BrooksPointerの更新は CAS を使って行う。 Aが退避対象のリージョンにあり、BrooksPointer切り替え前、つまり
11.
CAS コンペア・アンド・スワップ(Compare-and-Swap、CAS)とは、アトミックに、あるメモリ位置の内容と指定された値 を比較し、等しければそのメモリ位置に別の指定された値を格納するCPUの特別な命令の一種である。この操作の結果、 置換が行われたかどうかを示す必要があり、単純な真理値を返すか、そのメモリ位置から読み込んだ内容(書き込んだ内 容ではない)を返す。(中略) CAS命令を利用したアルゴリズムは、一般にあるキーとなるメモリ位置を読み取り、その古い値を記憶しておく。その古 い値に基づいて、新しい値を計算する。その後、CAS命令でそのメモリ位置に新しい値を格納するが、そのときにCAS命 令の比較によって計算に用いた古い値が置換時にもそのまま入っていることを確認する。CAS命令が比較に失敗した場合 、最初から処理をやり直す。メモリ位置を再度読み取って、値を計算し、CAS命令を再実行するのである。 https://ja.wikipedia.org/wiki/コンペア・アンド・スワップ あるスレッドがBrooksPointerの値を変更した後で別のスレッド が意図せずBrooksPointerの切り替えようとした場合、書き換え を防ぐことができる = 一つのBrooksPointerが2度更新されることを防げる
12.
BrookPointer+ライトバリア+CAS ① ② ③
④ Java スレッド 0 0 0 0 0 0 0 0 0 0 0 0 +1したい GCスレッドが先に BrooksPointerを切り替 え JavaスレッドもBrooksPointerを切 り替えようとするが、 BrooksPointerが変更されているた めCASが失敗する そのままBrooksPointerの参 照を辿って更新処理をすれ ばOK まだBrooksPointerは切り 替えられていないので Javaスレッドはコピーを 作成する 1
13.
BrookPointer+ライトバリア+CAS(逆) ① ② ③
④ Java スレッド 0 0 0 0 0 0 0 1 0 0 1 0 +1したい Javaスレッドが先に BrooksPointerを切り替 え Javaスレッドがオブジェクトを 更新 GCスレッドが BrooksPointerを切り替えよ うとしてもCASで失敗する まだBrooksPointerは切り 替えられていないので Javaスレッドはコピーを 作成する
14.
ShenandoahGCのログ Pause Init-Mark (2.346s,
2.347s) 0.274ms Concurrent marking 12M->12M(16M) (2.347s, 2.348s) 1.590ms Pause Final Mark 12M->4M(16M) (2.348s, 2.351s) 2.599ms Concurrent evacuation 4M->5M(16M) (2.351s, 2.351s) 0.155ms
15.
ShenandoahGCの流れ Pause Init-Mark (2.346s,
2.347s) 0.274ms Concurrent marking 12M->12M(16M) (2.347s, 2.348s) 1.590ms A CB 全ての生存オブジェクトをマークしていく
16.
ShenandoahGCの流れ Pause Init-Mark (2.346s,
2.347s) 0.274ms Concurrent marking 12M->12M(16M) (2.347s, 2.348s) 1.590ms Pause Final Mark 12M->4M(16M) (2.348s, 2.351s) 2.599ms A CB ConcurrentMark中に変更されたヒープの状 態を反映して、生存オブジェクトが確定する 。 確定したら、ごみの量に基いてコレクション セット(退避対象となるリージョンの集合) が決定される
17.
ShenandoahGCの流れ Pause Init-Mark (2.346s,
2.347s) 0.274ms Concurrent marking 12M->12M(16M) (2.347s, 2.348s) 1.590ms Pause Final Mark 12M->4M(16M) (2.348s, 2.351s) 2.599ms Concurrent evacuation 4M->5M(16M) (2.351s, 2.351s) 0.155ms A CB A’ コレクションセット内の生存オブジェクトを 空きリージョンに退避させる。 GCスレッドが退避させる前にアプリケーショ ンによる更新が行われた場合は、Javaスレッ ドが退避を実行する。
18.
ShenandoahGCの流れ A CB A’ Pause Init-Mark (2.346s,
2.347s) 0.274ms Concurrent marking 12M->12M(16M) (2.347s, 2.348s) 1.590ms Pause Final Mark 12M->4M(16M) (2.348s, 2.351s) 2.599ms Concurrent evacuation 4M->5M(16M) (2.351s, 2.351s) 0.155ms Pause Init-Mark (2.926s, 2.928s) 1.869ms Concurrent marking 12M->12M(16M) (2.928s, 2.932s) 3.416ms 次のGCのマークフェイズで、辿っている参照 がコレクションセット内のオブジェクトを指し ていたら、マークついでに退避先に参照を切り 替える。
19.
ShenandoahGCの流れ A CB A’ Pause Init-Mark (2.346s,
2.347s) 0.274ms Concurrent marking 12M->12M(16M) (2.347s, 2.348s) 1.590ms Pause Final Mark 12M->4M(16M) (2.348s, 2.351s) 2.599ms Concurrent evacuation 4M->5M(16M) (2.351s, 2.351s) 0.155ms Pause Init-Mark (2.926s, 2.928s) 1.869ms Concurrent marking 12M->12M(16M) (2.928s, 2.932s) 3.416ms Pause Final Mark 12M->9M(16M) (2.932s, 2.933s) 1.205ms マークが完了した時点で前回選択されたコレクシ ョンセットへの有効な参照はなくなっているので 、リージョンのメモリを解放することができる。 マークの情報を使って、新しいコレクションセッ トが選択される。 ログからもFinalMark のタイミングでメモリ使用 量が減っていることが読み取れる。
20.
non-generational GC ❖ 世代別GC ➢
一部領域をGCする際に経験則に基いて行う ➢ 「最近アロケーションした領域をGCしたほうが回収効率が良いだろう」 ❖ Shenandoah では FinalMark 時点でヒープ内の全てのオブジェクトの 生存状況が把握できている ❖ どのリージョンを回収すればよいかを考える際、仮説に基づく必要はない ShenadoahGC は世代別GCではない ❖ 世代別仮説にあてはまらないケースでも安定して動作する ❖ RememberedSet を持つ必要がない ❖ GCするたびにヒープ全体をマークする必要がある
21.
まとめ ❖ ShenandoahGCではコピーGCをアプリケーションと並行に実行できる ❖ 並行退避を安全に行うための仕組み -
BrooksPointer 退避先のオブジェクトが必ず参照されるようにする - ライトバリア 退避処理が終わる前に更新が行われないようにする - CAS 1つのオブジェクトが2回以上退避されないようにする ❖ ShenandoahGCのサイクル - 前回のサイクルのコレクションセットを解放している - マークフェーズで参照の移動をしている ❖ShenandoahGC は世代別GCではない
22.
おまけ(FAQ) ❖ ShenandoahGC は試せますか? →
Shenandoahのソースコード(JDK9)を mercurial から持ってきてビルドすれば、あとは -XX:+UseShenandoahGC オプションで利用できます。 ただし開発中なのでどのプラットフォームでも安定してビルドできるというわけではなかったりします。 今回はCentOS7の最新でうまくビルドできたので、うまくいかない場合はRedhat系ディストリビューショ ンの最新版で試すのが良さそうです。 ❖ ShenandoahGC の開発は進んでますか? → 2016年の後半は開発メンバーも増え、メーリングリストでのやりとりも活発でした。ソースコードを読 んでいても半年でずいぶんちゃんとしたなという印象です。一方でまだクリティカルなバグが普通に発生 したり、未実装の機能があったり(ex. ヒープダンプ出せません)するので、Production まではもう少しかか りそうです。 ❖ 色々処理が追加されているのでオーバーヘッドがあるのでは? → RememberedSetをなくしたというプラスはあるのですが、BrooksPointerもライトバリアもCASも少な からずオーバーヘッドがあります。2016年はじめに開発主要メンバーのRomanさんが試してみたところ だと、G1にはちょっと負けているようです(ポーズタイムはShenandoahの方がずっと短い)。 (参考) https://rkennke.wordpress.com/2016/02/08/shenandoah-performance/
Télécharger maintenant