وب سایت تخصصی شرکت فرین
دسته بندی دوره ها

Java Application Performance Tuning and Memory Management

سرفصل های دوره

Discover how coding choices, benchmarking, performance tuning and memory management can optimize your Java applications


01 - Chapter 1 - Introduction
  • 001 What do we mean by performance, and what versions of Java does this course cover
  • 002 Example code provided with this course
  • 002 PracticalsAndCode.zip
  • 003 Using different JDK and JVM vendors
  • 004 The structure of this course
  • 005 How to get support while youre taking this course

  • 02 - Chapter 2 - Just In Time Compilation and the Code Cache
  • 001 What is bytecode
  • 002 The concept of Just In Time Compilation
  • 003 Introducing the first example project
  • 004 Finding out which methods are being compiled in our applications
  • 005 The C1 and C2 Compilers and logging the compilation activity
  • 006 Tuning the code cache size
  • 007 Remotely monitoring the code cache with JConsole

  • 03 - Chapter 3 - Selecting the JVM
  • 001 The differences between the 32 bit and 64 bit JVM
  • 002 Specifying which compiler to use at runtime
  • 003 Turning off tiered compilation
  • 004 Tuning native compilation within the Virtual Machine

  • 04 - Chapter 4 - How memory works - the stack and the heap
  • 001 Introduction - the structure of Javas memory
  • 002 How the stack works
  • 003 How the heap works
  • 004 The heap and the stack together - an example

  • 05 - Chapter 5 - Passing objects between methods
  • 001 What does passing by value mean
  • 002 What does passing by reference mean
  • 003 Passing objects into methods
  • 004 The final keyword and why its not the same as a constant
  • 005 Why the final keyword doesnt stop an objects values from being changed

  • 06 - Chapter 6 - Memory exercise 1
  • 001 Instructions for the exercise
  • 002 Walkthrough of the solution

  • 07 - Chapter 7 - Escaping References
  • 001 Introduction - what is an escaping reference
  • 002 Strategy 1 - using an iterator
  • 003 Strategy 2 - duplicating collections
  • 004 Strategy 3 - using immutable collections
  • 005 Strategy 4 - duplicating objects
  • 006 Strategy 5 - using interfaces to create immutable objects
  • 007 Strategy 6 - using modules to hide the implementation

  • 08 - Chapter 8 - Memory Exercise 2
  • 001 Instructions for the exercise
  • 002 Walkthrough of the solution

  • 09 - Chapter 9 - The Metaspace and internal JVM memory optimisations
  • 001 The role of the Metaspace
  • 002 The PermGen
  • 003 Are objects always created on the heap
  • 004 The String Pool
  • 005 Interning Strings

  • 10 - Chapter 10 - Tuning the JVMs Memory Settings
  • 001 How the string pool is implemented
  • 002 Understanding the size and density of the string pool
  • 003 Tuning the size of the string pool
  • 004 Tuning the size of the heap
  • 005 Shortcut syntax for heap tuning flags

  • 11 - Chapter 11 - Introducing Garbage Collection
  • 001 What it means when we say Java is a managed language
  • 002 How Java knows which objects can be removed from the Heap
  • 003 The System.gc() method
  • 004 Java 11s garbage collector can give unused memory back to the operating system
  • 005 Why its not a good idea to run the System.gc() method
  • 006 The finalize() method
  • 007 The danger of using finalize()

  • 12 - Chapter 12 - Monitoring the Heap
  • 001 What is a soft leak
  • 002 Introducing (J)VisualVM
  • 003 Monitoring the size of the heap over time
  • 004 Fixing the problem and checking the heap size

  • 13 - Chapter 13 - Analysing a heap dump
  • 001 Generating a heap dump
  • 002 Viewing a heap dump

  • 14 - Chapter 14 - Generational Garbage Collection
  • 001 How the garbage collector works out what is garbage
  • 002 Why the heap is divided into generations
  • 003 The Internals of the Young Generation
  • 004 Viewing the generations in VisualVM
  • 005 Viewing the heap when theres a soft leak

  • 15 - Chapter 15 - Garbage Collector tuning & selection
  • 001 Monitoring garbage collections
  • 002 Turning off automated heap allocation sizing
  • 003 Tuning garbage collection - old and young allocation
  • 004 Tuning garbage collection - survivor space allocation
  • 005 Tuning garbage collection - generations needed to become old
  • 006 Selecting a garbage collector
  • 007 The G1 garbage collector
  • 008 Tuning the G1 garbage collector
  • 009 String de-duplication

  • 16 - Chapter 16 - Using a profiler to analyse application performance
  • 001 Introducing Java Mission Control (JMC)
  • 002 Building the JMC binaries
  • 003 Running JMC and connecting to a VM
  • 004 Customising the overview tab
  • 005 The MBean Browser tab
  • 006 The System, Memory and Diagnostic Commands tabs
  • 007 Introducing our problem project
  • 008 Using the flight recorder
  • 009 Analyzing a flight recording
  • 010 Improving our application

  • 17 - Chapter 17 - Assessing Performance
  • 001 Why benchmarking isnt straight forward
  • 002 Setting up the code for benchmarking
  • 003 A simple approach to micro-benchmarking
  • 004 Adding in a warm-up period
  • 005 Comparing two code alternatives
  • 006 Using Macro-bencharmking

  • 18 - Chapter 18 - Benchmarking with JMH
  • 001 Installing the JMH benchmarking tool
  • 002 Creating and running benchmarks
  • 003 Using different benchmark modes

  • 19 - Chapter 19 - Performance and Benchmarking Exercise
  • 001 Instructions for exercise 1 (creating a flight recording)
  • 002 Walkthrough of the solution & setting up ready for the next challenge
  • 003 Instructions for exercise 2 (use JMH to macrobenchmark the project)
  • 004 Walkthrough of the solution - part 1 setting up the code
  • 005 Walkthrough of the solution - part 2 - integrating into JMH

  • 20 - Chapter 20 - How Lists Work
  • 001 Why its important to understand how the different List implementations work
  • 002 The 8 different list implementations
  • 003 The CopyOnWriteArrayList
  • 004 The ArrayList
  • 005 Specifying the initial size of an ArrayList
  • 006 The Vector
  • 007 The Stack
  • 008 The LinkedList
  • 009 Choosing the optimal list type
  • 010 Sorting lists

  • 21 - Chapter 21 - How Maps Work
  • 001 How Hashmaps Work - part 1
  • 002 The role of the Hashcode
  • 003 How Hashmaps Work - part 2
  • 004 Specifying the initial size and factor of a HashMap
  • 005 HashMap Performance
  • 006 The rules for Hashcodes
  • 007 Generating and optimising the Hashcode method
  • 008 Optimising Hashmap Performance
  • 009 How The LinkedHashMap Works
  • 010 The HashTable and TreeMap

  • 22 - Chapter 22 - Other Coding Choices
  • 001 Introduction to how well compare coding options
  • 002 Comparing primatives with objects
  • 003 Comparing BigDecimals with Doubles
  • 004 Using the StringBuilder
  • 005 Comparing loops and streams
  • 006 A note on logging

  • 23 - Chapter 23 - GraalVM
  • 001 What is GraalVM
  • 002 Installing GraalVM
  • 003 Using the Graal Virtual Machine
  • 004 Using the Graal Compiler
  • 005 Native image building with Graal
  • 006 Using the Graal experimental features within OpenJDK

  • 24 - Chapter 24 - Using Other JVM Languages
  • 001 The principles of using other JVM Languages
  • 002 Looking at bytecode with javap
  • 003 Disassembling bytecode back to Java

  • 25 - Chapter 25 - Course Summary
  • 001 The OpenJ9 Virtual Machine and whats coming up in future versions of Java
  • 002 Bonus lecture.html
  • 139,000 تومان
    بیش از یک محصول به صورت دانلودی میخواهید؟ محصول را به سبد خرید اضافه کنید.
    خرید دانلودی فوری

    در این روش نیاز به افزودن محصول به سبد خرید و تکمیل اطلاعات نیست و شما پس از وارد کردن ایمیل خود و طی کردن مراحل پرداخت لینک های دریافت محصولات را در ایمیل خود دریافت خواهید کرد.

    ایمیل شما:
    تولید کننده:
    شناسه: 18775
    حجم: 2163 مگابایت
    مدت زمان: 605 دقیقه
    تاریخ انتشار: 14 شهریور 1402
    طراحی سایت و خدمات سئو

    139,000 تومان
    افزودن به سبد خرید