【Android】隐式调用Activity时匹配category需要注意的细节

category的匹配规则:

    1.Intent隐式调用Activity时,需要 Intent中的category 在 Activity中的某个Intent-filter的category 区间内。

    2.Intent隐式调用Activity时,会默认加上android.intent.category.DEFAULT。Manifest.xml中的Activity如果没有加上这个category,是匹配不到的。所以为了我们的Activity能够被隐式调用,一定要加上这个category。

    3.当我们通过隐式方式启动一个Activity的时候,可以做一下判断,看是否有Activity能够匹配我们的隐式Intent,如果不做判断,并且没有Activity能够匹配,会报运行时异常:NoActivity found to handle Intent。判断方法有两种:采用PackageManager的resolveActivity方法(返回Activity信息List)或Intent的resolveActivity(返回最佳匹配Activity信息)方法,如果它们找不到匹配的Activity就会返回null,我们通过判断返回值就可以规避上述错误了。(注意方法参数中的flag,需要 使用MATCH_DEFAULT_ONLY,这个标记位会匹配intent-filter中声明了的Activity。因为我们Intent隐式调用时会默认加上这个category,这样 就保持了匹配一致性。)

你可能感兴趣的:(Android)