关于Fragment的无参构造方法

本文探讨了Android中Fragment与Activity的生命周期,分析了二者的关系及区别。Fragment不是Activity的扩展,但可以像Activity一样被扩展,并通过子类改变其行为。文章详细介绍了如何通过Bundle传递参数给Fragment,以及在Activity重建时Fragment如何重建。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

看文章时Activity 与 Fragment 生命周期探讨

Fragment是直接从Object继承的,而Activity是Context的子类。
因此我们可以得出结论:Fragment不是Activity的扩展。
但是与Activity一样,在我们使用Fragment的时候我们总会扩展Fragment(或者是她的子类),
并可以通过子类更改她的行为。
使用Fragment时,必要构建一个无参构造函数,系统会默认带。
但一但写有参构造函数,就必要构建无参构造函数。一般来说我们传参数给Fragment,
会通过bundle,而不会用构造方法传,代码如下:
public static MyFragment newInstance(int index){  
  MyFragment mf = new MyFragment();  
  Bundle args = new Bundle();  
  args.putInt("index",index);  
  mf.setArguments(args);  
  return mf;  
}

Activity重建,Fragment也会重建,通过onCreate( Bundle savedInstanceState)传入之前保存的数据savedInstanceState,通过反射无参构造实例化一个新的Fragment,如果Fragment的构造函数不是无参的,就无法实例化Fragment,会导致程序崩溃。

如果MainViewModel有一个有构造方法,你需要实现一个ViewModelProvider.Factory的接口,以便正确地创建实例。具体步骤如下: 1. 创建一个实现ViewModelProvider.Factory接口的类,例如: ```kotlin class MainViewModelFactory(private val application: Application, private val param: String) : ViewModelProvider.Factory { override fun <T : ViewModel?> create(modelClass: Class<T>): T { if (modelClass.isAssignableFrom(MainViewModel::class.java)) { return MainViewModel(application, param) as T } throw IllegalArgumentException("Unknown ViewModel class") } } ``` 在上述代码中,我们创建了一个MainViewModelFactory类,它有一个构造函数,传入了Application和一个字符串类型的数。在create方法中,我们检查传入的modelClass是否是MainViewModel类的子类,如果是,则返回通过有构造函数创建的MainViewModel实例,否则抛出IllegalArgumentException异常。 2. 在Activity或Fragment中使用MainViewModelFactory创建MainViewModel实例,例如: ```kotlin val factory = MainViewModelFactory(application, "Hello World") val viewModel = ViewModelProviders.of(this, factory).get(MainViewModel::class.java) ``` 在上述代码中,我们先创建了一个MainViewModelFactory实例,传入了Application和一个字符串类型的数。然后,我们使用ViewModelProviders提供的of方法并传入factory数,获取MainViewModel实例。 这样,你就成功地使用有构造函数创建了MainViewModel实例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值