The Shared Variable facility is roughly analogous to a Windows out-of-process server today.
When APL360 was first introduced in 1968, there were no built-in means by which a user could directly access data from outside of the APL system. Some of the timesharing vendors began offering an external file system at the time, however IBM's approach was to supply a more generic facility whereby an external process could be used by an APL program. Following APL.SV, the IBM VS APL and APL2 program products also supported shared variables, as well as the IBM 5100 line of computers.
Shared Variable Processors were available to allow APL access to the following:
In the early 1980s, I. P. Sharp Associates, which offered a rich and advanced APL, introduced Shared Variables in their product offering. Many of the Shared Variable Processors available for IBM products were also written for Sharp APL, notably TSIO (called PJAM), AP124, AP126, and AP127. Further, as I. P. Sharp also offered IPSANET which allowed in-house clients of SHARP APL to be connected to the network, a Network Shared Variable Processor, or NSVP, allowed programs from one mainframe site to access another. NSVP predates the widespread usage of the Internet by five years.
Shared Variables were one technique used by APL implementors and vendors to increase the richness of the APL language, doing so without touching the core implementation. With the advent of more powerful personal computing, the exodus of the APL user community to smaller computers was inevitable. APL was first available on 8008, 8080, and Z80 based hardware, later the original IBM PC, and today on the 32- and 64-bit Linux and Windows workstations. Although Dyalog APL included an implementation of shared variables for communication with the now-deprecated Microsoft Windows DDE, it is interesting to note that only IBM continued to use Shared Variables as a means to supply new features to their versions of the APL2 language for non-mainframe computers.
Nearly all other APL vendors chose to implement new functionality, such as access to Linux and Windows native features, graphical user interface, presentation graphics, database management system interfaces, and so on, more directly in their respective versions of the APL language. In modern non-IBM APL implementations, the Shared Variable interface has been largely supplanted by COM, ActiveX, and .Net.
US Patent Issued to International Business Machines on Sept. 7 for "Management of Cluster-Wide Resources with Shared Variables" (German Inventor)
Sep 08, 2010; ALEXANDRIA, Va., Sept. 9 -- United States Patent no. 7,792,916, issued on Sept. 7, was assigned to International Business...
US Patent Issued to Intel on Jan. 11 for "Protecting Shared Variables in a Software Transactional Memory System" (California Inventors)
Jan 14, 2011; ALEXANDRIA, Va., Jan. 14 -- United States Patent no. 7,870,545, issued on Jan. 11, was assigned to Intel Corp. (Santa Clara,...
US Patent Issued to International Business Machines on July 23 for "Updating Shared Variables Atomically" (Texas Inventor)
Jul 23, 2013; ALEXANDRIA, Va., July 23 -- United States Patent no. 8,495,311, issued on July 23, was assigned to International Business...