Methods and apparatus for managing execution of an application according to an application lifecycle. The application lifecycle is managed by an application manager through a set of commands that enable the application manager to cause the application to enter one of a plurality of states. In addition, the application can communicate with the application manager to indicate that the application cannot change its state as the application manager has requested or to request that the application manager change the state of the application to a particular state.
|
1. A computer-implemented method of managing execution of an application according to a lifecycle, comprising:
receiving a signal indicating that a new service is selected;
initiating execution of the application when the new service is selected such that the application enters an active state;
pausing execution of the application such that the application enters a paused state from the active state;
receiving a resume request from the application that has been paused indicating that the application wishes to resume execution and enter the active state from the paused state; and
starting execution of the application from which the resume request was received such that the application enters the active state from the paused state when the resume request is received from the application, thereby enabling the application to initiate its own state change from the paused state to the active state without human intervention.
2. A computer-implemented method of managing execution of a plurality of applications according to a lifecycle, comprising:
initiating execution of each one of the plurality of applications such that the plurality of applications enter an active state;
pausing execution of one of the plurality of applications such that the one of the plurality of applications enters a paused state from the active state;
receiving a resume request from the one of the applications that has been paused, the resume request indicating that the one of the plurality of applications requests to resume execution and enter the active state from the paused state; and
starting execution of the one of the plurality of applications from which the resume request was received such that the one of the plurality of applications enters the active state from the paused state in response to receiving the resume request from the application, thereby enabling the one of the plurality of applications to initiate its own state change from the paused state to the active state without human intervention.
31. A digital television receiver for managing execution of an application according to a lifecycle, comprising:
means for determining from a data stream whether an application is present in the data stream;
means for loading an application when it is determined that an application is present in the data stream;
means for executing the loaded application according to the lifecycle, the lifecycle including a plurality of states;
means for enabling the application manager to cause the application to change from one of the plurality of states to another one of the plurality of states; and
means for enabling the application to prevent a change in state of the application requested by the application manager or to communicate to the application manager a state change of the application from one of a first set of the plurality of states to one of a second set of the plurality of states, wherein the state change of the application is initiated by the application without human intervention, and wherein means for enabling the application to communicate to the application manager that the application cannot change its state as the application manager has requested, thereby enabling the application to prevent its own state change.
3. A computer-implemented method of managing execution of an application according to a lifecycle, comprising:
requesting a first time that the application change its state from a first state to a second state by sending a request to the application, wherein the request is a conditional request that is conditional upon the application's decision to change from the first state to the second state, thereby enabling the application to allow or prevent its own state change from the first state to the second state in response to the conditional request;
determining whether the application has decided to allow its own state change from the first state to the second state in response to the conditional request by ascertaining whether the application has changed its state from the first state to the second state; and
requesting a second time that the application change its state from the first state to the second state when it is determined that the application has not changed its state from the first state to the second state and a predetermined condition is satisfied, wherein the predetermined condition indicates that a specified period of time has elapsed or that the application is now able to perform the requested state change.
19. A system for managing execution of an application on a computer according to a lifecycle, the system comprising:
a processor; and
a memory, the processor and the memory providing:
one or more rules;
an application manager capable of executing one or more applications according to the lifecycle, the lifecycle enabling each of the applications to enter one of a plurality of states in response to one or more associated predetermined commands, the application manager capable of selecting one of the predetermined commands to execute according to the one or more rules;
a mechanism for enabling the application to perform at least one of initiate and prevent its own state change from a first one of the plurality of states to a second one of the plurality of states without human intervention; and
an application environment object enabling the application to communicate with the application manager, thereby enabling the application to perform at least one of initiate its own state change, inform the application manager of the application-initiated state change, prevent its own state change, and inform the application manager that it is preventing its own change state change that has been requested by the application manager.
13. An apparatus for managing execution of an application according to a lifecycle, comprising:
a processor; and
a memory, the processor and the memory being adapted for:
requesting a first time that the application change its state from a first state to a second state by sending a request to the application, wherein the request is a conditional request that is conditional upon the application's decision to change from the first state to the second state, thereby enabling the application to allow or prevent its own state change from the first state to the second state in response to the conditional request;
determining whether the application has decided to allow its own state change from the first state to the second state in response to the conditional request by ascertaining whether the application has changed its state from the first state to the second state; and
requesting a second time that the application change its state from the first state to the second state when it is determined that the application has not changed its state from the first state to the second state and a predetermined condition is satisfied, wherein the predetermined condition indicates that a specified period of time has elapsed or that the application is now able to perform the requested state change.
9. A computer-implemented method of managing execution of an application according to a lifecycle, comprising:
requesting that the application change its state from a first state to a second state by sending a request to the application, wherein the request is a conditional request that is conditional upon the application's decision to change from the first state to the second state, thereby enabling the application to allow or prevent its own state change from the first state to the second state in response to the conditional request;
determining whether the application has decided to allow its own state change from the first state to the second state in response to the conditional request by ascertaining whether the application has changed its state from the first state to the second state, wherein the first state is an active state indicating that the application is currently executing, the second state is a destroyed state indicating that the execution of the application has terminated, and the third state is a paused state indicating that execution of the application has paused such that the application can resume execution; and
requesting that the application change its state from the first state to a third state when it is determined that the application has not changed its state from the first state to the second state.
4. The method as recited in
5. The method as recited in
6. The method as recited in
8. The method as recited in
10. The method as recited in
11. The method as recited in
12. The method as recited in
14. The apparatus as recited in
15. The apparatus as recited in
16. The apparatus as recited in
17. The apparatus as recited in
18. The apparatus as recited in
20. The system as recited in
a signaling monitor coupled to the application manager and capable of receiving a data stream, the signal monitor adapted for determining whether an application is present in the data stream and communicating information associated with the application to the application manager.
21. The system as recited in
22. The system as recited in
23. The system as recited in
24. The system as recited in
25. The system as recited in
26. The system as recited in
27. The system as recited in
28. The system as recited in
a display manager coupled to the application manager and adapted for managing a display context for each of the applications, the display context being in a first state when the display context is visible and being in a second state when the display context is invisible.
29. The system as recited in
30. The system as recited in
32. The digital television receiver as recited in
33. The digital television receiver as recited in
means for releasing memory associated with the application when the application has been terminated.
34. The digital television receiver as recited in
means for enabling the application to request that the application manager change the state of the application from one of the first set of the plurality of states to one of the second set of the plurality of states, thereby enabling the application to initiate its own state change without human intervention.
35. The digital television receiver as recited in
36. The digital television receiver as recited in
means for enabling the application to raise a state change exception indicating that the application cannot change its state as the application manager has requested.
37. The digital television receiver as recited in
means for enabling the application to raise a state change exception indicating that the application does not want to change its state as the application manager has requested, thereby enabling the application to prevent its own state change.
38. The digital television receiver as recited in
means for creating a class loader associated with each one of a plurality of applications such that a plurality of class loaders are generated, each of the plurality of class loaders being associated with only one of the plurality of applications, the class loader being adapted for loading one or more classes associated with the application;
means for employing the class loader to load the classes associated with one of the plurality of applications; and
means for instantiating the application using the classes that have been loaded by the class loader.
39. The digital television receiver as recited in
means for unloading the classes associated with the application when the application is terminated.
40. The digital television receiver as recited in
means for de-referencing the class loader by an application manager.
|
This invention is related to U.S. patent application Ser. No. 09/465,994, filed on the same day as this patent application, naming Tao Ye et al. as inventors, and entitled “METHODS AND APPARATUS FOR IMPLEMENTING AN APPLICATION LIFECYCLE DESIGN FOR APPLICATIONS.” That application is incorporated herein by reference in its entirety and for all purposes.
This invention is also related to U.S. patent application Ser. No. 09/465,995, filed on the same day as this patent application, which later issued as U.S. Pat. No. 6,701,334, naming Tao Ye et al. as inventors, and entitled “METHODS AND APPARATUS FOR IMPLEMENTING INDIVIDUAL CLASS LOADERS.” That application is incorporated herein by reference in its entirety and for all purposes.
1. Field of the Invention
The present invention relates generally to computer software. More particularly, the present invention relates to methods and apparatus for managing execution of an application.
2. Description of Related Art
The digital television revolution is one of the most significant events in the history of broadcast television. With the advent of digital television, high speed data transfer is possible via satellite, cable and terrestrial television channels. Digital television offers users more channels as well as significantly improved video and audio quality. Most importantly, digital television ushers in the age of true interactive television. For instance, digital receivers will be able to offer users a variety of enhanced services, from simple interactive quiz shows, to internet, and a mix of television and web-type content. As the market for digital television grows, content developers are looking for a feature-rich, cost-effective, and reliable software platform upon which to build the next generation of interactive television services such as Electronic Programming Guides, Video-On-Demand, and Enhanced Broadcasting.
Java is a leading commercial object-oriented language designed as a portable language that can run on any compatible device that supports the JAVA™ PLATFORM. For instance, Java is incorporated into all major Web browsers. Thus, Java runs on any web-enabled computer via that computer's Web browser. As such, Java offers great promise as the software platform for set-top boxes and digital television.
In object-oriented programming, code and data are merged into objects. Each object is defined via its class, which determines the properties and behavior of an object. In other words, objects are individual instances of a class.
In the desktop environment, certain resources associated with each loaded application (e.g., classes and objects) need not be frequently released or tightly monitored since memory is relatively unlimited. However, memory is a valuable resource in the environment of embedded systems, particularly in the area of digital television. Moreover, in an interactive digital television environment, it will be common to run multiple applications. A digital television service might consist of audio, video and one or more applications. For instance, when a television viewer changes the channel, each associated service or program provided by that channel will likely require that multiple classes be loaded. As a result, memory will continually be allocated to the applications and associated classes until the limited amount of memory is consumed. Once the memory is consumed, it will be impossible to run any further applications. This is particularly important since it will be undesirable to reboot the set-top box in the event of an error.
The JAVA PLATFORM currently defines a number of application models, each with its own lifecycle. In general, these application lifecycle models have been designed to address specific issues on the JAVA PLATFORM. For instance, the Applet was designed to provide support for executable content in web pages. However, none of the existing application lifecycle models fully address the requirements specific to systems having limited memory, such as television receivers. For instance, classes associated with an Applet, once loaded, its class objects will not be removed from memory. Moreover, it is impossible to determine when execution of the Applet has been terminated.
In view of the above, it would be beneficial if an application lifecycle were designed to address the requirements specific to television receivers. Moreover, it would be desirable if a mechanism for managing the loading and execution of an application according to an application lifecycle were designed.
The present invention enables one or more applications to be managed. In addition, execution of one or more applications may be managed according to an application lifecycle. This is accomplished, in part, through the use of an application manager that is capable of initiating and monitoring changes in the state of the application. In this manner, applications may be executed in a consistent manner on a variety of platforms.
According to one aspect of the invention, an application manager loads the application and allocates resources to the application for use by the application throughout its execution. Once the application is loaded, the application manager executes the application according to an application lifecycle. This is accomplished according to one embodiment through an application interface that is visible to the application manager. Through this application interface, the application manager can initiate various state changes in the application. As one example, the application manager may request the application to pause its execution and enter a paused state. As another example, the application manager may request the application to continue its execution from the paused state and enter an active state.
According to another aspect of the invention, the application communicates information regarding its state and potential state changes to an application manager. According to one embodiment, this is accomplished, in part, through an application environment interface. Through this application environment interface, the application may request that the application manager cause a state change of the application. For example, the application may request that the application manager cause the application to enter the active state. In addition, the application may indicate through this application environment interface that the application cannot perform the service as requested and therefore has paused or terminated, as appropriate under the circumstances. Once the state of the application is changed (e.g., caused by the application manager or performed by the application), the application may communicate this state change to the application manager (e.g., through an application environment interface that is visible to the application).
According to yet another aspect of the invention, the application manager may terminate the application on a conditional or unconditional basis. When the application manager terminates the application unconditionally, the application must terminate. However, when the application manager terminates the application on a conditional basis, the application manager may terminate the application only when the application agrees to its termination. In this manner, the application manager may terminate applications and therefore release resources associated with applications in a manner that is agreed upon by the applications being terminated.
The present invention enables applications to be managed according to an application lifecycle by an application manager. This enables applications to be executed in a predictable manner regardless of the platform on which they are executed. Moreover, since the application manager monitors the current state of each of the applications, the application manager may release memory associated with each application immediately upon its termination. This is particularly useful in systems having limited memory, such as in a digital television receiver.
The invention, together with further advantages thereof, may best be understood by reference to the following description taken in conjunction with the accompanying drawings in which:
In the following description, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art, that the present invention may be practiced without some or all of these specific details. In other instances, well known process steps have not been described in detail in order not to unnecessarily obscure the present invention.
An invention is described herein that enables an application to be loaded and executed according to an application lifecycle. The sequence of steps by which an application becomes initialized, makes various state changes based on its environment, and eventually is destroyed is collectively known as the application lifecycle. According to one embodiment, this is accomplished through the use of an application manager that is capable of loading and managing execution of one or more applications. According to one embodiment, the application lifecycle is implemented through the use of two interfaces. First, an application programming interface enables the application manager to manage the execution of an application according to the application lifecycle. Second, an application environment interface enables the application to communicate to the application manager its desire to change from one state to another or, alternatively, indicate that it is unable to perform a state change as requested by the application manager. For example, an application may request that the application manager cause the application to enter an active state. As another example, the application may indicate that it has entered a paused state or a destroyed state (e.g., when it is unable to enter the active state as requested by the application manager). Thus, the application environment interface may enable the application communicate to the application manager that it has changed from one state to another since the application ultimately has the best knowledge of the state that it is in.
The invention is described within the context of a digital television and digital television receiver.
A Java Virtual Machine is one platform that may be used to implement the present invention to process information received by a digital television receiver such as that illustrated in
According to one embodiment of the invention, the application manager is configured to operate according to a set of rules 216. These rules may be specified in a variety of ways in order to implement an application lifecycle. For instance, an application lifecycle may enable an application to enter a loaded state, a paused state, an active state, and a destroyed state upon the occurrence of predetermined events.
The application manager 208 may simultaneously manage the lifecycle of numerous applications. According to one embodiment of the invention, in order to maintain information associated with each potentially executing application 400, the application manager manages an application context list 402.
According to one embodiment, information associated with an application is centralized and referenced by the application context 404.
As described above with reference to
The display context may be displayed according to a state diagram for the display context.
An application lifecycle is implemented by enabling an application to enter a number of states under predetermined conditions. The states, as well as the conditions that determine when an application will enter each of the states, may vary according to the implementation of the application manager and the application lifecycle.
As described above with reference to
Once the application is in the paused state, the application may enter the active state. However, only the application manager can cause this state change using a start method 708. The start method 708, once called, signals the application to start providing service and enter the active state. In the active state, the application may hold shared resources. A variety of failures may prevent the service from starting. For instance, the failure may be transient or non-transient. According to one embodiment, the application distinguishes between these two types of failures. For transient failures, a state change exception is raised. When a non-transient failure occurs, another exception may be raised or a done method may be called to properly terminate the method. For example, when the application determines that it cannot access the resources it needs to execute, this may be implemented as either a transient or non-transient failure.
A pause method 710, once called by the application manager, signals the application to stop executing and enter the paused state from the active state. In the paused state, the application stops executing and tries to use as few resources as possible. Thus, the application may release a portion or all of the shared resources held by it.
It may be desirable to terminate the application from any one of the loaded, active, or paused states. This may be accomplished by calling a destroy method 712. The destroy method 712 signals the application to terminate and enter the destroyed state. In the destroyed state, the application should release all resources and save preferences or state information.
When the application manager wishes to destroy (e.g., terminate) an application, it may be desirable to indicate various levels of urgency. According to one embodiment, the termination of an application is performed when a predetermined condition is satisfied. As one example, the predetermined condition may be the presence of a signal from the application agreeing to its premature termination. As another example, the predetermined condition may be the lack of receipt of a signal from the application within a specified period of time. This may be accomplished through a parameter 714 to the destroy method 712. The parameter 714 indicates that the destroy signal is conditional when in a first state and unconditional when in a second state. Thus, when the application manager merely wishes to request that the application terminate, it may specify that the destroy signal is conditional upon the application's decision to terminate. The application may indicate that it wishes to continue to execute and therefore not enter the destroyed state by raising a state change exception. If the application manager wishes to honor this request from the application, the application manager may call the destroy method again at a later time. Alternatively, the application manager may attempt to destroy another application that has, for example, a higher (or lower) priority. In this manner, the application manager may obtain resources needed by it (e.g., by the next application to be loaded) from only those applications which choose to terminate. Moreover, the application manager may attempt to destroy the applications in a specified order, such as a priority order, the application using the most (or least) amount of memory, or order in which execution has been initiated.
When the application manager needs a specific application to terminate, it may indicate this by specifying that the destroy signal is unconditional through the parameter 714 of the destroy method 712. For instance, the application manager may specify that the destroy signal is unconditional when all resources held by the application are needed by the application manager. Thus, the application manager may force an application to terminate and release resources held by it when the destroy signal is unconditional. Accordingly, even if an application raises a state change exception indicating that it wishes to continue to execute, the application manager may ignore this exception when the destroy signal is unconditional. Although the above-description refers to the conditional and unconditional termination of an application, other operations may similarly be performed conditionally and unconditionally.
As described above, an application environment object is passed to an application when the application is initialized. In addition, the application environment object provides an application with a mechanism to retrieve properties, as well as a way to signal internal state changes. According to one embodiment, the application environment object has an application environment interface that is available to the application being loaded and executed. More particularly, once the application is initialized, the application environment interface is available to the application.
As described above, the application may enter the destroyed state from the loaded, active, or paused states. Moreover, the application manager or the application may cause the application to enter the destroyed state. As shown and described with reference to
When the application is in the active state, the application manager or the application may cause the application to enter the paused state. More particularly, the application manager may pause the application using the pause method, as shown and described with reference to
A get property method 808 having a parameter 810 provides an application with a mechanism to retrieve one or more properties from the application environment object. As one example, in a Java environment, a “root container” is typically used to contain user interface components (e.g., pull-down menus, buttons) so that they can be displayed in the Java environment. Thus, the get property method 808 may be used to determine the root container in which components can be placed. As another example, information associated with the broadcast data stream (e.g., location of file within the broadcast data stream) may be obtained. Other properties may include, for example, a reference to a service session object (service context) and information specific to the underlying transport protocol.
Although only the application manager can cause an application to enter the active state, the application may wish to indicate that it is interested in entering the active state. This is accomplished, according to one embodiment, via a resume request method 812. Through the resume request method 812, one or more applications may each indicate a desire to enter the active state. However, the number of applications that may be simultaneously executed may be limited by the set of rules that the application manager follows. For instance, as described above with reference to
Through the above described interfaces, the application lifecycle can be controlled by both the application manager and the application. Although the interfaces are well-defined, the bodies of the methods shown and described above with reference to
A variety of digital television services may be received by a digital television receiver such as that illustrated in
At block 1016 it is determined whether an application associated with the selected service is present in the data stream. For instance, when the user selects the Disney service, a Disney application may be received in the data stream. If it is determined that an application is present in the data stream at block 1018, the application manager loads the application as shown at block 1022 and executes the application according to the application lifecycle at block 1024. The loading and executing processes will be described in further detail below with reference to
Once the application is instantiated, the application enters the loaded state as shown at block 1114. In order to enable the application to obtain properties associated with its environment and communicate with the application manager, an application environment object complying with an application environment interface such as that illustrated in
In addition to loading the application, the application manager is responsible for monitoring and managing the execution of the application.
Once destroyed, resources held by the application may be released. For instance, a signal may be received by the application manager (e.g., from the application or the broadcast environment via the receiver) to initiate clean-up of the application. More particularly, the class loader may unload the classes associated with the application at block 1214. In addition, the application context referenced by the application context list as shown in
As described above, the application manager changes the state of an application from loaded to paused in order to prepare it for execution.
According to one embodiment, only the application manager can change the state of the application to the active state.
The present invention may be applied in a variety of situations. One example is that of a stock ticker that is displayed at the bottom of a monitor (e.g., television screen) on various channels. The stock information may be obtained by a receiver from a broadcast service or a back channel to a central server or broadcaster (e.g., via modem, cable, or other connection to the Internet). Assuming that the stock ticker application is in the paused state after initialization, a user presses a button on the television's remote that signals the application manager to start the stock ticker application. The application manager calls the start application method for the stock ticker application. The application manager assumes at this point that the application is performing its service. Upon receiving the start signal, the stock ticker application creates a new thread that opens the back channel to retrieve the stock quotes. The stock ticker application is now in the active state.
While in the active state, the stock ticker application continues to show the stock quotes. However, due to circumstances beyond the control of the application, the stock ticker application may no longer be able to retrieve updated stock quotes. Under these circumstances, the application may decide to continue displaying the most recent stock quotes that it has available. However, after a period of time, the application may still be unable to open the back channel. The application may therefore decide that the quotes it is displaying are too old to present and that it can no longer perform its service. The application may then choose to take itself out of the active state by calling the paused method on the application environment object to signal this change to the application manager. Moreover, the application may at this point or at a later time decide that it no longer has any chance of performing its service, so it decides it should terminate. The application does some clean-up, releasing resources that are no longer required by the application. The application then terminates and calls the destroyed method on the application environment object to signal the application manager that it has entered the destroyed state. The application manager then does the corresponding clean-up of this application.
The present invention may be implemented on any suitable computer system.
Computer system 1530 or, more specifically, CPUs 1532, may be arranged to support a virtual machine, as will be appreciated by those skilled in the art. The computer system 1502 includes any number of processors 1504 (also referred to as central processing units, or CPUs) that may be coupled to memory devices including primary storage device 1506 (typically a read only memory, or ROM) and primary storage device 1508 (typically a random access memory, or RAM). As is well known in the art, ROM acts to transfer data and instructions uni-directionally to the CPUs 1504, while RAM is used typically to transfer data and instructions in a bi-directional manner. Both the primary storage devices 1506, 1508 may include any suitable computer-readable media. The CPUs 1504 may generally include any number of processors.
A secondary storage medium 1510, which is typically a mass memory device, may also be coupled bi-directionally to CPUs 1504 and provides additional data storage capacity. The mass memory device 1510 is a computer-readable medium that may be used to store programs including computer code, data, and the like. Typically, the mass memory device 1510 is a storage medium such as a hard disk which is generally slower than primary storage devices 1506, 1508.
The CPUs 1504 may also be coupled to one or more input/output devices 1512 that may include, but are not limited to, devices such as video monitors, track balls, mice, keyboards, microphones, touch-sensitive displays, transducer card readers, magnetic or paper tape readers, tablets, styluses, voice or handwriting recognizers, or other well-known input devices such as, of course, other computers. Finally, the CPUs 1504 optionally may be coupled to a computer or telecommunications network, e.g., an internet network or an intranet network, using a network connection as shown generally at 1514. With such a network connection, it is contemplated that the CPUs 1504 might receive information from the network, or might output information to the network in the course of performing the above-described method steps. Such information, which is often represented as a sequence of instructions to be executed using the CPUs 1504, may be received from and outputted to the network, for example, in the form of a computer data signal embodied in a carrier wave.
Through the use of an application manager to load and manage execution of each application according to an application lifecycle, the execution of an application is standardized and memory resources are effectively conserved. The application lifecycle is implemented, in part, by controlling in a consistent manner the states that the application may enter. According to one embodiment, an interface defining appropriate methods for controlling the application lifecycle is provided for the application as well as the application manager. In this manner, the application and the application manager may communicate state changes, requests for state changes, requests that state changes be delayed or cancelled, as well as communicate other state information. Through the use of the present invention, an application may be run on different machines at different times, yet producing the same result in a predictable manner. Moreover, the present invention enables memory associated with an application to be released when it is determined that the resources are no longer required. Given the limited amount of memory resources in digital receivers and set-top boxes, the ability to manage memory resources in a digital television environment represents a significant improvement.
Although illustrative embodiments and applications of this invention are shown and described herein, many variations and modifications are possible which remain within the concept, scope, and spirit of the invention, and these variations would become clear to those of ordinary skill in the art after perusal of this application. For instance, the present invention is described as being implemented within the context of a digital television receiver. However, the present invention may be used in other contexts. Moreover, although the present invention is described as being implemented on a JAVA PLATFORM, it may also be implemented on a variety of platforms. Moreover, the above described process blocks are illustrative only. Therefore, the implementation of the application manager and application lifecycle may be performed using alternate process blocks as well as alternate data structures. Moreover, although both the application manager and the application are described as having separate interfaces, these interfaces may include public methods that are visible to all applications as well as the application manager. Accordingly, the present embodiments are to be considered as illustrative and not restrictive, and the invention is not to be limited to the details given herein, but may be modified within the scope and equivalents of the appended claims.
Calder, Bartley H., Ye, Tao, Courtney, Jonathan D., Rivas, Jesus David, Messer, Keith L.
Patent | Priority | Assignee | Title |
11758020, | Mar 14 2022 | UNITED SERVICES AUTOMOBILE ASSOCIATION USAA | Selective messaging for reducing server load |
7509627, | Feb 19 2008 | International Business Machines Corporation | Method for management of dynamically alterable lifecycles in structured classification domains |
7533165, | Dec 13 2002 | Canon Kabushiki Kaisha | Communication apparatus |
8767714, | Oct 29 2001 | The United States of America as represented by the Administrator of the National Aeronautics and Space Administration | Ad hoc selection of voice over internet streams |
8881162, | Feb 21 2006 | Samsung Electronics Co., Ltd. | Apparatus and method for managing resources in containment framework environment |
9098341, | Nov 24 2004 | AT&T MOBILITY II LLC | Service manager for adaptive load shedding |
Patent | Priority | Assignee | Title |
5283561, | Feb 24 1989 | MEDIATEK INC | Color television window for a video display unit |
5455950, | Jul 15 1991 | Bull S.A. | Universal device for coupling a computer bus to a specific link of a network and operating system therefor |
5572232, | Aug 06 1993 | Intel Corporation | Method and apparatus for displaying an image using subsystem interrogation |
5608662, | Jan 12 1995 | SOLIDUM SYSTEMS CORPORATION | Packet filter engine |
5727147, | Dec 08 1995 | Oracle America, Inc | System and method for resolving symbolic references to externally located program files |
5815718, | May 30 1996 | Oracle America, Inc | Method and system for loading classes in read-only memory |
5950008, | Dec 08 1995 | Oracle America, Inc | System and method for resolving symbolic references to externally located program files |
5966542, | May 30 1996 | Sun Microsystems, Inc. | Method and system for loading classes in read-only memory |
6085030, | May 02 1997 | RPX Corporation | Network component server |
6202208, | Sep 29 1998 | Nortel Networks Limited | Patching environment for modifying a Java virtual machine and method |
6223346, | May 30 1996 | Sun Microsystems, Inc. | Computer program product having preloaded software module |
6266716, | Jan 26 1998 | International Business Machines Corp | Method and system for controlling data acquisition over an information bus |
6279030, | Nov 12 1998 | International Business Machines Corporation | Dynamic JAVA™ class selection and download based on changeable attributes |
6289369, | Aug 25 1998 | International Business Machines Corporation | Affinity, locality, and load balancing in scheduling user program-level threads for execution by a computer system |
6339841, | Oct 19 1998 | International Business Machines Corporation | Class loading model |
6374286, | Apr 06 1998 | Rockwell Collins, Inc | Real time processor capable of concurrently running multiple independent JAVA machines |
6430564, | Mar 01 1999 | Qualcomm Incorporated | Java data manager for embedded device |
6430570, | Mar 01 1999 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Java application manager for embedded device |
6442565, | Aug 13 1999 | HIDDENMIND TECHNOLOGY, LLC | System and method for transmitting data content in a computer network |
6496871, | Jun 30 1998 | NEC Corporation | Distributed agent software system and method having enhanced process mobility and communication in a computer network |
6507946, | Jun 11 1999 | International Business Machines Corporation | Process and system for Java virtual method invocation |
6513155, | Dec 12 1997 | International Business Machines Corporation | Method and system for merging event-based data and sampled data into postprocessed trace output |
6519594, | Nov 14 1998 | Sony Corporation | Computer-implemented sharing of java classes for increased memory efficiency and communication method |
EP333617, | |||
EP524071, | |||
EP653742, | |||
EP844766, | |||
EP908821, | |||
GB2310335, | |||
WO9413107, | |||
WO9720413, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Dec 08 1999 | CALDER, BARTLEY H | Sun Microsystems, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 010473 | /0646 | |
Dec 08 1999 | YE, TAO | Sun Microsystems, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 010473 | /0646 | |
Dec 08 1999 | COURTNEY, JONATHAN D | Sun Microsystems, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 010473 | /0646 | |
Dec 08 1999 | MESSER, KEITH L | Sun Microsystems, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 010473 | /0646 | |
Dec 10 1999 | RIVAS, JESUS DAVID | Sun Microsystems, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 010473 | /0646 | |
Dec 16 1999 | Sun Microsystems, Inc. | (assignment on the face of the patent) | / | |||
Feb 12 2010 | ORACLE USA, INC | Oracle America, Inc | MERGER AND CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 037302 | /0843 | |
Feb 12 2010 | Sun Microsystems, Inc | Oracle America, Inc | MERGER AND CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 037302 | /0843 | |
Feb 12 2010 | Oracle America, Inc | Oracle America, Inc | MERGER AND CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 037302 | /0843 |
Date | Maintenance Fee Events |
Jan 14 2011 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jan 21 2015 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Jan 31 2019 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Aug 14 2010 | 4 years fee payment window open |
Feb 14 2011 | 6 months grace period start (w surcharge) |
Aug 14 2011 | patent expiry (for year 4) |
Aug 14 2013 | 2 years to revive unintentionally abandoned end. (for year 4) |
Aug 14 2014 | 8 years fee payment window open |
Feb 14 2015 | 6 months grace period start (w surcharge) |
Aug 14 2015 | patent expiry (for year 8) |
Aug 14 2017 | 2 years to revive unintentionally abandoned end. (for year 8) |
Aug 14 2018 | 12 years fee payment window open |
Feb 14 2019 | 6 months grace period start (w surcharge) |
Aug 14 2019 | patent expiry (for year 12) |
Aug 14 2021 | 2 years to revive unintentionally abandoned end. (for year 12) |