原文地址:https://android.jlelse.eu/android-architecture-components-viewmodel-e74faddf5b94
ViewModel最重要的作用就是为UI提供和管理数据。
介绍
我猜想你肯定有一些Activity,也许你还有一些用来存储和提供数据给UI的类,比如说MVP模式中的Presenter,或者是MVVM中的ViewModel,很不幸的,用户可以旋转他的手机。
接下来会发生什么呢,你的Activity会被重新创建,还有你的UI数据的持有者,这意味着什么呢?
- 你需要将数据传递到重新创建的Activity中,否则你就需要再次恢复他们
- 必须警惕内存泄漏的问题,因为数据持有者的生命周期比Activity的生命周期长。
怎么解决这些问题呢,我们来认识一下VieModel。
ViewModel
ViewModel存储数据并且提供给UI,并且他是生命周期可感知的,看一下下面的图:
[图片上传失败...(image-aa886-1513051151124)]
ViewModel能够保证在配置更改的时候仍然保证数据和ViewModel对象都不会更改。
- 你不用去担心数据持有者的生命周期,ViewModel将由工厂自动创建,不需要自己处理创建和销毁。
- 数据始终会更新,电话旋转之后将会获得跟之前一样的数据,所以你不需要将数据传递到新的活动,或者再次调用数据库。
- 如果你要进行API调用,同时旋转了手机,结果将在重新创建Activity之前交付,数据将会被保存在ViewModel中,在Activity被重新创建之后会立即获取到数据。
如何使用ViewModel
ViewModel使用起来是非常简单的,让我们看一下示例:
public class UsersViewModel extends ViewModel {
private List<User> userList;
public List<User> getUserList() {
if (userList == null) {
usersList = loadUsers();
}
return userList;
}
private List<User> loadUsers() {
// do something to load users
}
}
这个例子中,有一个用户列表,使用ViewModel的时候,我们只用创建一个类集成ViewModel就行了,下面是完整的Activity的代码
public class UsersActivity extends AppCompatActivity{
@Override
protected void onCreate(final Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
UserViewModel usersViewModel =
ViewModelProviders.of(this).get(UsersViewModel.class);
showUsers(usersViewModel.getUserList());
}
}
使用ViewModelProviders.of()方法来回去ViewModel,这是ViewModel的工厂,我们不需要担心ViewModel的生命周期,获取到ViewModel对象之后,我们使用usersViewModel.getUserList()方法获取数据。
ViewModel和onSaveInstanceState()
通常情况下当配置更改时我们都是使用onSaveInstanceState来保存数据的,ViewModel并不会替代onSaveInstanceState()
ViewModel仅存储用于方向更改而重新创建的Activity,而onSaveInstanceState可以存储因系统终止的Activity的一些数据,比如说系统为了释放内存而杀死Activity。那么同时有两个的目的是什么呢?我们可以只使用onSaveInstanceState(),但是他有很多缺点:
- 在onSaveInstanceState中我们只能存储一少部分的数据
- data需要被序列化,所以不容易设置和恢复数据
那么什么时候我们要使用onSaveInstanceState()?
- 使用ViewModel来为UI存储实际的数据
- 使用onSaveInstanceState来存储因被系统杀死所需的数据。
网友评论