SlideShare une entreprise Scribd logo
1  sur  22
超先取り
ShenandoahGC
Yohei Oda
@JJUG CCC 2016 Fall
今日のトピック
絶賛開発中
http://openjdk.java.net/projects/shenandoah/
CMS,G1,Shenandoah
回収アルゴリズム 並行性 コンパクション
CMS スイープ ◯ ☓(断片化放置)
G1 コピー ☓(STW) ◯
Shenandoah コピー ◯ ◯
やりたいこと
あるリージョンの生存オブジェ
クトだけを別のリージョンに移
動(退避)して元の領域を解放
したい
ただし退避はアプリケーション
を止めずに行う
一般的な退避
A’
B C
A
1.退避させたいオブジェクトAのコピーA’を空き
リージョンに作る
2.Aへの参照をA’に向けるようにする
3.これをリージョン内の全生存オブジェクトに対して
行ったら、リージョンを解放できる
Javaスレッド
退避対象リージョン 空きリージョン
退避対象外リージョン
並行退避の問題
A
B C
A’
Aを参照するオブジェクトは複数ある(B,C)ため、
BとCがA’を参照するようになるタイミングにはラ
グができる。
このタイミングでオブジェクトが更新されると、
同じオブジェクトであるはずのAとA'のデータが
ずれてしまい、参照経路によって取り出されるデ
ータが変わってしまう。
=
?
参照/更新されるのがAかA’か不定なのはダメ
B経由、C経由のどちらの経路でもA'にアクセスできる仕組みが必要
BrooksPointer(間接参照)
Object
pointer
field
field
• オブジェクトごとに一つポインタ(BrooksPointer)をセットで作成する
• 普段はBrooksPointerは同時に作られたオブジェクトへのポインタになっている
• オブジェクトのフィールドには参照するオブジェクトのBrooksPointer
のアドレスが入る
BrooksPointerを使った退避
A
CB
A’ AのBrooksPointerをA'に向けておくと、
B or C → A の参照が更新されていない状態でも、
BrooksPointerを経由して A’ にアクセスさせる
ことができる
BrooksPointer切り替え時の問題
A
CB
A’を作ってからBrooksPointerをA'に切り替えるまでの間に
Aが更新された場合、その更新内容は消えてしまう
退避処理と更新処理が独立して行われているのが問題
これらの処理の前後関係を規定する必要がある
A
CB
A’ A
CB
A’
ライトバリア
または A A’A
Aに対して更新処理が行われると、アプリケーションは更新処理の前に
Aの退避(コピーとBrooksPointerの切り替え)を行うようにする。
のとき
1 0 1
0例えば、 のとき「0を1に変更したい」のであれば
である。
なお、JavaスレッドやGCスレッドのBrooksPointer切り替えが競合しないよう、
BrooksPointerの更新は CAS を使って行う。
Aが退避対象のリージョンにあり、BrooksPointer切り替え前、つまり
CAS
コンペア・アンド・スワップ(Compare-and-Swap、CAS)とは、アトミックに、あるメモリ位置の内容と指定された値
を比較し、等しければそのメモリ位置に別の指定された値を格納するCPUの特別な命令の一種である。この操作の結果、
置換が行われたかどうかを示す必要があり、単純な真理値を返すか、そのメモリ位置から読み込んだ内容(書き込んだ内
容ではない)を返す。(中略)
CAS命令を利用したアルゴリズムは、一般にあるキーとなるメモリ位置を読み取り、その古い値を記憶しておく。その古
い値に基づいて、新しい値を計算する。その後、CAS命令でそのメモリ位置に新しい値を格納するが、そのときにCAS命
令の比較によって計算に用いた古い値が置換時にもそのまま入っていることを確認する。CAS命令が比較に失敗した場合
、最初から処理をやり直す。メモリ位置を再度読み取って、値を計算し、CAS命令を再実行するのである。
https://ja.wikipedia.org/wiki/コンペア・アンド・スワップ
あるスレッドがBrooksPointerの値を変更した後で別のスレッド
が意図せずBrooksPointerの切り替えようとした場合、書き換え
を防ぐことができる
= 一つのBrooksPointerが2度更新されることを防げる
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
BrookPointer+ライトバリア+CAS(逆)
① ② ③ ④
Java
スレッド
0 0
0
0 0
0
0 1
0
0 1
0
+1したい
Javaスレッドが先に
BrooksPointerを切り替
え
Javaスレッドがオブジェクトを
更新
GCスレッドが
BrooksPointerを切り替えよ
うとしてもCASで失敗する
まだBrooksPointerは切り
替えられていないので
Javaスレッドはコピーを
作成する
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
ShenandoahGCの流れ
Pause Init-Mark (2.346s, 2.347s) 0.274ms
Concurrent marking 12M->12M(16M) (2.347s, 2.348s) 1.590ms
A
CB
全ての生存オブジェクトをマークしていく
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中に変更されたヒープの状
態を反映して、生存オブジェクトが確定する
。
確定したら、ごみの量に基いてコレクション
セット(退避対象となるリージョンの集合)
が決定される
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スレッ
ドが退避を実行する。
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のマークフェイズで、辿っている参照
がコレクションセット内のオブジェクトを指し
ていたら、マークついでに退避先に参照を切り
替える。
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 のタイミングでメモリ使用
量が減っていることが読み取れる。
non-generational GC
❖ 世代別GC
➢ 一部領域をGCする際に経験則に基いて行う
➢ 「最近アロケーションした領域をGCしたほうが回収効率が良いだろう」
❖ Shenandoah では FinalMark 時点でヒープ内の全てのオブジェクトの
生存状況が把握できている
❖ どのリージョンを回収すればよいかを考える際、仮説に基づく必要はない
ShenadoahGC は世代別GCではない
❖ 世代別仮説にあてはまらないケースでも安定して動作する
❖ RememberedSet を持つ必要がない
❖ GCするたびにヒープ全体をマークする必要がある
まとめ
❖ ShenandoahGCではコピーGCをアプリケーションと並行に実行できる
❖ 並行退避を安全に行うための仕組み
- BrooksPointer
退避先のオブジェクトが必ず参照されるようにする
- ライトバリア
退避処理が終わる前に更新が行われないようにする
- CAS
1つのオブジェクトが2回以上退避されないようにする
❖ ShenandoahGCのサイクル
- 前回のサイクルのコレクションセットを解放している
- マークフェーズで参照の移動をしている
❖ShenandoahGC は世代別GCではない
おまけ(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/

Contenu connexe

Dernier

AWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdf
AWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdfAWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdf
AWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdfFumieNakayama
 
デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)
デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)
デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)UEHARA, Tetsutaro
 
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)NTT DATA Technology & Innovation
 
業務で生成AIを活用したい人のための生成AI入門講座(社外公開版:キンドリルジャパン社内勉強会:2024年4月発表)
業務で生成AIを活用したい人のための生成AI入門講座(社外公開版:キンドリルジャパン社内勉強会:2024年4月発表)業務で生成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...モーダル間の変換後の一致性とジャンル表を用いた解釈可能性の考察  ~Text-to-MusicとText-To-ImageかつImage-to-Music...
モーダル間の変換後の一致性とジャンル表を用いた解釈可能性の考察 ~Text-to-MusicとText-To-ImageかつImage-to-Music...博三 太田
 
クラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdf
クラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdfクラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdf
クラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdfFumieNakayama
 
CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?
CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?
CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?akihisamiyanaga1
 
自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer
自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer
自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineerYuki Kikuchi
 
TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案
TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案
TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案sugiuralab
 

Dernier (9)

AWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdf
AWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdfAWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdf
AWS の OpenShift サービス (ROSA) を使った OpenShift Virtualizationの始め方.pdf
 
デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)
デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)
デジタル・フォレンジックの最新動向(2024年4月27日情洛会総会特別講演スライド)
 
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
 
業務で生成AIを活用したい人のための生成AI入門講座(社外公開版:キンドリルジャパン社内勉強会:2024年4月発表)
業務で生成AIを活用したい人のための生成AI入門講座(社外公開版:キンドリルジャパン社内勉強会:2024年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...モーダル間の変換後の一致性とジャンル表を用いた解釈可能性の考察  ~Text-to-MusicとText-To-ImageかつImage-to-Music...
モーダル間の変換後の一致性とジャンル表を用いた解釈可能性の考察 ~Text-to-MusicとText-To-ImageかつImage-to-Music...
 
クラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdf
クラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdfクラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdf
クラウドネイティブなサーバー仮想化基盤 - OpenShift Virtualization.pdf
 
CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?
CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?
CTO, VPoE, テックリードなどリーダーポジションに登用したくなるのはどんな人材か?
 
自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer
自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer
自分史上一番早い2024振り返り〜コロナ後、仕事は通常ペースに戻ったか〜 by IoT fullstack engineer
 
TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案
TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案
TataPixel: 畳の異方性を利用した切り替え可能なディスプレイの提案
 

En vedette

Everything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPTEverything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPTExpeed Software
 
Product Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage EngineeringsProduct Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage EngineeringsPixeldarts
 
How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthHow Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthThinkNow
 
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdfAI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdfmarketingartwork
 
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024Neil Kimberley
 
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)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 2024How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024Albert Qian
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsKurio // The Social Media Age(ncy)
 
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Search Engine Journal
 
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summarySpeakerHub
 
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd 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 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 IntentGoogle's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentLily Ray
 
Time Management & Productivity - Best Practices
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best PracticesVit Horky
 
The six step guide to practical project management
The six step guide to practical project managementThe six step guide to practical project management
The six step guide to practical project managementMindGenius
 
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...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...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 ChatGPTEverything 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 EngineeringsProduct 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 HealthHow 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.pdfAI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
 
Skeleton Culture Code
Skeleton Culture CodeSkeleton Culture Code
Skeleton Culture Code
 
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024PEPSICO 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)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 2024How 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 InsightsSocial 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 2024Trends 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 summary5 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 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 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 IntentGoogle'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 How to have difficult conversations
How to have difficult conversations
 
Introduction to Data Science
Introduction to Data ScienceIntroduction to Data Science
Introduction to Data Science
 
Time Management & Productivity - Best Practices
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best Practices
 
The six step guide to practical project management
The six step guide to practical project managementThe 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...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...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