AmbientTalk is an experimental object-oriented distributed programming language developed at the Software Languages Lab at the Vrije Universiteit Brussel, Belgium. The language is primarily targeted at writing programs deployed in mobile ad hoc networks.
AmbientTalk is a research platform to experiment with new language features or programming abstractions to facilitate the construction of software that has to run in highly volatile networks exhibiting intermittent connectivity and little infrastructure.
The language's concurrency features are founded on the actor model and have been largely influenced by the E programming language. The language's object-oriented features find their influence in languages like Smalltalk (i.e. block closures, keyworded messages) and Self (prototype-based programming, delegation). Finally, the language has a functional core, inspired by Scheme and Pico.
AmbientTalk's main differences with mainstream languages are that:
· It employs a purely event-driven concurrency framework, founded on actors.
· It abandons the RPC abstraction in favor of asynchronous, non-blocking message passing. Because the system automatically buffers such messages while the receiver of the message is disconnected, the programmer can abstract from temporary network failures by default.
· It has built-in programming language constructs for objects to discover one another in the local ad hoc network. Peer-to-peer service discovery is built into the language.
· It features a dynamic OO kernel language built upon the principles of prototype-based programming. The kernel language supports reflection using mirrors, which provide access to an extensive metaobject protocol, making the language extensible from within itself.
· The language syntax derives primarily from the 'curly brace' family of languages, but it mixes in the keyworded messaging syntax from Smalltalk as well. This, together with AmbientTalk's lightweight block syntax, enables you to easily build your own control structures.
· The current implementation of AmbientTalk embraces the JVM as a platform. It's easy for AmbientTalk programs to use Java libraries, and it's easy for Java objects to use AmbientTalk as an embedded scripting language. This interaction is safe: even when AmbientTalk objects are "exposed" to the JVM, JVM threads cannot violate the concurrency constraints of AmbientTalk's actor model.
AmbientTalk runs on J2SE, J2ME under the connected device configuration (CDC), and Android 2.1 Platform.
Like it? Share with your friends!
Supported operating systems:
Google Android 10.x, Google Android 2.1, Google Android 2.2, Google Android 2.3, Google Android 3.0, Google Android 3.1, Google Android 3.2, Google Android 4.0, Google Android 4.1, Google Android 4.2, Google Android 4.3, Google Android 4.4, Google Android 5.x, Google Android 6.x, Google Android 7.x, Google Android 8.x, Google Android 9.x, Java ME, Java Nokia 240x320, Java SE 240x320
Similar Software:
Learn Apache POI Word Learn Apache POI Word - Learn Apache POI Word provides a basic understanding of Apache POI library and its features. You will learn how to read, write, and manage MS-Word documents using Java programs. This app is designed for the readers working on Java and especially those who want to create, read, write, and modify Word files using Java
OpenWebGIS OpenWebGIS - OpenWebGIS is created for everyone who wishes to see and use a new free&open Geographic Information System(GIS). Please make your comments and suggestions. In this GIS you can use the extensive mathematical functionality to calculate and analyze your data
Learn Lucene Learn Lucene - Lucene is an open source java based search library. Lucene is very popular and fast search library used in java based application to add document search capability to any kind of application in a very simple and efficient way
learn XML-RPC learn XML-RPC - In Learn XML - RPC, you will learn what is XML-RPC and why and how to use it. This brief app will be extremely useful for all those who want to learn how to use XML-RPC to establish connections between computers across a network
z4mod z4mod is another lagfix for Samsung Galaxy S. This one is a bit different from existing lagfixes though:
- Differences from OCLF: Uses native EXT/JFS instead of loopback mounts. Loopback mounts in linux can be a bit flakey at times, especially when they're on RFS. So this is generally better
Learn Artificial Intelligence Learn Artificial Intelligence - This tutorial is prepared for the students at beginner level who aspire to learn Artificial Intelligence. This tutorial provides introductory knowledge on Artificial Intelligence. It would come to a great help if you are about to select Artificial Intelligence as a course subject
Learn JPA Learn JPA - Java Persistence API is a collection of classes and methods to persistently store the vast amounts of data into a database which is provided by the Oracle Corporation. This tutorial provides you the basic understanding of Persistence (storing the copy of database object into temporary memory), and we will learn the understanding of JAVA Persistence API (JPA)
jQuery Reference Complete reference of all jQuery objects and methods, along with examples
Learn Apache Ant Learn Apache Ant - Apache Ant is a Java based build tool from Apache Software Foundation. Apache Ant's build files are written in XML and they take advantage of being open standard, portable and easy to understand.This app should show you how to use Apache ANT to automate the build and deployment process in simple and easy steps
AmbientTalk Interpreter AmbientTalk Interpreter - AmbientTalk is an experimental object-oriented distributed programming language developed at the Software Languages Lab at the Vrije Universiteit Brussel, Belgium. The language is primarily targeted at writing programs deployed in mobile ad hoc networks
weScribble weScribble - Draw with your friends!
Draw with your enemies!
Draw with anyone who has an Android device... and a finger!
This is a demo version of the weScribble application for collaborative drawing.
You can draw with anyone on the same wireless network, with changes synchronizing in real time