【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 适用于需要访问应用级资源的场景。在选择使用哪个类时,应根据具体的需求来决定。

相关推荐
杉氧16 小时前
深入理解 Compose 重组机制:快照系统如何驱动 UI 精准刷新?
android·架构·android jetpack
召钱熏16 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
杉氧17 小时前
深度解析:Jetpack Compose 核心架构与底层原理 —— 十年安卓老兵的“破茧重生”
android·架构·android jetpack
通玄17 小时前
Jetpack Compose 入门系列(七):ViewModel 与界面状态管理
android
落魄Android在线炒饭17 小时前
Android Framework 开发技巧:android.jar 生成与系统快速编译验证
android
如此风景18 小时前
Kotlin Flow操作符学习
android·kotlin
plainGeekDev19 小时前
GreenDAO → Room
android·java·kotlin
weiggle19 小时前
第八篇:ViewModel + Compose——生产级状态管理实践
android
恋猫de小郭1 天前
Amper 正式转正 Kotlin Toolchain ,Gradle 未来何去何从
android·前端·flutter
plainGeekDev1 天前
ButterKnife → ViewBinding
android·java·kotlin