Concurrency (computer Science) - Practice

Practice

Concurrent programming encompasses the programming languages and algorithms used to implement concurrent systems. Concurrent programming is usually considered to be more general than parallel programming because it can involve arbitrary and dynamic patterns of communication and interaction, whereas parallel systems generally have a predefined and well-structured communications pattern. The base goals of concurrent programming include correctness, performance and robustness. Concurrent systems such as Operating systems and Database management systems are generally designed to operate indefinitely, including automatic recovery from failure, and not terminate unexpectedly (see Concurrency control). Some concurrent systems implement a form of transparent concurrency, in which concurrent computational entities may compete for and share a single resource, but the complexities of this competition and sharing are shielded from the programmer.

Because they use shared resources, concurrent systems in general require the inclusion of some kind of arbiter somewhere in their implementation (often in the underlying hardware), to control access to those resources. The use of arbiters introduces the possibility of indeterminacy in concurrent computation which has major implications for practice including correctness and performance. For example arbitration introduces unbounded nondeterminism which raises issues with model checking because it causes explosion in the state space and can even cause models to have an infinite number of states.

Some concurrent programming models include coprocesses and deterministic concurrency. In these models, threads of control explicitly yield their timeslices, either to the system or to another process.

Read more about this topic:  Concurrency (computer Science)

Famous quotes containing the word practice:

    The practice of politics in the East may be defined by one word: dissimulation.
    Benjamin Disraeli (1804–1881)

    Communism to me is one-third practice and two-thirds explanation.
    Will Rogers (1879–1935)

    If I had my life over again I should form the habit of nightly composing myself to thoughts of death. I would practise, as it were, the remembrance of death. There is no other practice which so intensifies life. Death, when it approaches, ought not to take one by surprise. It should be part of the full expectancy of life. Without an ever- present sense of death life is insipid. You might as well live on the whites of eggs.
    Muriel Spark (b. 1918)