The present disclosure related to a mobile device, more particularly, to a mobile device with a shared data structure.
An operator of a mobile device (for example, a cell phone or a head mounted display) usually launches a system development kit (SDK) for the developers to create their own applications compatible with the mobile device. In these applications, some software assets are similar or substantially the same.
The first known method is building the same software assets into individual applications before these applications are downloaded or updated. In detail, when an application or an updated version of an application is released, all related software assets are already built into the application or the updated version of the application. Then the application can be launched in an application store platform for users to download or update. Different applications using the same software assets have the same software assets built in (for example, a virtual reality tree, car, etc.), causing a large size of each application.
The second known method is loading software assets into a memory of the mobile device repeatedly for different applications. In detail, when two different applications need the same software asset in the mobile device, it will load the same software asset to the memory twice. That is, the memory of the mobile device will have N software assets for N different applications, wherein the N software assets are substantially the same.
Both the first and second known methods cause large data transmission and memory space usage of the hard disk. Therefore, the mobile device may spend a lot of time for data transmission, the operating system performance may go down because of too many data accesses, and network bandwidth of the network provider may always be occupied.
An embodiment discloses a mobile device. A mobile device includes a shared memory. The shared memory preloads a plurality of objects from a library before an application needs an object within the plurality of objects. The shared memory is a volatile memory. When an application needs the object within the plurality of objects, the application accesses the object prestored in the shared memory.
Another embodiment discloses a method for data sharing. The method comprises preloading a plurality of objects from a library to a shared memory of the mobile device before an application needs an object within the plurality of objects, and providing the object prestored in the shared memory to the application when the application needs the object. The shared memory is a volatile memory.
These and other objectives of the present invention will no doubt become obvious to those of ordinary skill in the art after reading the following detailed description of the preferred embodiment that is illustrated in the various figures and drawings.
The library 104 can stored in a volatile memory or a non-volatile memory. For example, the non-volatile memory can be a read-only memory (ROM), a flash memory, a hard disk, a disc or a tape. The shared memory 106 is a volatile memory, for example, a random-access memory (RAM), wherein the RAM can be a dynamic random-access memory (DRAM) or a static random-access memory (SRAM). In contrast to the non-volatile memory, the volatile memory is computer memory that requires power to maintain the stored information, that is, the volatile memory retains its contents while powered on but may quickly lost its stored data when the power is interrupted.
In this embodiment, the number of the applications 108, 110 is two. However, the number of the applications of the present disclosure is not limited thereto. The plurality of objects 112 can include an avatar and virtual objects, for example, a group of a virtual tree, a virtual volleyball, a virtual house and a virtual bed. The plurality of objects 112 can be used in an augmented reality (AR) scene, a virtual reality (VR) scene, a mixed reality (MR) scene or the like. The object 114 can be the virtual tree. The remote storage device 200 can be a cloud computing server, an edge computing server, a local server, a personal computer, a mobile device, a universal serial bus (USB) hard disk, or a USB flash, etc.
Step S202: loading a plurality of objects 112 to the library 104 from a remote storage device 200;
Step S204: performing an identity check on the plurality of objects 112 downloaded to the library 104 from the remote storage device 200 successful; if so, go to Step S208; else go to Step S206;
Step S206: dropping the plurality of objects 112.
Step S208: preloading the plurality of objects 112 from the library 104 to the shared memory 106 before the applications 108, 110 requiring for any object within the plurality of objects 112;
Step S210: running the applications 108, 110 on the operating system 102; and
Step S212: the applications 108, 110 accessing an object 114 preloaded in the shared memory 106 within the plurality of objects 112.
The method is not limited to the above sequence, for instance, Steps S210 may be performed before Step S202. Further, S202, S204, S206 and S210 can be omitted or modified according to actual needs.
In Step S208, the plurality of objects 112 is preloaded before the applications 108, 110 requiring for any object within the plurality of objects 112. For example, the shared memory 106 preloads the plurality of objects 112 when the mobile device 100 is rebooted. For another example, the shared memory 106 preloads the plurality of objects 112 when an application, run before the applications 108, 110, requires for any object within the plurality of objects 112.
Obviously, Step S208 is not disclosed by the first and second known method described in the prior art. In Detail, in the first known method, since the plurality of objects may be installed in the individual applications initially, there is no need for the individual applications to access any object within the plurality of objects from the library. Neither, in the second known method, the applications may have to load the object and its copies from the library multiple times because of the lack of the shared memory.
In Step S212, the applications 108, 110 access the object 114 preloaded in the shared memory 106 within the plurality of objects 112. The object 114 can be accessed by the applications 108, 110 from the shared memory 106 simultaneously. Therefore, it is possible that the access time for the applications 108, 110 completely accessing the object 114 can be reduced.
In an embodiment, the remote storage device 200 can periodically update the library 104 with new objects and renewed objects and fix issues in the library 104.
In an embodiment, a library can be disposed in a remote storage device, rather than a mobile device.
In short, the present disclosure provides a shared memory. The shared memory preloads the plurality of objects before the applications need them. Then, when the object is in need, the shared memory provides multiple and simultaneous access rights for different applications. The applications can directly access the object preloaded in the shared memory, that is, the shared memory does not have to access the object from the library again. Therefore, it is possible that the data transmission amount and the memory space usage can be reduced, the transmission time can be saved and the network bandwidth of the network provider can be free from occupied, especially when the object is a basic object, such as an avatar or a virtual object, and used in most of the application.
Those skilled in the art will readily observe that numerous modifications and alterations of the device and method may be made while retaining the teachings of the invention. Accordingly, the above disclosure should be construed as limited only by the metes and bounds of the appended claims.