Class WindowsOperatingSystem
- java.lang.Object
-
- oshi.software.common.AbstractOperatingSystem
-
- oshi.software.os.windows.WindowsOperatingSystem
-
- All Implemented Interfaces:
OperatingSystem
@ThreadSafe public class WindowsOperatingSystem extends AbstractOperatingSystem
Microsoft Windows, commonly referred to as Windows, is a group of several proprietary graphical operating system families, all of which are developed and marketed by Microsoft.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface oshi.software.os.OperatingSystem
OperatingSystem.OSVersionInfo, OperatingSystem.ProcessFiltering, OperatingSystem.ProcessSorting
-
-
Field Summary
Fields Modifier and Type Field Description private static longBOOTTIMEprivate static booleanIS_VISTA_OR_GREATERprivate static org.slf4j.LoggerLOGprivate java.util.function.Supplier<java.util.Map<java.lang.Integer,ProcessPerformanceData.PerfCounterBlock>>processMapFromPerfCountersprivate java.util.function.Supplier<java.util.Map<java.lang.Integer,ProcessPerformanceData.PerfCounterBlock>>processMapFromRegistryprivate static java.util.function.Supplier<java.lang.String>systemLogprivate java.util.function.Supplier<java.util.Map<java.lang.Integer,ThreadPerformanceData.PerfCounterBlock>>threadMapFromPerfCountersprivate java.util.function.Supplier<java.util.Map<java.lang.Integer,ThreadPerformanceData.PerfCounterBlock>>threadMapFromRegistryprivate static booleanUSE_PROCSTATE_SUSPENDEDprivate static booleanWOWprivate static booleanX86-
Fields inherited from class oshi.software.common.AbstractOperatingSystem
USE_WHO_COMMAND
-
-
Constructor Summary
Constructors Constructor Description WindowsOperatingSystem()
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description private static booleanenableDebugPrivilege()Attempts to enable debug privileges for this process, required for OpenProcess() to get processes other than the current user.OSThreadgetCurrentThread()Makes a best effort to get the current thread.java.util.List<OSDesktopWindow>getDesktopWindows(boolean visibleOnly)Gets windows on the operating system's GUI desktop.FileSystemgetFileSystem()Instantiates aFileSystemobject.InternetProtocolStatsgetInternetProtocolStats()Instantiates aInternetProtocolStatsobject.NetworkParamsgetNetworkParams()Instantiates aNetworkParamsobject.private static java.util.Map<java.lang.Integer,java.lang.Integer>getParentPidsFromSnapshot()OSProcessgetProcess(int pid)Gets information on a currently running processintgetProcessCount()Get the number of processes currently runningjava.util.List<OSProcess>getProcesses(java.util.Collection<java.lang.Integer> pids)Gets information on aCollectionof currently running processes.intgetProcessId()Gets the current process ID (PID).java.util.List<OSService>getServices()Gets the all services on the system.java.util.List<OSSession>getSessions()Gets currently logged in users.longgetSystemBootTime()Get Unix time of boot.longgetSystemUptime()Get the System up time (time since boot).intgetThreadCount()Get the number of threads currently runningintgetThreadId()Makes a best effort to get the current thread ID (TID).private static booleanisCurrentWow()private static booleanisCurrentX86()booleanisElevated()Determine whether the current process has elevated permissions such as sudo / Administrator(package private) static booleanisWow()Is the current operating process x86 or x86-compatibility mode?(package private) static booleanisWow(com.sun.jna.platform.win32.WinNT.HANDLE h)Is the specified process x86 or x86-compatibility mode?(package private) static booleanisX86()Is the processor architecture x86?private static java.lang.StringparseCodeName(int suiteMask)Gets suites available on the system and return as a codenameprivate java.util.List<OSProcess>processMapToList(java.util.Collection<java.lang.Integer> pids)java.util.List<OSProcess>queryAllProcesses()protected intqueryBitness(int jvmBitness)Backup OS-specific query to determine bitness if previous checks failjava.util.List<OSProcess>queryChildProcesses(int parentPid)java.util.List<OSProcess>queryDescendantProcesses(int parentPid)Pair<java.lang.String,OperatingSystem.OSVersionInfo>queryFamilyVersionInfo()java.lang.StringqueryManufacturer()private static java.util.Map<java.lang.Integer,ProcessPerformanceData.PerfCounterBlock>queryProcessMapFromPerfCounters()private static java.util.Map<java.lang.Integer,ProcessPerformanceData.PerfCounterBlock>queryProcessMapFromRegistry()private static longquerySystemBootTime()private static java.lang.StringquerySystemLog()private static longquerySystemUptime()private static java.util.Map<java.lang.Integer,ThreadPerformanceData.PerfCounterBlock>queryThreadMapFromPerfCounters()private static java.util.Map<java.lang.Integer,ThreadPerformanceData.PerfCounterBlock>queryThreadMapFromRegistry()-
Methods inherited from class oshi.software.common.AbstractOperatingSystem
getBitness, getChildProcesses, getChildrenOrDescendants, getChildrenOrDescendants, getDescendantProcesses, getFamily, getManufacturer, getProcesses, getVersionInfo, toString
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface oshi.software.os.OperatingSystem
getCurrentProcess, getProcesses
-
-
-
-
Field Detail
-
LOG
private static final org.slf4j.Logger LOG
-
USE_PROCSTATE_SUSPENDED
private static final boolean USE_PROCSTATE_SUSPENDED
-
IS_VISTA_OR_GREATER
private static final boolean IS_VISTA_OR_GREATER
-
systemLog
private static java.util.function.Supplier<java.lang.String> systemLog
-
BOOTTIME
private static final long BOOTTIME
-
X86
private static final boolean X86
-
WOW
private static final boolean WOW
-
processMapFromRegistry
private java.util.function.Supplier<java.util.Map<java.lang.Integer,ProcessPerformanceData.PerfCounterBlock>> processMapFromRegistry
-
processMapFromPerfCounters
private java.util.function.Supplier<java.util.Map<java.lang.Integer,ProcessPerformanceData.PerfCounterBlock>> processMapFromPerfCounters
-
threadMapFromRegistry
private java.util.function.Supplier<java.util.Map<java.lang.Integer,ThreadPerformanceData.PerfCounterBlock>> threadMapFromRegistry
-
threadMapFromPerfCounters
private java.util.function.Supplier<java.util.Map<java.lang.Integer,ThreadPerformanceData.PerfCounterBlock>> threadMapFromPerfCounters
-
-
Method Detail
-
queryManufacturer
public java.lang.String queryManufacturer()
- Specified by:
queryManufacturerin classAbstractOperatingSystem
-
queryFamilyVersionInfo
public Pair<java.lang.String,OperatingSystem.OSVersionInfo> queryFamilyVersionInfo()
- Specified by:
queryFamilyVersionInfoin classAbstractOperatingSystem
-
parseCodeName
private static java.lang.String parseCodeName(int suiteMask)
Gets suites available on the system and return as a codename- Parameters:
suiteMask- The suite mask bitmask- Returns:
- Suites
-
queryBitness
protected int queryBitness(int jvmBitness)
Description copied from class:AbstractOperatingSystemBackup OS-specific query to determine bitness if previous checks fail- Specified by:
queryBitnessin classAbstractOperatingSystem- Parameters:
jvmBitness- The bitness of the JVM- Returns:
- The operating system bitness
-
isElevated
public boolean isElevated()
Description copied from interface:OperatingSystemDetermine whether the current process has elevated permissions such as sudo / Administrator- Returns:
- True if this process has elevated permissions
-
getFileSystem
public FileSystem getFileSystem()
Description copied from interface:OperatingSystemInstantiates aFileSystemobject.- Returns:
- A
FileSystemobject.
-
getInternetProtocolStats
public InternetProtocolStats getInternetProtocolStats()
Description copied from interface:OperatingSystemInstantiates aInternetProtocolStatsobject.- Returns:
- a
InternetProtocolStatsobject.
-
getSessions
public java.util.List<OSSession> getSessions()
Description copied from interface:OperatingSystemGets currently logged in users.On macOS, Linux, and Unix systems, the default implementation uses native code (see
man getutxent) that is not thread safe. OSHI's use of this code is synchronized and may be used in a multi-threaded environment without introducing any additional conflicts. Users should note, however, that other operating system code may access the same native code.The
Who.queryWho()method produces similar output parsing the output of the Posix-standardwhocommand, and may internally employ reentrant code on some platforms. Users may opt to use this command-line variant by default using theoshi.os.unix.whoCommandconfiguration property.- Returns:
- A list of
OSSessionobjects representing logged-in users
-
getProcesses
public java.util.List<OSProcess> getProcesses(java.util.Collection<java.lang.Integer> pids)
Description copied from interface:OperatingSystemGets information on aCollectionof currently running processes. This has potentially improved performance vs. iterating individual processes.- Parameters:
pids- A collection of process IDs- Returns:
- A list of
OSProcessobjects for the specified process ids if it is running
-
queryAllProcesses
public java.util.List<OSProcess> queryAllProcesses()
- Specified by:
queryAllProcessesin classAbstractOperatingSystem
-
queryChildProcesses
public java.util.List<OSProcess> queryChildProcesses(int parentPid)
- Specified by:
queryChildProcessesin classAbstractOperatingSystem
-
queryDescendantProcesses
public java.util.List<OSProcess> queryDescendantProcesses(int parentPid)
- Specified by:
queryDescendantProcessesin classAbstractOperatingSystem
-
getParentPidsFromSnapshot
private static java.util.Map<java.lang.Integer,java.lang.Integer> getParentPidsFromSnapshot()
-
getProcess
public OSProcess getProcess(int pid)
Description copied from interface:OperatingSystemGets information on a currently running process- Parameters:
pid- A process ID- Returns:
- An
OSProcessobject for the specified process id if it is running; null otherwise
-
processMapToList
private java.util.List<OSProcess> processMapToList(java.util.Collection<java.lang.Integer> pids)
-
queryProcessMapFromRegistry
private static java.util.Map<java.lang.Integer,ProcessPerformanceData.PerfCounterBlock> queryProcessMapFromRegistry()
-
queryProcessMapFromPerfCounters
private static java.util.Map<java.lang.Integer,ProcessPerformanceData.PerfCounterBlock> queryProcessMapFromPerfCounters()
-
queryThreadMapFromRegistry
private static java.util.Map<java.lang.Integer,ThreadPerformanceData.PerfCounterBlock> queryThreadMapFromRegistry()
-
queryThreadMapFromPerfCounters
private static java.util.Map<java.lang.Integer,ThreadPerformanceData.PerfCounterBlock> queryThreadMapFromPerfCounters()
-
getProcessId
public int getProcessId()
Description copied from interface:OperatingSystemGets the current process ID (PID).- Returns:
- the Process ID of the current process
-
getProcessCount
public int getProcessCount()
Description copied from interface:OperatingSystemGet the number of processes currently running- Returns:
- The number of processes running
-
getThreadId
public int getThreadId()
Description copied from interface:OperatingSystemMakes a best effort to get the current thread ID (TID). May not be useful in a multithreaded environment. The thread ID returned may have been short lived and no longer exist.Thread IDs on macOS are not correlated with any other Operating System output.
- Returns:
- the Thread ID of the current thread if known, 0 otherwise.
-
getCurrentThread
public OSThread getCurrentThread()
Description copied from interface:OperatingSystemMakes a best effort to get the current thread. May not be useful in a multithreaded environment. The thread returned may have been short lived and no longer exist.On macOS, returns the oldest thread in the calling process.
- Returns:
- the current thread if known; an invalid thread otherwise.
-
getThreadCount
public int getThreadCount()
Description copied from interface:OperatingSystemGet the number of threads currently running- Returns:
- The number of threads running
-
getSystemUptime
public long getSystemUptime()
Description copied from interface:OperatingSystemGet the System up time (time since boot).- Returns:
- Number of seconds since boot.
-
querySystemUptime
private static long querySystemUptime()
-
getSystemBootTime
public long getSystemBootTime()
Description copied from interface:OperatingSystemGet Unix time of boot.- Returns:
- The approximate time at which the system booted, in seconds since the Unix epoch.
-
querySystemBootTime
private static long querySystemBootTime()
-
getNetworkParams
public NetworkParams getNetworkParams()
Description copied from interface:OperatingSystemInstantiates aNetworkParamsobject.- Returns:
- A
NetworkParamsobject.
-
enableDebugPrivilege
private static boolean enableDebugPrivilege()
Attempts to enable debug privileges for this process, required for OpenProcess() to get processes other than the current user. Requires elevated permissions.- Returns:
trueif debug privileges were successfully enabled.
-
getServices
public java.util.List<OSService> getServices()
Description copied from interface:OperatingSystemGets the all services on the system. The definition of what is a service is platform-dependent.- Returns:
- An array of
OSServiceobjects
-
querySystemLog
private static java.lang.String querySystemLog()
-
getDesktopWindows
public java.util.List<OSDesktopWindow> getDesktopWindows(boolean visibleOnly)
Description copied from interface:OperatingSystemGets windows on the operating system's GUI desktop.On Unix-like systems, reports X11 windows only, which may be limited to the current display and will not report windows used by other window managers.
While not a guarantee, a best effort is made to return windows in foreground-to-background order. This ordering may be used along with
OSDesktopWindow.getOrder()to (probably) determine the frontmost window.- Parameters:
visibleOnly- Whether to restrict the list to only windows visible to the user.This is a best effort attempt at a reasonable definition of visibility. Visible windows may be completely transparent.
- Returns:
- A list of
OSDesktopWindowobjects representing the desktop windows.
-
isX86
static boolean isX86()
Is the processor architecture x86?- Returns:
- true if the processor architecture is Intel x86
-
isCurrentX86
private static boolean isCurrentX86()
-
isWow
static boolean isWow()
Is the current operating process x86 or x86-compatibility mode?- Returns:
- true if the current process is 32-bit
-
isWow
static boolean isWow(com.sun.jna.platform.win32.WinNT.HANDLE h)
Is the specified process x86 or x86-compatibility mode?- Parameters:
h- The handle to the processs to check- Returns:
- true if the process is 32-bit
-
isCurrentWow
private static boolean isCurrentWow()
-
-