Java Memory Model in 10 minutes

  Рет қаралды 264,587

Defog Tech

Defog Tech

Күн бұрын

Пікірлер: 206
@70ME3E
@70ME3E 4 жыл бұрын
I'm going through this playlist to learn Java concurrency, and I have to say your explanation and presentation quality are amazing, and the diagrams are really helpful. thank you!
@DefogTech
@DefogTech 4 жыл бұрын
Wow, thanks!
@mohammedrahamathulla4040
@mohammedrahamathulla4040 3 жыл бұрын
@@DefogTech Why no videos from you😔?? All your subscribers are waiting
@monishchhadwa777
@monishchhadwa777 9 ай бұрын
I would absolutely recommend all Java engineers-whether junior or very senior-to watch this!
@shellindebted5328
@shellindebted5328 6 жыл бұрын
I tried multiple times myself to understand JMM, But this is the first time i got to learn something about them. Excellent Presentation. Hats of to you, You define perfection!!
@DefogTech
@DefogTech 6 жыл бұрын
I am far from perfect. Though, thanks much for the kind words sir!
@yifei663
@yifei663 6 жыл бұрын
May be you should read java language specification : docs.oracle.com/javase/specs/jls/se8/html/jls-17.html .
@suhani091088
@suhani091088 4 жыл бұрын
Always read these topic therotically, but could never visualise it like this you have explained..Great presentation man!
@iknowyourerightbut6246
@iknowyourerightbut6246 5 жыл бұрын
future me: volatile has semantics for memory visibility. Basically, the value of a volatile field becomes visible to all readers (other threads in particular) after a write operation completes on it. Without volatile, readers could see some non-updated value.
@rohitsharma-xt8qe
@rohitsharma-xt8qe 5 жыл бұрын
I have never seen such an excellent explanation of JMM. Thanks a lot
@Admiral.MacDonnell
@Admiral.MacDonnell 10 ай бұрын
My takeaway - if the tasks perform blocking IO operation, I should not use fork join pool. so true. Thanks for the explanation! You have a gift of mixing complicated concept easy to digest!
@Dedeepya9
@Dedeepya9 5 жыл бұрын
Started watching thread pool videos Nd then addicted to all of ur videos Nd subscribed..the way of explanation is precise , innovative Nd interesting.your wrk deserves more than a thnks..
@DefogTech
@DefogTech 5 жыл бұрын
Thank you for the kind words!! I am so happy its helping everyone
@sepraveen
@sepraveen 5 жыл бұрын
Yes are techie by heart
@NaturalPro100
@NaturalPro100 5 жыл бұрын
The best video i could find on youtube.
@tanoysaha7410
@tanoysaha7410 5 жыл бұрын
Your explanations are precise, but have so in-depth/hidden informations and moreover so easy to understand
@paneerdopyaaza2914
@paneerdopyaaza2914 4 жыл бұрын
Please make a whole course...I will definitely try buying it.Your videos are just awesome.
@mostinho7
@mostinho7 4 жыл бұрын
2:10 each core has its own cache and then there are shared caches. Thread running on core changes the variable in its local cache only, volatile keyword makes sure variable is flushed to shared cache when thread changes it so that changes are visible to all the other threads 6:05 happens before relationship 9:30 volatile keyword example
@monstersmiled648
@monstersmiled648 4 жыл бұрын
Hi can you help me I am confused when i was trying real time as per the diagram in the time 00:03:52 here i used this... System.out.println("the writerThread x is: "+x); System.out.println("the readerThread r2 is:"+r2); --------------------------------------------------------------------------------------------------------------------------------- like in this program(below): public class FieldVisibility { int x = 0; public void writerThread() { x = 1; System.out.println("the writerThread x is: "+x); } public void readerThread() { int r2 = x; System.out.println("the readerThread r2 is:"+x); } } output is:-- the writerThread x is: 1 the readerThread r2 is:1 ....................................................................................... instead of the writerThread x is: 1 the readerThread r2 is:0
@bhavyashah2630
@bhavyashah2630 6 жыл бұрын
Awesome video...Please don't stop making such excellent videos.
@DefogTech
@DefogTech 6 жыл бұрын
Thank you for the motivation sir!
@gurupadamgundala5142
@gurupadamgundala5142 6 жыл бұрын
Please make more videos
@ITech2005
@ITech2005 5 жыл бұрын
Defog Tech More videos :)
@saravanprathi6956
@saravanprathi6956 4 жыл бұрын
More videos pleaseeeee
@TauCu
@TauCu 4 жыл бұрын
This helped me understand a lot about the JVM Thanks, you're very good at explaining things without any unneeded gibberish!
@mrchief3383
@mrchief3383 4 жыл бұрын
Man, you are awesome. I was struggling trying to understand atomic operations and the use cases of volatile variables. Thank you so much
@Machinerium
@Machinerium 5 жыл бұрын
I had an interview question like that.. This is a very clean explanation , keep doing it!
@skaLife
@skaLife 4 жыл бұрын
You have a good teacher in you. Please continue the good work.
@narendrasriram
@narendrasriram 11 ай бұрын
This playlist you have made is too awesome. your example/explanation for happens-before has a few issues. Not sure if I understood wrong, otherwise.Thank you so much for this playslit.
@prashanttiwari120
@prashanttiwari120 4 жыл бұрын
Best video on java on whole KZbin universe
@sivagurunathanparanitharan4714
@sivagurunathanparanitharan4714 4 жыл бұрын
🙏 You are the Best Teacher that I have ever seen.🥇, A classical method of approach = Superb indeed.👌.🎯Please Could you kindly teach us Flutter & Dart & Go lang & Scala too . Pleeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeese Sir..... 🙏🙏🙏🙏🙏🙏🙏🙏🙏🙏🙏
@saravanprathi6956
@saravanprathi6956 3 жыл бұрын
You are a fantastic teacher.. please please make more videos
@contactdi8426
@contactdi8426 2 жыл бұрын
I am really amazed sir by your knowledge. Can you please share how you plan and learn all these things/concepts? Do you require them all these in your office related work regularly? I have been in IT industry for around 4-5 years but literally never faced these things, therefore never felt the need either to learn these. Please share some suggestions as senior developers to juniors on learning paths.
@vikaskokae
@vikaskokae 2 жыл бұрын
Exactly my feelings after been in the industry for a couple of decades. Learning from experience when applying concepts to real life work enhances understanding of concepts to the next level, something that prevail for years. I would be interested to know from Deepak, how he went about approaching concepts.
@rajasruji2476
@rajasruji2476 3 жыл бұрын
Wow…. Such an well articulated video. I felt this topic to be very difficult to understand before I watched your video. Please sir keep adding more and more topics to this channel. For the first time fell in love with subject videos.
@sumitbabel5415
@sumitbabel5415 4 жыл бұрын
Honestly exceptionally well explained Sir, hats off
@kotojava
@kotojava 2 жыл бұрын
this channel deserve much more subscribers.
@ganeshpathak4804
@ganeshpathak4804 5 жыл бұрын
Hi, I have one request if you could make a video on Performance improvement techniques. Not necessarily related to threading but in general. I am sure everyone would be benefited as you explain complex things in very simple way :)
@DefogTech
@DefogTech 5 жыл бұрын
Sure, sounds like a good idea. Will add it to the list
@vikramreddy7586
@vikramreddy7586 4 жыл бұрын
This video is pure GOLD!!!
@VikiSangani
@VikiSangani 5 жыл бұрын
Very nicely explained. Please keep making such videos.👍👍
@Lucky-uz3je
@Lucky-uz3je 5 жыл бұрын
You are my interview trainer...love you bro:)
@shaikshasayyad131
@shaikshasayyad131 5 жыл бұрын
Crystal clear explanation!!! thanks a million .. I observed that the code was working fine though i had not used the volatile keyword at 9:37. what could it be the reason ?
@DefogTech
@DefogTech 5 жыл бұрын
It will work 99% of the time, but java memory model doesn't guarantee it will work all the time, thus we need the keyword
@shaikshasayyad131
@shaikshasayyad131 5 жыл бұрын
Thanks a lot for your your response.
@harish7706
@harish7706 5 жыл бұрын
I have been going through a lot of JAVA topic videos in different forums, by far Defog Tech is the best that I have come across. Advanced topics explained in a simple way which provides clarity. Keep going
@DefogTech
@DefogTech 5 жыл бұрын
Thank you for the kind words sir!
@edeepakjain
@edeepakjain 5 жыл бұрын
Best explanation of volatile so far... 👌
@SatyaprasadMr
@SatyaprasadMr 4 жыл бұрын
Videos are very useful. Crisp & Clear. I request to make more videos
@philthehuman
@philthehuman 6 жыл бұрын
Very clear video, though I would like suggest you to fix the code examples of locks or at least to have a disclaimer by voice that no one should use locks by your examples and should read a documentation instead which says you have to use "try { .. } finally { lock.unlock(); }" construct.
@DefogTech
@DefogTech 6 жыл бұрын
Agreed. Will add a card to the video. Thanks!
@adamrizk6735
@adamrizk6735 4 ай бұрын
What an excellent presentation, thank you for sharing
@noortech254
@noortech254 3 жыл бұрын
Bro You are simply amazing. You may be not realised how much you are helping us. Thank You bhai :D
@DrAkyla1123
@DrAkyla1123 6 жыл бұрын
Very concise and easy to grasp. Great job!
@perrym8048
@perrym8048 11 ай бұрын
Best explanation I've seen, great work!
@BeatSyncBytes
@BeatSyncBytes 4 жыл бұрын
Explaination with L2 and L3 is so deep. How do you get so deep
@chetankhandave1072
@chetankhandave1072 5 жыл бұрын
very very good explanation, it shows you have studied very hard , Hats off to you. But I will be very happy if you provide good working example to show difference between with volatile and without volatile, because when I try to find out difference using volatile and without volatile I do not notice anyone. your example in video do not demonstrate difference when I try it myself. thanks
@DefogTech
@DefogTech 5 жыл бұрын
Correct, so without volatile JVM doesn't guarantee other threads will see updated value. But it depends on speed of your operations, JVM implementation etc. Thus like for most concurrency issues it will work on local, will work in production for few days but might fail suddenly after
@chetankhandave1072
@chetankhandave1072 5 жыл бұрын
Yes you are correct, when I run my program again and again so many times then at some time situation arises and my volatile variable and non volatile variable get different values. I will be happy to share program to you. thanks
@anilkinikar
@anilkinikar 5 жыл бұрын
Awesome clarity. Voice is very clear and videos are well designed. Subscribed 👍
@venu5791
@venu5791 5 жыл бұрын
Thanks for sharing this concept. I had only some theoretical knowledge of this before I watch this imp video.
@ivanevseevv
@ivanevseevv 3 жыл бұрын
Explanation is very good and sharp!
@pradhumansingh1195
@pradhumansingh1195 3 жыл бұрын
Who the hell dislikes such a great videos??
@devendrawangikar2890
@devendrawangikar2890 3 жыл бұрын
other video makers :)
@StyleTrick
@StyleTrick 4 жыл бұрын
Hey great videos as always! I just wanted to ask, since primitives are passed by value and Objects are passed as reference, does the JVM only cache primitives into a threads local cache? If the value being updated was an Integer Object, e.g. new Integer(1), it would not need flushing as the object is passed by REFERENCE?
@sandeepkumarsahoo3458
@sandeepkumarsahoo3458 5 жыл бұрын
Crystal clear explaination... Loved it
@shobhitmittal77
@shobhitmittal77 4 жыл бұрын
This is one ultimate video...subscribed !!
@nlarralde
@nlarralde 3 жыл бұрын
Great video, very clear explanation and examples. Thank you
@thomashpfner-dahl1433
@thomashpfner-dahl1433 6 жыл бұрын
Dude!! You are awesome, a true lifesaver. You are the first that have made it simple, at least that I have come across
@DefogTech
@DefogTech 6 жыл бұрын
Thanks much buddy!
@tarang65
@tarang65 3 жыл бұрын
Amazing presentation. All the videos are really helpful. Great work.
@viveksingh9120
@viveksingh9120 5 жыл бұрын
Awesome mate. You are really doing great, very impressive
@purnimadas3762
@purnimadas3762 6 жыл бұрын
That was really good. Thanks for posting, excellent, clear and to the point presentation, good job!
@DefogTech
@DefogTech 6 жыл бұрын
Thank you
@studio2038
@studio2038 4 жыл бұрын
very simple to understand
@sshks10
@sshks10 4 жыл бұрын
Very good and simple explanation
@kannadasans7564
@kannadasans7564 4 жыл бұрын
Could you make a samples of reactive programming followed by your aka Java fiber videos. For eg, How to use RxJava for the below categories of apps, 1. Considering both frontend and backend 2. Considering there is no frontend and it's purely backend app. Doing good job. Really great👍
@ardiansyah6794
@ardiansyah6794 4 жыл бұрын
Oh thanks man. I wish you were my lecturer 😀
@__nitinkumar__
@__nitinkumar__ 3 жыл бұрын
2:50 loved this diagram man.
@niftymiller6057
@niftymiller6057 6 жыл бұрын
Very good and crisp way of explanation. Keep doing this good :) work
@DefogTech
@DefogTech 6 жыл бұрын
Thank you!
@coreyhartman4510
@coreyhartman4510 5 жыл бұрын
This video is excellent.
@hakura88
@hakura88 Жыл бұрын
love your simple examples. thank you
@RobinsonGames
@RobinsonGames 5 жыл бұрын
Really good explanation with a good visual display of those
@gurupadamgundala5142
@gurupadamgundala5142 6 жыл бұрын
Awesome. Expected more videsos 👌👌👌
@DefogTech
@DefogTech 6 жыл бұрын
Thank you sir!
@masteradityamishra9486
@masteradityamishra9486 6 жыл бұрын
Very nice explanation appreciate it, thanks.
@mujahidshaikh5034
@mujahidshaikh5034 3 жыл бұрын
everything to the point.. love ur videos bro❤️
@abhik9450
@abhik9450 5 жыл бұрын
Thanks for a proper explanation on happens-before 🙂
@AkshayNalavade18
@AkshayNalavade18 3 жыл бұрын
Volatile won't work here. You have to use Atomic integer.... You have explained it in another of your videos. Volatile vs Atomic
@MarkGla55
@MarkGla55 3 жыл бұрын
Excellent explanation. Thank you
@kakashihatake4840
@kakashihatake4840 6 жыл бұрын
Really loved the explanation. Thank you
@StyleTrick
@StyleTrick 6 жыл бұрын
Great video! Would it be possible to showcase when this happens? I've tried to replicate the issue with creating 2 new threads, however they seem to read x perfectly fine.
@DefogTech
@DefogTech 6 жыл бұрын
Sure, so it is possible that JVM will show the updated value to the other thread even though it is not say volatile, but, it is not guaranteed. In certain cases it can choose to keep using cached value. With volatile and other JMM rules we can be 100% sure that read-after always works. Can you share your code please. I can take a look
@StyleTrick
@StyleTrick 6 жыл бұрын
public class JavaMemoryModel { static int x = 0; public static void writerThread() { x = 11; System.out.println("In writer thread: " + Thread.currentThread().getName() + ": " + x); } public static void readerThread() { int r2 = x; System.out.println("In reader thread: " + Thread.currentThread().getName() + ": " + r2); } public static void main(String[] args) throws InterruptedException { ExecutorService executorService = Executors.newFixedThreadPool(6); executorService.execute(new Runner()); executorService.execute(() -> readerThread()); executorService.execute(() -> writerThread()); executorService.execute(new Runner()); executorService.execute(() -> readerThread()); executorService.execute(() -> writerThread()); executorService.shutdown(); } static class Runner implements Runnable { @Override public void run() { x = 29; System.out.println("In Runner Class: " + Thread.currentThread().getName() + ": " + x); } } } Something like this. How would you replicate the error of the shared cache not being updated?
@DefogTech
@DefogTech 6 жыл бұрын
Check this code gist.github.com/DeepakVadgama/fdd282d9b10794ed21867dc912bafffd Try calling reader and writer methods, instead of reader2 and writer2. One uses atomicInteger, other uses int. In the output, int shows inconsistent results, while atomicInteger one prints in correct order.
@shilpaagrawal7126
@shilpaagrawal7126 4 жыл бұрын
Awesome video... Can u also make video on design patterns ...?
@aniln4736
@aniln4736 4 жыл бұрын
In my case there is concurrent hashmap obj that holds configurations read from different server. Quartz scheduler will fetch configuration data for every 30 sec and update a new data (whole obj) to this concurrent hashmap.. In this case ,in my opinion voltaile should be used to always get the updated obj to the reader threads but some quality checking tools raising it as bug So any suggestions during this scenario
@prasantkumar7693
@prasantkumar7693 6 жыл бұрын
Thank you for nice explanation and make more videos.
@dinkarinjosh
@dinkarinjosh 5 жыл бұрын
can you please make a video on working of JVM and its architecture? btw good job.
@AmitGadaley17
@AmitGadaley17 3 жыл бұрын
Hi, Could you please make a video on memory management in java or provide a useful link for it. Thanks!!
@gauravbajpai6890
@gauravbajpai6890 5 жыл бұрын
U earned a fan today - Subscribed !
@umeriqbal5662
@umeriqbal5662 5 жыл бұрын
Jigger u r love... Awesome video.... Amazing teaching skills... Thanks a lot
@isayanpal
@isayanpal 2 жыл бұрын
You're just brilliant! 🙏🏽
@manognajoshik8465
@manognajoshik8465 3 жыл бұрын
Thank you very much sir!! You are amazing ❤️
@ibrahimshaikh3642
@ibrahimshaikh3642 4 жыл бұрын
Thank u, waiting for more videos on java
@krishnach7290
@krishnach7290 4 жыл бұрын
At 7:01 in video, x is volatile. But not a b or c. Will they also pushed back to main memory along with x? later in the same video you showing synchronise / locks for all fields
@Murga_Mutton
@Murga_Mutton 4 жыл бұрын
Hi, Thanks for the video. How is the volatile or synchronized or lock usage different from having the field in the constructor? Can't the shared cache object be used by putting the field in the constructor method and calling it in different threads?
@srinathchintha9565
@srinathchintha9565 3 жыл бұрын
Hi why did you stop making videos.. please make more videos..
@pogrommist
@pogrommist 4 жыл бұрын
Awesome explanation and examples!
@vikrantharne8576
@vikrantharne8576 5 жыл бұрын
But in multithreaded environment u can not be sure about which thread will get chance though we can override thread schedules behavior by setting priority...so in this case we need synchronization? My another questions is when thread executes the run method is it the only method thread executes then what about about synchronized blocks and synchronized methods...do we need to write those inside run method.... please clear my doubts..
@DefogTech
@DefogTech 5 жыл бұрын
Its difficult to ensure one thread is scheduled before another even in case of priority (eg: if CPU is multi-core, both low and high priority threads can be scheduled together). So its better to code using concurrency utilities (eg: Latches, Semaphores, volatiles etc.) Yes, most of the code that we want to run in a separate thread (as opposed to main thread) needs to be in run or call methods of Runnable/Called. Though, in Java 8, CompletableFuture or other frameworks/libraries could take your code in Supplier/Function/or any form, and run it within runnable without us knowing about it.
@vikrantharne8576
@vikrantharne8576 5 жыл бұрын
@@DefogTech thanks for the reply
@jeremythen7239
@jeremythen7239 5 жыл бұрын
Best explanations! Keep it up.
@sharadrsoni1991
@sharadrsoni1991 4 жыл бұрын
Late comer :) Question: How at 9:03 locks will result in maintaining the variables a,b,c,x being atomic? The locks are for methods, which I understand as, no other there can enter in THAT method, but if some other methods are executed, then you may get the stale data. Isn't it?
@vijayp6810
@vijayp6810 5 жыл бұрын
Learnt new information..thank you so much
@jiteshkumar3387
@jiteshkumar3387 3 жыл бұрын
Good explanation !! :) Very usefull
@khushbuchoudhary5185
@khushbuchoudhary5185 3 жыл бұрын
Super video! I applauded for ₹40.00 👏
@harshitshukla7382
@harshitshukla7382 6 жыл бұрын
Can you make a video on stream api in java8? I am very much looking forward to understanding them and you have an excellent presentation and organization of the videos. Keep doing the good job!!
@DefogTech
@DefogTech 6 жыл бұрын
Thank you sir! Stream API is on my list, will definitely upload one in coming weeks
@kakashihatake4840
@kakashihatake4840 6 жыл бұрын
Please do more such videos
@narendramanikanta7597
@narendramanikanta7597 5 жыл бұрын
Awesome explanation mate. God bless you
@sbylk99
@sbylk99 6 жыл бұрын
Great tutorial, thank you SIR!
@DefogTech
@DefogTech 6 жыл бұрын
You're very welcome!
@angelakarapetyan586
@angelakarapetyan586 3 жыл бұрын
I cannot understand one thing, how can synchronized work without volotile correctly, Does not thread copy x only to it's memory anyway?
@mehulmakwana7091
@mehulmakwana7091 5 жыл бұрын
Awesome explanation buddy. thanks a lot. :)
@vijaykumarreddyt3287
@vijaykumarreddyt3287 Жыл бұрын
You are doing Great! Dude
@siddharthswain9463
@siddharthswain9463 5 күн бұрын
Thanks a ton! So helpful.
@Jayantch.999
@Jayantch.999 4 жыл бұрын
Super explanation 👍
@abhinavsrivastava1870
@abhinavsrivastava1870 5 жыл бұрын
Can Volatile keyword be used with HashMap in any where code snippet. If yes, how to do that?
@hbhatia999
@hbhatia999 2 жыл бұрын
@DefogTech At time 8:47 How we are saying that value of all 4 variable will get updated while reading in readerThread because You are saying that X is not volatile. ?? As per first video of Volatile ,In this it was said that volatile values gets updated in Cache and because of that we are able to get updated value in different thread. Please help in this..
@DefogTech
@DefogTech 2 жыл бұрын
Updates to variables are visible to other threads by using any one of the options, volatile, synchronized or locks. Thus if you are using synchronized, even if variable is not volatile, updates will still be visibile to other threads.
Java ExecutorService - Part 1 - Introduction
10:12
Defog Tech
Рет қаралды 422 М.
The Java Memory Model - The Basics
23:41
Jakob Jenkov
Рет қаралды 132 М.
Disrespect or Respect 💔❤️
00:27
Thiago Productions
Рет қаралды 43 МЛН
Увеличили моцареллу для @Lorenzo.bagnati
00:48
Кушать Хочу
Рет қаралды 8 МЛН
ТЫ В ДЕТСТВЕ КОГДА ВЫПАЛ ЗУБ😂#shorts
00:59
BATEK_OFFICIAL
Рет қаралды 4,5 МЛН
When u fight over the armrest
00:41
Adam W
Рет қаралды 31 МЛН
Многопоточность глазами разработчика
1:36:04
Андрей Паньгин - Память Java процесса по полочкам
59:20
JPoint, Joker и JUG ru — Java-конференции
Рет қаралды 74 М.
Using volatile vs AtomicInteger in Java concurrency
7:27
Defog Tech
Рет қаралды 318 М.
14. JAVA. Memory Model | Технострим
30:20
VK Team
Рет қаралды 41 М.
Александр Ланцов - Не happens-before единым: нестандартные семантики
48:03
JPoint, Joker и JUG ru — Java-конференции
Рет қаралды 9 М.
ThreadLocal in Java
10:59
Defog Tech
Рет қаралды 187 М.
Stack vs Heap Memory - Simple Explanation
5:28
Alex Hyett
Рет қаралды 252 М.
Memory Leaks in Java | Issues Caused and How to Prevent | Example
13:13
But, what is Virtual Memory?
20:11
Tech With Nikola
Рет қаралды 310 М.
The Java memory model explained, Rafael Winterhalter
48:01
Bulgarian Java User Group
Рет қаралды 21 М.
Что происходит внутри клавиатуры😮
0:26
💁‍♂️Зачем infinix это сделала?🤦‍♂️
0:42