【Android】ViewModel和AndroidViewModel区别

在 Android 开发中,AndroidViewModelViewModel 都是 ViewModel 架构组件的一部分,用于在界面(如 ActivityFragment)和数据之间进行分离,以保持数据在配置更改(如屏幕旋转)时的持久性。不过,它们之间存在一些关键区别。

继承关系与构造函数

  • ViewModelViewModel 是一个抽象类,位于 androidx.lifecycle 包中。它是所有 ViewModel 类的基类,构造函数较为简单,不包含任何特定的 Android 上下文依赖。示例如下:
java 复制代码
import androidx.lifecycle.ViewModel; 
public class MyViewModel extends ViewModel { 
// 构造函数无特殊要求 
    public MyViewModel() { 
    // 初始化操作 
    } 
}
  • AndroidViewModelAndroidViewModel 继承自 ViewModel,并且在构造函数中接收 Application 上下文。这意味着它可以访问应用级别的资源,例如 Application 类的实例。示例如下:
js 复制代码
import android.app.Application; 
import androidx.lifecycle.AndroidViewModel; 
public class MyAndroidViewModel extends AndroidViewModel { 
    public MyAndroidViewModel(Application application) { 
    super(application); 
    // 可以使用 application 实例进行操作 
    } 
}
-   **ViewModel**:当 `ViewModel` 不需要访问 Android 上下文或只需要一些与上下文无关的数据和逻辑时,推荐使用 `ViewModel`。例如,处理简单的业务逻辑、数据转换等。

上下文的使用

  • ViewModel :由于 ViewModel 不持有任何 Android 上下文,所以它不适合直接访问 Android 特定的资源,如 ContextSharedPreferences 等。如果需要在 ViewModel 中执行与上下文相关的操作,应该通过依赖注入的方式将所需的资源传递给 ViewModel
  • AndroidViewModelAndroidViewModel 持有 Application 上下文,这使得它可以安全地访问应用级别的资源,例如 Application 类的实例、SharedPreferences 等。不过,需要注意的是,不应该在 AndroidViewModel 中持有 ActivityFragmentView 的引用,因为这可能会导致内存泄漏。

使用场景

  • ViewModel :当 ViewModel 不需要访问 Android 上下文或只需要一些与上下文无关的数据和逻辑时,推荐使用 ViewModel。例如,处理简单的业务逻辑、数据转换等。
java 复制代码
import androidx.lifecycle.LiveData; 
import androidx.lifecycle.MutableLiveData; import androidx.lifecycle.ViewModel; 
public class CounterViewModel extends ViewModel { 
    private MutableLiveData<Integer> count = new MutableLiveData<>(0); 
    public LiveData<Integer> getCount() { 
        return count; 
    } 
    public void increment() { 
        count.setValue(count.getValue() + 1); 
    } 
}
  • AndroidViewModel :当 ViewModel 需要访问应用级别的资源时,应该使用 AndroidViewModel。例如,访问 SharedPreferences、数据库等。
typescript 复制代码
import android.app.Application; 
import androidx.lifecycle.AndroidViewModel; 
import androidx.lifecycle.LiveData; 
import androidx.lifecycle.MutableLiveData; 
import android.content.SharedPreferences; 
public class SettingsViewModel extends AndroidViewModel { 
    private SharedPreferences sharedPreferences; 
    private MutableLiveData<String> theme = new MutableLiveData<>(); 
    public SettingsViewModel(Application application) { 
    super(application); 
    sharedPreferences = application.getSharedPreferences("settings", 0); theme.setValue(sharedPreferences.getString("theme", "light")); } 
    
    public LiveData<String> getTheme() { 
        return theme; 
    } 
    
    public void setTheme(String theme) { 
        this.theme.setValue(theme)
        sharedPreferences.edit().putString("theme", theme).apply(); 
    } 
}

综上所述,ViewModel 适用于不需要 Android 上下文的场景,而 AndroidViewModel 适用于需要访问应用级资源的场景。在选择使用哪个类时,应根据具体的需求来决定。

相关推荐
瘦瘦的追梦洋1 小时前
Android Audio音量设置
android·audioframework
_一条咸鱼_1 小时前
Android Studio 常见问题解决方案
android
_一条咸鱼_2 小时前
Android Compose 框架的列表与集合模块之列表项动画深入剖析(四十七)
android
行墨2 小时前
Kotlin语言的run内置函数
android
顾林海2 小时前
Jetpack Room 使用与原理解析
android·android jetpack
MuYe2 小时前
Android Hook - 动态链接器命名空间机制
android·操作系统
冰糖葫芦三剑客3 小时前
Android 常用工具类记录
android
威哥爱编程4 小时前
谷歌Android闭源与鸿蒙崛起:一场关于技术主权的生态博弈
android·harmonyos
小鱼人爱编程5 小时前
Flutter 打包APK的几种方式
android·前端·后端
sunly_6 小时前
Flutter:切换账号功能记录
android·java·flutter