这是奇怪的撞击,有人能解释为什么它会出现。
尝试打开(通过制表符或滑动)viewpager中的第三个片段时出现崩溃(此时自动初始化前两个片段)
日志中没有太多信息,只是建议“验证”。
当android studio创建的apk无法复制时,只能存在于testfairy创建的apk中
STACK_TRACE=java.lang.VerifyError: .../CaseDetailUsersFragment
at ...CaseDetailViewPagerAdapter.getFragment(CaseDetailViewPagerAdapter.java:55)
at ...CaseDetailViewPagerAdapter.getItem(CaseDetailViewPagerAdapter.java:35)
at android.support.v13.app.FragmentPagerAdapter.instantiateItem(FragmentPagerAdapter.java:101)
at android.support.v4.view.ViewPager.addNewItem(ViewPager.java:836)
at android.support.v4.view.ViewPager.populate(ViewPager.java:1052)
at android.support.v4.view.ViewPager.setCurrentItemInternal(ViewPager.java:554)
at android.support.v4.view.ViewPager.setCurrentItemInternal(ViewPager.java:513)
at android.support.v4.view.ViewPager.setCurrentItem(ViewPager.java:494)
at ...CaseDetailViewPagerFragment.onTabSelected(CaseDetailViewPagerFragment.java:148)
at
...view.MaterialTab.onTouch(MaterialTab.java:191)
at android.view.View.dispatchTouchEvent(View.java:7772)
案例详细视图页面
public class CaseDetailViewPagerAdapter extends FragmentPagerAdapter{
/**
* class Adapter for Tabs in CaseDetail
*/
public class CaseDetailViewPagerAdapter extends FragmentPagerAdapter{
private final Context context;
private String caseId;
private int numItems;
public CaseDetailViewPagerAdapter(Context context, FragmentManager fm, String caseId, int numItems) {
super(fm);
this.context = context;
this.caseId = caseId;
this.numItems = numItems;
}
@Override
public Fragment getItem(int i) {
return getFragment(i);
}
@Override
public int getCount() {
return numItems;
}
/**
* @return instance of Fragment accordion to selected position
*/
private Fragment getFragment(int position) {
switch (position) {
case 0:
return CaseDetailLogFragment.newInstance(caseId);
case 1:
return CaseDetailChecklistFragment.newInstance(caseId);
case 2:
//55 line return CaseDetailUsersFragment.newInstance(caseId);
case 3:
return CaseDetailMapFragment.newInstance(caseId);
}
return null;
}
}
案例细节用户片段
public class CaseDetailUsersFragment extends Fragment {
public static final int USER_LOADER_ID = 3;
public static final int GROUP_LOADER_ID = 4;
static final String CASE_ID = "case_id";
String caseServerId;
public static CaseDetailUsersFragment newInstance(String caseId) {
CaseDetailUsersFragment usersFragment = new CaseDetailUsersFragment();
Bundle bundle = new Bundle();
bundle.putString(CASE_ID, caseId);
usersFragment.setArguments(bundle);
return usersFragment;
}
@Override
public void onServiceResult(long requestId, Intent requestIntent, int resultCode, Bundle resultData) {
super.onServiceResult(requestId, requestIntent, resultCode, resultData);
if (requestId == requestIdGetCaseUsersCommand && GetCaseUsersCommand.ACTION.equals(requestIntent.getAction())) {
requestIdGetCaseUsersCommand = BaseServiceHelper.DEFAULT_REQUEST_ID;
switch (resultCode) {
case Command.RESULT_SUCCESSFUL:
Logger.logD("onServiceResult finish refreshing");
Bundle b = new Bundle();
b.putString(CASE_ID, caseServerId);
getLoaderManager().restartLoader(USER_LOADER_ID, b, usersLoader);
showSwipeProgress(false);
break;
case Command.RESULT_FAILURE:
showSwipeProgress(false);
if (!NetworkHelper.isConnected(getActivity())) {
Toast.makeText(getActivity(), R.string.notification_error_no_connection, Toast.LENGTH_LONG).show();
} else if (resultData != null) {
ErrorInfo errorInfo = resultData.getParcelable(TransitionConstant.ERROR_INFO);
if (errorInfo != null) {
Toast.makeText(getActivity(), errorInfo.getErrorMessage(), Toast.LENGTH_LONG).show();
} else {
Toast.makeText(getActivity(), getString(R.string.failure_get_case_list_error_code, resultData.getInt(TransitionConstant.STATUS_ERROR_CODE)), Toast.LENGTH_LONG).show();
}
} else {
Toast.makeText(getActivity(), R.string.failure_get_case_list, Toast.LENGTH_LONG).show();
}
break;
default:
break;
}
} else if (requestId == requestIdGetCaseGroupsCommand && GetCaseGroupsCommand.ACTION.equals(requestIntent.getAction())) {
requestIdGetCaseGroupsCommand = BaseServiceHelper.DEFAULT_REQUEST_ID;
switch (resultCode) {
case Command.RESULT_SUCCESSFUL:
Logger.logD("onServiceResult finish refreshing groups");
Bundle b = new Bundle();
b.putString(CASE_ID, caseServerId);
getLoaderManager().restartLoader(GROUP_LOADER_ID, b, groupLoader);
break;
case Command.RESULT_FAILURE:
if (!NetworkHelper.isConnected(getActivity())) {
Toast.makeText(getActivity(), R.string.notification_error_no_connection, Toast.LENGTH_LONG).show();
} else if (resultData != null) {
ErrorInfo errorInfo = resultData.getParcelable(TransitionConstant.ERROR_INFO);
if (errorInfo != null) {
Toast.makeText(getActivity(), errorInfo.getErrorMessage(), Toast.LENGTH_LONG).show();
} else {
Toast.makeText(getActivity(), getString(R.string.failure_get_case_list_error_code, resultData.getInt(TransitionConstant.STATUS_ERROR_CODE)), Toast.LENGTH_LONG).show();
}
} else {
Toast.makeText(getActivity(), R.string.failure_get_case_list, Toast.LENGTH_LONG).show();
}
break;
default:
break;
}
}
}
compileSdkVersion 22
buildToolsVersion "22.0.1"
minSdkVersion 16
targetSdkVersion 22
修复了两个方法上的break onServiceResult()方法。
在testfairy日志中的警告中找到了w/dalvikvm?vfy:已拒绝lmy.package/myclass;.methodv
最佳答案
这个错误的原因需要在应用程序logcat中的dalwik警告中找到
例如:
W/Dalvikvm?vfy:已拒绝lmy.package/myclass;.methodv
在这种情况下,需要重构方法,因为您的方法太复杂。
更多详细答案请参见:
VerifyError - Verifier rejected class