Concurrent Computing - Coordinating Access To Resources

Coordinating Access To Resources

One of the major issues in concurrent computing is preventing concurrent processes from interfering with each other. For example, consider the following algorithm for making withdrawals from a checking account represented by the shared resource balance:

1 bool withdraw( int withdrawal ) 2 { 3 if ( balance >= withdrawal ) 4 { 5 balance -= withdrawal; 6 return true; 7 } 8 return false; 9 }

Suppose balance=500, and two concurrent threads make the calls withdraw(300) and withdraw(350). If line 3 in both operations executes before line 5 both operations will find that balance > withdrawal evaluates to true, and execution will proceed to subtracting the withdrawal amount. However, since both processes perform their withdrawals, the total amount withdrawn will end up being more than the original balance. These sorts of problems with shared resources require the use of concurrency control, or non-blocking algorithms.

Because concurrent systems rely on the use of shared resources (including communication media), concurrent computing in general requires the use of some form of arbiter somewhere in the implementation to mediate access to these resources.

Unfortunately, while many solutions exist to the problem of a conflict over one resource, many of those "solutions" have their own concurrency problems such as deadlock when more than one resource is involved.

Read more about this topic:  Concurrent Computing

Famous quotes containing the words access and/or resources:

    Make thick my blood,
    Stop up th’ access and passage to remorse,
    That no compunctious visitings of nature
    Shake my fell purpose.
    William Shakespeare (1564–1616)

    Parenting, as an unpaid occupation outside the world of public power, entails lower status, less power, and less control of resources than paid work.
    Nancy Chodorow, U.S. professor, and sociologist. The Reproduction of Mothering Psychoanalysis and the Sociology of Gender, ch. 2 (1978)