# android-architecture
**Repository Path**: ouyangpengdev/android-architecture
## Basic Information
- **Project Name**: android-architecture
- **Description**: A collection of samples to discuss and showcase different architectural tools and patterns for Android apps.
- **Primary Language**: Unknown
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2021-03-23
- **Last Updated**: 2021-03-23
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
#Android官方MVP架构项目解析
两篇简书上的说明文章
>http://www.jianshu.com/p/389c9ae1a82c
>http://www.jianshu.com/p/618750ed10a3
# Android Architecture Blueprints [beta]
[](https://gitter.im/googlesamples/android-architecture?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
The Android framework offers a lot of flexibility when it comes to defining how
to organize and architect an Android app. This freedom, whilst very valuable, can also result in apps
with large classes, inconsistent naming and architectures (or lack of) that can
make testing, maintaining and extending difficult.
Android Architecture Blueprints is meant to demonstrate possible ways to help
with these common problems. In this project we offer the same application
implemented using different architectural concepts and tools.
You can use these samples as a reference or as a starting point for creating
your own apps. The focus here is on code structure, architecture, testing and
maintainability. However, bear in mind that there are many ways to build apps
with these architectures and tools, depending on your priorities, so these
shouldn't be considered canonical examples. The UI is deliberately kept simple.
### What does beta mean?
We're still making decisions that could affect all samples so we're keeping the
initial number of variants low before the stable release.
## Samples
All projects are released in their own branch. Check each project's README for
more information.
* [todo-mvp/](https://github.com/googlesamples/android-architecture/tree/todo-mvp/) - Basic Model-View-Presenter architecture.
* [todo-mvp-loaders/](https://github.com/googlesamples/android-architecture/tree/todo-mvp-loaders/) - Based on todo-mvp, fetches data using Loaders.
* [todo-mvp-databinding/](https://github.com/googlesamples/android-architecture/tree/todo-databinding/) - Based on todo-mvp, uses the Data Binding Library.
In progress:
* [dev-todo-mvp-contentproviders/](https://github.com/googlesamples/android-architecture/tree/dev-todo-mvp-contentproviders/) - Based on todo-mvp-loaders, uses Content Providers
* [dev-todo-mvp-clean/](https://github.com/googlesamples/android-architecture/tree/dev-todo-mvp-clean/) - Based on todo-mvp, uses concepts from Clean Architecture.
* [dev-todo-mvp-dagger/](https://github.com/googlesamples/android-architecture/tree/dev-todo-mvp-dagger/) - Based on todo-mvp, uses Dagger2 for Dependency Injection
Also, see ["New sample" issues](https://github.com/googlesamples/android-architecture/issues?q=is%3Aissue+is%3Aopen+label%3A%22New+sample%22) for planned samples.
## Why a to-do application?
The aim of the app is to be simple enough that it's understood quickly, but
complex enough to showcase difficult design decisions and testing scenarios.
Check out the [app's specification](https://github.com/googlesamples/android-architecture/wiki/To-do-app-specification).
Also, a similar project exists to compare JavaScript frameworks, called [TodoMVC](https://github.com/tastejs/todomvc).
## Which sample should I choose for my app?
That's for you to decide: each sample has a README where you'll find metrics
and subjective assessments. Your mileage may vary depending on the size of the
app, the size and experience of your team, the amount of maintenance that you
foresee, whether you need a tablet layout or support multiple platforms, how
compact you like your codebase, etc.
## Who is behind this project?
This project is **built by the community** and curated by Google and core maintainers.
### External contributors
[David González](http://github.com/malmstein) - Core developer (Content Providers sample)
[Karumi](http://github.com/Karumi) - Developers (MVP Clean architecture sample)
[Erik Hellman](https://github.com/ErikHellman) - Developer (MVP RxJava sample)
### Googlers
[Jose Alcérreca](http://github.com/JoseAlcerreca) - Lead/Core developer
[Natalie Masse](http://github.com/freewheelnat) - Core developer
[Stephan Linzner](http://github.com/slinzner) - Core developer
[Mustafa Kurtuldu](https://github.com/mustafa-x) - UX/design
Want to be part of it? Read [how to become a contributor](https://github.com/googlesamples/android-architecture/blob/master/CONTRIBUTING.md) and the [contributor's guide](https://github.com/googlesamples/android-architecture/wiki/Contributions)