Polymorphic types for constructing concurrent objects and layered communication protocols
dc.contributor.author | Lavender, R. Gregory | en |
dc.contributor.committeechair | Kafura, Dennis G. | en |
dc.contributor.committeemember | Nance, Richard E. | en |
dc.contributor.committeemember | Lee, John A.N. | en |
dc.contributor.committeemember | Arthur, James D. | en |
dc.contributor.committeemember | Abrams, Marc | en |
dc.contributor.committeemember | Midkiff, Scott F. | en |
dc.contributor.committeemember | Cannata, Philip E. | en |
dc.contributor.department | Computer Science | en |
dc.date.accessioned | 2014-03-14T21:14:22Z | en |
dc.date.adate | 2008-06-06 | en |
dc.date.available | 2014-03-14T21:14:22Z | en |
dc.date.issued | 1993-05-05 | en |
dc.date.rdate | 2008-06-06 | en |
dc.date.sdate | 2008-06-06 | en |
dc.description.abstract | Polymorphic type abstractions are proposed for constructing concurrent objects and layered peer-to-peer communication protocols, both of which exhibit inherently asynchronous behavior. The type abstractions are shown to be both expressive and efficient in the context of a statically typed object-oriented language. Where appropriate, the utility of the type abstractions is illustrated by demonstrating their usefulness in concurrent programming using the Actor model. The results of this work have direct applicability to problems in concurrent programming, distributed systems, and communication protocol architectures. An extensible, polymorphic type abstraction for structuring concurrent method execution in a strongly typed object-oriented language is introduced. The type abstraction is called a <i>polymorphic lambda type</i>. A lambda type is an abstraction for a procedure that is based in part on λ-abstraction in the λ-calculus. The lambda type is a key component of a concurrent object model that allows methods defined in a class to be instantiated as <i>lambda objects</i>. Lambda objects are used to represent some aspect of behavior and they represent a first-class execution environment. The first-class nature of lambda objects facilitates the construction of more powerful computational abstractions, primarily those requiring 'asynchronous interaction and concurrent execution. Through a series of refinements, lambda objects are shown to be as expressive as traditional procedures with little extra cost for call setup and invocation. Concurrent objects require synchronization control. A type abstraction called a <i>behavior set</i> is introduced for specifying synchronization constraints in a strongly typed concurrent object-oriented language with Actor-style concurrency semantics. The behavior set abstraction offers a solution to structuring synchronization control that coexists with an inheritance mechanism, thereby avoiding the inheritance anomaly. | en |
dc.description.degree | Ph. D. | en |
dc.format.extent | xiii, 205 leaves | en |
dc.format.medium | BTD | en |
dc.format.mimetype | application/pdf | en |
dc.identifier.other | etd-06062008-170911 | en |
dc.identifier.sourceurl | http://scholar.lib.vt.edu/theses/available/etd-06062008-170911/ | en |
dc.identifier.uri | http://hdl.handle.net/10919/38440 | en |
dc.language.iso | en | en |
dc.publisher | Virginia Tech | en |
dc.relation.haspart | LD5655.V856_1993.L383.pdf | en |
dc.relation.isformatof | OCLC# 29179279 | en |
dc.rights | In Copyright | en |
dc.rights.uri | http://rightsstatements.org/vocab/InC/1.0/ | en |
dc.subject.lcc | LD5655.V856 1993.L383 | en |
dc.subject.lcsh | Communications software | en |
dc.subject.lcsh | Object-oriented programming (Computer science) | en |
dc.title | Polymorphic types for constructing concurrent objects and layered communication protocols | en |
dc.type | Dissertation | en |
dc.type.dcmitype | Text | en |
thesis.degree.discipline | Computer Science | en |
thesis.degree.grantor | Virginia Polytechnic Institute and State University | en |
thesis.degree.level | doctoral | en |
thesis.degree.name | Ph. D. | en |
Files
Original bundle
1 - 1 of 1