Class WindowsCentralProcessor

java.lang.Object
oshi.hardware.common.AbstractCentralProcessor
oshi.hardware.platform.windows.WindowsCentralProcessor
All Implemented Interfaces:
CentralProcessor

@ThreadSafe final class WindowsCentralProcessor extends AbstractCentralProcessor
A CPU, representing all of a system's processors. It may contain multiple individual Physical and Logical processors.
  • Field Details

  • Constructor Details

    • WindowsCentralProcessor

      WindowsCentralProcessor()
  • Method Details

    • queryProcessorId

      protected CentralProcessor.ProcessorIdentifier queryProcessorId()
      Initializes Class variables
      Specified by:
      queryProcessorId in class AbstractCentralProcessor
      Returns:
      An array of initialized Logical Processors
    • parseIdentifier

      private static String parseIdentifier(String identifier, String key)
      Parses identifier string
      Parameters:
      identifier - the full identifier string
      key - the key to retrieve
      Returns:
      the string following id
    • initProcessorCounts

      Description copied from class: AbstractCentralProcessor
      Initializes logical and physical processor lists and feature flags.
      Specified by:
      initProcessorCounts in class AbstractCentralProcessor
      Returns:
      Lists of initialized Logical Processors, Physical Processors, Processor Caches, and Feature Flags.
    • querySystemCpuLoadTicks

      public long[] querySystemCpuLoadTicks()
      Description copied from class: AbstractCentralProcessor
      Get the system CPU load ticks
      Specified by:
      querySystemCpuLoadTicks in class AbstractCentralProcessor
      Returns:
      The system CPU load ticks
    • queryCurrentFreq

      public long[] queryCurrentFreq()
      Description copied from class: AbstractCentralProcessor
      Get processor current frequency.
      Specified by:
      queryCurrentFreq in class AbstractCentralProcessor
      Returns:
      The current frequency.
    • queryMaxFreq

      public long queryMaxFreq()
      Description copied from class: AbstractCentralProcessor
      Get processor max frequency.
      Overrides:
      queryMaxFreq in class AbstractCentralProcessor
      Returns:
      The max frequency.
    • queryNTPower

      private long[] queryNTPower(int fieldIndex)
      Call CallNTPowerInformation for Processor information and return an array of the specified index
      Parameters:
      fieldIndex - The field, in order as defined in the
      invalid reference
      PowrProf#PROCESSOR_INFORMATION
      structure.
      Returns:
      The array of values.
    • getSystemLoadAverage

      public double[] getSystemLoadAverage(int nelem)
      Description copied from interface: CentralProcessor
      Returns the system load average for the number of elements specified, up to 3, representing 1, 5, and 15 minutes. The system load average is the sum of the number of runnable entities queued to the available processors and the number of runnable entities running on the available processors averaged over a period of time.

      This method is designed to provide a hint about the system load and may be queried frequently.

      The way in which the load average is calculated is operating system specific but is typically a damped time-dependent average. Linux includes processes waiting for system resources such as disks, while macOS and Unix consider only processes waiting for CPU.

      Windows does not provide a load average. Users may set the configuration property oshi.os.windows.loadaverage to true to start a daemon thread which will provide a similar metric.

      The load average may be unavailable on some platforms (e.g., Windows without the above configuration). If the load average is not available, a negative value is returned.

      Parameters:
      nelem - Number of elements to return.
      Returns:
      an array of the system load averages for 1, 5, and 15 minutes with the size of the array specified by nelem; or negative values if not available.
    • queryProcessorCpuLoadTicks

      public long[][] queryProcessorCpuLoadTicks()
      Description copied from class: AbstractCentralProcessor
      Get the processor CPU load ticks
      Specified by:
      queryProcessorCpuLoadTicks in class AbstractCentralProcessor
      Returns:
      The processor CPU load ticks
    • lazilyCalculateMultiplier

      private long lazilyCalculateMultiplier(long deltaBase, long deltaT)
      Lazily calculate the capacity tick multiplier once.
      Parameters:
      deltaBase - The difference in base ticks.
      deltaT - The difference in elapsed 100NS time
      Returns:
      The ratio of elapsed time to base ticks
    • queryProcessorUtilityCounters

      private static Pair<List<String>,Map<ProcessorInformation.ProcessorUtilityTickCountProperty,List<Long>>> queryProcessorUtilityCounters()
    • queryContextSwitches

      public long queryContextSwitches()
      Description copied from class: AbstractCentralProcessor
      Get number of context switches
      Specified by:
      queryContextSwitches in class AbstractCentralProcessor
      Returns:
      The context switches
    • queryInterrupts

      public long queryInterrupts()
      Description copied from class: AbstractCentralProcessor
      Get number of interrupts
      Specified by:
      queryInterrupts in class AbstractCentralProcessor
      Returns:
      The interrupts