public
class
Process
extends Object
java.lang.Object | |
↳ | android.os.Process |
Tools for managing OS processes.
Constants | |
---|---|
int |
FIRST_APPLICATION_UID
Defines the start of a range of UIDs (and GIDs), going from this
number to |
int |
LAST_APPLICATION_UID
Last of application-specific UIDs starting at
|
int |
PHONE_UID
Defines the UID/GID under which the telephony code runs. |
int |
SIGNAL_KILL
|
int |
SIGNAL_QUIT
|
int |
SIGNAL_USR1
|
int |
SYSTEM_UID
Defines the UID/GID under which system code runs. |
int |
THREAD_PRIORITY_AUDIO
Standard priority of audio threads. |
int |
THREAD_PRIORITY_BACKGROUND
Standard priority background threads. |
int |
THREAD_PRIORITY_DEFAULT
Standard priority of application threads. |
int |
THREAD_PRIORITY_DISPLAY
Standard priority of system display threads, involved in updating the user interface. |
int |
THREAD_PRIORITY_FOREGROUND
Standard priority of threads that are currently running a user interface that the user is interacting with. |
int |
THREAD_PRIORITY_LESS_FAVORABLE
Minimum increment to make a priority less favorable. |
int |
THREAD_PRIORITY_LOWEST
Lowest available thread priority. |
int |
THREAD_PRIORITY_MORE_FAVORABLE
Minimum increment to make a priority more favorable. |
int |
THREAD_PRIORITY_URGENT_AUDIO
Standard priority of the most important audio threads. |
int |
THREAD_PRIORITY_URGENT_DISPLAY
Standard priority of the most important display threads, for compositing the screen and retrieving input events. |
Public constructors | |
---|---|
Process()
|
Public methods | |
---|---|
static
final
long
|
getElapsedCpuTime()
Returns elapsed milliseconds of the time this process has run. |
static
final
int[]
|
getExclusiveCores()
On some devices, the foreground process may have one or more CPU cores exclusively reserved for it. |
static
final
int
|
getGidForName(String name)
Returns the GID assigned to a particular user name, or -1 if there is none. |
static
final
long
|
getStartElapsedRealtime()
Return the |
static
final
long
|
getStartUptimeMillis()
Return the |
static
final
int
|
getThreadPriority(int tid)
Return the current priority of a thread, based on Linux priorities. |
static
final
int
|
getUidForName(String name)
Returns the UID assigned to a particular user name, or -1 if there is none. |
static
final
boolean
|
is64Bit()
Returns true if the current process is a 64-bit runtime. |
static
boolean
|
isApplicationUid(int uid)
Returns whether the given uid belongs to an application. |
static
final
void
|
killProcess(int pid)
Kill the process with the given PID. |
static
final
int
|
myPid()
Returns the identifier of this process, which can be used with
|
static
final
int
|
myTid()
Returns the identifier of the calling thread, which be used with
|
static
final
int
|
myUid()
Returns the identifier of this process's uid. |
static
UserHandle
|
myUserHandle()
Returns this process's user handle. |
static
final
void
|
sendSignal(int pid, int signal)
Send a signal to the given process. |
static
final
void
|
setThreadPriority(int tid, int priority)
Set the priority of a thread, based on Linux priorities. |
static
final
void
|
setThreadPriority(int priority)
Set the priority of the calling thread, based on Linux priorities. |
static
final
boolean
|
supportsProcesses()
This method was deprecated in API level 14. This method always returns true. Do not use. |
Inherited methods | |
---|---|
From
class
java.lang.Object
|
int FIRST_APPLICATION_UID
Defines the start of a range of UIDs (and GIDs), going from this
number to LAST_APPLICATION_UID
that are reserved for assigning
to applications.
Constant Value: 10000 (0x00002710)
int LAST_APPLICATION_UID
Last of application-specific UIDs starting at
FIRST_APPLICATION_UID
.
Constant Value: 19999 (0x00004e1f)
int PHONE_UID
Defines the UID/GID under which the telephony code runs.
Constant Value: 1001 (0x000003e9)
int SYSTEM_UID
Defines the UID/GID under which system code runs.
Constant Value: 1000 (0x000003e8)
int THREAD_PRIORITY_AUDIO
Standard priority of audio threads. Applications can not normally
change to this priority.
Use with setThreadPriority(int)
and
setThreadPriority(int, int)
, not with the normal
Thread
class.
Constant Value: -16 (0xfffffff0)
int THREAD_PRIORITY_BACKGROUND
Standard priority background threads. This gives your thread a slightly
lower than normal priority, so that it will have less chance of impacting
the responsiveness of the user interface.
Use with setThreadPriority(int)
and
setThreadPriority(int, int)
, not with the normal
Thread
class.
Constant Value: 10 (0x0000000a)
int THREAD_PRIORITY_DEFAULT
Standard priority of application threads.
Use with setThreadPriority(int)
and
setThreadPriority(int, int)
, not with the normal
Thread
class.
Constant Value: 0 (0x00000000)
int THREAD_PRIORITY_DISPLAY
Standard priority of system display threads, involved in updating
the user interface. Applications can not
normally change to this priority.
Use with setThreadPriority(int)
and
setThreadPriority(int, int)
, not with the normal
Thread
class.
Constant Value: -4 (0xfffffffc)
int THREAD_PRIORITY_FOREGROUND
Standard priority of threads that are currently running a user interface
that the user is interacting with. Applications can not normally
change to this priority; the system will automatically adjust your
application threads as the user moves through the UI.
Use with setThreadPriority(int)
and
setThreadPriority(int, int)
, not with the normal
Thread
class.
Constant Value: -2 (0xfffffffe)
int THREAD_PRIORITY_LESS_FAVORABLE
Minimum increment to make a priority less favorable.
Constant Value: 1 (0x00000001)
int THREAD_PRIORITY_LOWEST
Lowest available thread priority. Only for those who really, really
don't want to run if anything else is happening.
Use with setThreadPriority(int)
and
setThreadPriority(int, int)
, not with the normal
Thread
class.
Constant Value: 19 (0x00000013)
int THREAD_PRIORITY_MORE_FAVORABLE
Minimum increment to make a priority more favorable.
Constant Value: -1 (0xffffffff)
int THREAD_PRIORITY_URGENT_AUDIO
Standard priority of the most important audio threads.
Applications can not normally change to this priority.
Use with setThreadPriority(int)
and
setThreadPriority(int, int)
, not with the normal
Thread
class.
Constant Value: -19 (0xffffffed)
int THREAD_PRIORITY_URGENT_DISPLAY
Standard priority of the most important display threads, for compositing
the screen and retrieving input events. Applications can not normally
change to this priority.
Use with setThreadPriority(int)
and
setThreadPriority(int, int)
, not with the normal
Thread
class.
Constant Value: -8 (0xfffffff8)
long getElapsedCpuTime ()
Returns elapsed milliseconds of the time this process has run.
Returns | |
---|---|
long |
Returns the number of milliseconds this process has return. |
int[] getExclusiveCores ()
On some devices, the foreground process may have one or more CPU cores exclusively reserved for it. This method can be used to retrieve which cores that are (if any), so the calling process can then use sched_setaffinity() to lock a thread to these cores. Note that the calling process must currently be running in the foreground for this method to return any cores. The CPU core(s) exclusively reserved for the foreground process will stay reserved for as long as the process stays in the foreground. As soon as a process leaves the foreground, those CPU cores will no longer be reserved for it, and will most likely be reserved for the new foreground process. It's not necessary to change the affinity of your process when it leaves the foreground (if you had previously set it to use a reserved core); the OS will automatically take care of resetting the affinity at that point.
Returns | |
---|---|
int[] |
an array of integers, indicating the CPU cores exclusively reserved for this process. The array will have length zero if no CPU cores are exclusively reserved for this process at this point in time. |
int getGidForName (String name)
Returns the GID assigned to a particular user name, or -1 if there is none. If the given string consists of only numbers, it is converted directly to a gid.
Parameters | |
---|---|
name |
String
|
Returns | |
---|---|
int |
long getStartElapsedRealtime ()
Return the elapsedRealtime()
at which this process was started.
Returns | |
---|---|
long |
long getStartUptimeMillis ()
Return the uptimeMillis()
at which this process was started.
Returns | |
---|---|
long |
int getThreadPriority (int tid)
Return the current priority of a thread, based on Linux priorities.
Parameters | |
---|---|
tid |
int :
The identifier of the thread/process to change. |
Returns | |
---|---|
int |
Returns the current priority, as a Linux priority level, from -20 for highest scheduling priority to 19 for lowest scheduling priority. |
Throws | |
---|---|
IllegalArgumentException |
Throws IllegalArgumentException if tid does not exist. |
int getUidForName (String name)
Returns the UID assigned to a particular user name, or -1 if there is none. If the given string consists of only numbers, it is converted directly to a uid.
Parameters | |
---|---|
name |
String
|
Returns | |
---|---|
int |
boolean is64Bit ()
Returns true if the current process is a 64-bit runtime.
Returns | |
---|---|
boolean |
boolean isApplicationUid (int uid)
Returns whether the given uid belongs to an application.
Parameters | |
---|---|
uid |
int :
A kernel uid. |
Returns | |
---|---|
boolean |
Whether the uid corresponds to an application sandbox running in a specific user. |
void killProcess (int pid)
Kill the process with the given PID. Note that, though this API allows us to request to kill any process based on its PID, the kernel will still impose standard restrictions on which PIDs you are actually able to kill. Typically this means only the process running the caller's packages/application and any additional processes created by that app; packages sharing a common UID will also be able to kill each other's processes.
Parameters | |
---|---|
pid |
int
|
int myPid ()
Returns the identifier of this process, which can be used with
killProcess(int)
and sendSignal(int, int)
.
Returns | |
---|---|
int |
int myTid ()
Returns the identifier of the calling thread, which be used with
setThreadPriority(int, int)
.
Returns | |
---|---|
int |
int myUid ()
Returns the identifier of this process's uid. This is the kernel uid
that the process is running under, which is the identity of its
app-specific sandbox. It is different from myUserHandle()
in that
a uid identifies a specific app sandbox in a specific user.
Returns | |
---|---|
int |
UserHandle myUserHandle ()
Returns this process's user handle. This is the
user the process is running under. It is distinct from
myUid()
in that a particular user will have multiple
distinct apps running under it each with their own uid.
Returns | |
---|---|
UserHandle |
void sendSignal (int pid, int signal)
Send a signal to the given process.
Parameters | |
---|---|
pid |
int :
The pid of the target process. |
signal |
int :
The signal to send.
|
void setThreadPriority (int tid, int priority)
Set the priority of a thread, based on Linux priorities.
Parameters | |
---|---|
tid |
int :
The identifier of the thread/process to change. |
priority |
int :
A Linux priority level, from -20 for highest scheduling
priority to 19 for lowest scheduling priority. |
Throws | |
---|---|
IllegalArgumentException |
Throws IllegalArgumentException if tid does not exist. |
SecurityException |
Throws SecurityException if your process does not have permission to modify the given thread, or to use the given priority. |
void setThreadPriority (int priority)
Set the priority of the calling thread, based on Linux priorities. See
setThreadPriority(int, int)
for more information.
Parameters | |
---|---|
priority |
int :
A Linux priority level, from -20 for highest scheduling
priority to 19 for lowest scheduling priority. |
Throws | |
---|---|
IllegalArgumentException |
Throws IllegalArgumentException if tid does not exist. |
SecurityException |
Throws SecurityException if your process does not have permission to modify the given thread, or to use the given priority. |
See also:
boolean supportsProcesses ()
This method was deprecated
in API level 14.
This method always returns true. Do not use.
Determine whether the current environment supports multiple processes.
Returns | |
---|---|
boolean |
Returns true if the system can run in multiple processes, else false if everything is running in a single process. |