Developing high quality distributed systems software is hard; developing high quality reusable distributed systems software is even harder. The principles, methods, and skills required to develop reusable software cannot be learned by generalities. Instead, developers must learn through experience how reusable software components and frameworks can be designed, implemented, optimized, validated, maintained, and enhanced by applying good development practices and patterns.
Designing applications for mobile devices presents unique challenges. User interface, mobile-specific technologies, and the importance of performance require special consideration. The Android SDK has its own interesting aspects to learn: the multi-touch model, accelerometer, important APIs will receive attention. Students will learn important development concepts applicable to any mobile device programming environment, as well as Android-specific APIs. CS 282 will provide an intensive focus on conceptual and practical aspects of designing, implementing, and debugging concurrent and networked software systems using Android middleware. Key topics covered in this course include:
* Developing, documenting, and testing applications using object-oriented frameworks associated with Android middleware.
* Reuse of patterns and software architectures
* Developing concurrent and networked software using Java.
Design and implementation based on patterns and frameworks are central themes to enable the construction of reusable, extensible, efficient, and maintainable networked system software. In addition, abstraction based on patterns and OO techniques (such as separation of interface from implementation) will be the central concepts and principles throughout the course. These concepts and principles will enable you to construct reusable, extensible, efficient, and maintainable networked system software.
Patterns will be taught so that you will have good role models for structuring their own designs, as well as to clearly articulate the tradeoffs of alternative methods for designing systems. OO techniques will be taught so that you will learn by example how to build highly decentralized networked system software architectures that decouple inter-dependencies between components.
We will construct networked system components and applications using popular programming tools available on modern operating systems, such as make, emacs, and SVN. You are expected to be familiar with Java and Linux.
Register to leave a review