|  |  | 
 
 
                  
                     | 
                           
                              | 
                                    
                                       | Classification: | C++ | Category: | Base |  
                                       | Created: | 07/25/2003 | Modified: | 10/16/2003 |  
                                       | Number: | FAQ-0907 |  
                                       | Platform: | Not Applicable |  |  Question:
 Why doesn't Symbian OS support writeable static data
 
 Answer:
 The main reason writeable static data (WSD) is not supported on Symbian OS, is that it comes at the cost of significant memory
                           wastage. Symbian OS runs in memory constrained devices, so Symbian have made the design decision not to support WSD.
 
 The main sources of memory wastage are discussed below:
 
 1. Requirement for multiple copies of DLLs in RAM
 All processes that use a DLL must set the same address for the DLL's static data, because the address is referenced by the
                           shared DLL code. If the required address is free when the process comes to use the DLL, then there is no problem. However
                           it is perfectly possible that the address might not be free, so the copy of the DLL in memory cannot be used.
 
 The workaround is to copy the DLL code and modify the copy to use a different address for static data. Symbian OS does not
                           consider this duplication acceptable.
 
 2. Inefficient use of RAM pages
 The amount of memory needed for writable static data by any DLL is likely to be much smaller (<0x100 bytes) than the smallest
                           possible RAM allocation (4K). The remaining memory is wasted. Since the memory is per-process-dll-static-data, the memory
                           wastage on the machine is:
 (4K-WSD bytes)*number-client-processes.
 |  
                     |  |  |