Package oshi.software.os.unix.freebsd
Class FreeBsdOperatingSystem
java.lang.Object
oshi.software.common.AbstractOperatingSystem
oshi.software.os.unix.freebsd.FreeBsdOperatingSystem
- All Implemented Interfaces:
OperatingSystem
@ThreadSafe public class FreeBsdOperatingSystem extends AbstractOperatingSystem
FreeBSD is a free and open-source Unix-like operating system descended from
the Berkeley Software Distribution (BSD), which was based on Research Unix.
The first version of FreeBSD was released in 1993. In 2005, FreeBSD was the
most popular open-source BSD operating system, accounting for more than
three-quarters of all installed simply, permissively licensed BSD systems.
-
Nested Class Summary
Nested classes/interfaces inherited from class oshi.software.common.AbstractOperatingSystem
AbstractOperatingSystem.FamilyVersionInfo
Nested classes/interfaces inherited from interface oshi.software.os.OperatingSystem
OperatingSystem.OSVersionInfo, OperatingSystem.ProcessSort
-
Field Summary
-
Constructor Summary
Constructors Constructor Description FreeBsdOperatingSystem()
Constructor for FreeBsdOperatingSystem. -
Method Summary
Modifier and Type Method Description OSProcess[]
getChildProcesses(int parentPid, int limit, OperatingSystem.ProcessSort sort)
Gets currently running child processes of provided PID.FileSystem
getFileSystem()
Instantiates aFileSystem
object.InternetProtocolStats
getInternetProtocolStats()
Instantiates aInternetProtocolStats
object.NetworkParams
getNetworkParams()
Instantiates aNetworkParams
object.OSProcess
getProcess(int pid, boolean slowFields)
Gets information on a currently running processlong
getProcessAffinityMask(int processId)
Retrieves the process affinity mask for the specified process.int
getProcessCount()
Get the number of processes currently runningOSProcess[]
getProcesses(int limit, OperatingSystem.ProcessSort sort, boolean slowFields)
Gets currently running processes.int
getProcessId()
Gets the current process IDOSService[]
getServices()
Gets the all services on the system.long
getSystemBootTime()
Get Unix time of boot.long
getSystemUptime()
Get the System up time (time since boot).int
getThreadCount()
Get the number of threads currently runningprotected int
queryBitness(int jvmBitness)
Backup OS-specific query to determine bitness if previous checks failprotected boolean
queryElevated()
AbstractOperatingSystem.FamilyVersionInfo
queryFamilyVersionInfo()
java.lang.String
queryManufacturer()
Methods inherited from class oshi.software.common.AbstractOperatingSystem
getBitness, getFamily, getManufacturer, getProcess, getProcesses, getProcesses, getProcesses, getProcesses, getVersion, getVersionInfo, isElevated, processSort, toString
-
Constructor Details
-
FreeBsdOperatingSystem
public FreeBsdOperatingSystem()Constructor for FreeBsdOperatingSystem.
-
-
Method Details
-
queryManufacturer
public java.lang.String queryManufacturer()- Specified by:
queryManufacturer
in classAbstractOperatingSystem
-
queryFamilyVersionInfo
- Specified by:
queryFamilyVersionInfo
in classAbstractOperatingSystem
-
queryBitness
protected int queryBitness(int jvmBitness)Description copied from class:AbstractOperatingSystem
Backup OS-specific query to determine bitness if previous checks fail- Specified by:
queryBitness
in classAbstractOperatingSystem
- Parameters:
jvmBitness
- The bitness of the JVM- Returns:
- The operating system bitness
-
queryElevated
protected boolean queryElevated()- Specified by:
queryElevated
in classAbstractOperatingSystem
-
getFileSystem
Description copied from interface:OperatingSystem
Instantiates aFileSystem
object.- Returns:
- A
FileSystem
object.
-
getInternetProtocolStats
Description copied from interface:OperatingSystem
Instantiates aInternetProtocolStats
object.- Returns:
- a
InternetProtocolStats
object.
-
getProcesses
Description copied from interface:OperatingSystem
Gets currently running processes. If a positive limit is specified, returns only that number of processes; zero will return all processes. The order may be specified by the sort parameter, for example, to return the top cpu or memory consuming processes; if null, no order is guaranteed.- Parameters:
limit
- Max number of results to return, or 0 to return all resultssort
- If not null, determines sorting of resultsslowFields
- If false, skipOSProcess
fields that are slow to retrieve (e.g., group information on Windows, open files on Unix and Linux). If true, include all fields, regardless of how long it takes to retrieve the data.- Returns:
- An array of
OSProcess
objects for the specified number (or all) of currently running processes, sorted as specified. The array may contain null elements if a process terminates during iteration.
-
getProcess
Description copied from interface:OperatingSystem
Gets information on a currently running process- Parameters:
pid
- A process IDslowFields
- If false, skipOSProcess
fields that are slow to retrieve (e.g., group information on Windows, open files on Unix and Linux). If true, include all fields, regardless of how long it takes to retrieve the data.- Returns:
- An
OSProcess
object for the specified process id if it is running; null otherwise
-
getChildProcesses
Description copied from interface:OperatingSystem
Gets currently running child processes of provided PID. If a positive limit is specified, returns only that number of processes; zero will return all processes. The order may be specified by the sort parameter, for example, to return the top cpu or memory consuming processes; if null, no order is guaranteed.- Parameters:
parentPid
- A process IDlimit
- Max number of results to return, or 0 to return all resultssort
- If not null, determines sorting of results- Returns:
- An array of
OSProcess
objects presenting the specified number (or all) of currently running child processes of the provided PID, sorted as specified. The array may contain null elements if a process terminates during iteration.
-
getProcessAffinityMask
public long getProcessAffinityMask(int processId)Description copied from interface:OperatingSystem
Retrieves the process affinity mask for the specified process.On Windows systems with more than 64 processors, if the threads of the calling process are in a single processor group, returns the process affinity mask for that group (which may be zero if the specified process is running in a different group). If the calling process contains threads in multiple groups, returns zero.
If the Operating System fails to retrieve an affinity mask (e.g., the process has terminated), returns zero.
- Parameters:
processId
- The process ID for which to retrieve the affinity.- Returns:
- a bit vector in which each bit represents the processors that a process is allowed to run on.
-
getProcessId
public int getProcessId()Description copied from interface:OperatingSystem
Gets the current process ID- Returns:
- the Process ID of the current process
-
getProcessCount
public int getProcessCount()Description copied from interface:OperatingSystem
Get the number of processes currently running- Returns:
- The number of processes running
-
getThreadCount
public int getThreadCount()Description copied from interface:OperatingSystem
Get the number of threads currently running- Returns:
- The number of threads running
-
getSystemUptime
public long getSystemUptime()Description copied from interface:OperatingSystem
Get the System up time (time since boot).- Returns:
- Number of seconds since boot.
-
getSystemBootTime
public long getSystemBootTime()Description copied from interface:OperatingSystem
Get Unix time of boot.- Returns:
- The approximate time at which the system booted, in seconds since the Unix epoch.
-
getNetworkParams
Description copied from interface:OperatingSystem
Instantiates aNetworkParams
object.- Returns:
- A
NetworkParams
object.
-
getServices
Description copied from interface:OperatingSystem
Gets the all services on the system. The definition of what is a service is platform-dependent.- Specified by:
getServices
in interfaceOperatingSystem
- Overrides:
getServices
in classAbstractOperatingSystem
- Returns:
- An array of
OSService
objects
-