当 运行 来自 Google Play 但不是来自 Android Studio 时出现 NullPointerException
NullPointerException when running from Google Play but not from Android Studio
我遇到了一个大问题,我不知道发生了什么,我已经将一个应用程序上传到 Play 商店,因为当我 运行 它在模拟器上,甚至在我的真实设备上时,它是崩溃了,但现在当我从 Google 下载它时,播放它说:
java.lang.NullPointerException:
at com..onBindViewHolder (ChooseCard.java)
or .onCreateViewHolder (ChooseCard.java)
at com..onBindViewHolder (ChooseCard.java)
or .onCreateViewHolder (ChooseCard.java)
at com.firebase.ui.database.FirebaseRecyclerAdapter.getItemCount (FirebaseRecyclerAdapter.java)
or .onBindViewHolder (FirebaseRecyclerAdapter.java)
or .onChildChanged (FirebaseRecyclerAdapter.java)
or .onError (FirebaseRecyclerAdapter.java)
at com.yarolegovich.discretescrollview.InfiniteScrollAdapter.access0 (InfiniteScrollAdapter.java)
or .getItemCount (InfiniteScrollAdapter.java)
or .getItemViewType (InfiniteScrollAdapter.java)
or .onAttachedToRecyclerView (InfiniteScrollAdapter.java)
or .onBindViewHolder (InfiniteScrollAdapter.java)
or .onCreateViewHolder (InfiniteScrollAdapter.java)
or .wrap (InfiniteScrollAdapter.java)
这个问题已经好几天了,我找不到,你能帮帮我吗?
这是我的 build.gradle
实现
implementation fileTree(include: ['*.jar'], dir: 'libs')
implementation 'com.android.support:appcompat-v7:27.1.1'
implementation 'com.android.support.constraint:constraint-layout:1.1.0'
implementation 'com.android.support:design:27.1.1'
implementation 'com.intuit.sdp:sdp-android:1.0.4'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.1'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
implementation 'com.android.support:cardview-v7:27.1.1'
implementation 'com.google.firebase:firebase-core:15.0.0'
implementation 'com.google.firebase:firebase-auth:15.0.0'
implementation 'com.google.android.gms:play-services-auth:15.0.0'
implementation 'com.google.firebase:firebase-database:15.0.0'
implementation 'com.anjlab.android.iab.v3:library:1.0.44'
implementation 'com.firebaseui:firebase-ui-database:3.3.1'
implementation 'com.onesignal:OneSignal:3.7.1'
implementation 'com.yarolegovich:discrete-scrollview:1.3.2'
implementation 'com.pranavpandey.android:dynamic-toasts:0.9.0'
implementation 'pl.droidsonroids.gif:android-gif-drawable:1.2.11'
implementation 'com.google.android.gms:play-services-analytics:15.0.0'
.....
dependencies {
classpath 'com.android.tools.build:gradle:3.1.2'
classpath 'com.google.gms:google-services:3.2.1'
编辑
我已经在 Google Play 上更新了我的应用程序但没有任何反应,仍然在相同的 Activity
上崩溃,我现在知道如何调试它,问题是我下载时来自 Google Play 的应用程序,在模拟器上(即使在新的模拟器设备上也不会崩溃)和我的真实设备上。
正如@Marcos Vascondelos所说,我做了构建>生成签名APK>获取应用程序-release.apk将它安装在我的设备上,问题是我无法登录它正在使用这种方法:
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
// Result returned from launching the Intent from GoogleSignInApi.getSignInIntent(...);
if (requestCode == RC_SIGN_IN) {
Task<GoogleSignInAccount> task = GoogleSignIn.getSignedInAccountFromIntent(data);
try {
// Google Sign In was successful, authenticate with Firebase
GoogleSignInAccount account = task.getResult(ApiException.class);
firebaseAuthWithGoogle(account);
} catch (ApiException e) {
// Google Sign In failed, update UI appropriately
Log.w(TAG, "Google sign in failed", e.getCause());
Toast with e.getCause is null
}
}
}
如果你想看看我如何登录才能不在这个问题上添加更多代码,我会在这个 GitHubGist
我读到它可能是 SHA-1 的问题,但我不知道为什么在模拟器上没问题,设备没问题,Google播放没问题,但如果我安装 . apk直接说null.
上次编辑
我看到问题不在 Firebase
调用上,而是在填充列表上,我的意思是产品被正确捕获,但是当我尝试放入列表时它崩溃了
我的 FirebaseRecyclerOptions
适配器看起来像
final FirebaseRecyclerOptions< CardPOJO > options =
new FirebaseRecyclerOptions.Builder< CardPOJO >()
.setQuery(products_ref, CardPOJO.class)
.build();
adapter = new FirebaseRecyclerAdapter< CardPOJO, CardHolder>(options) {
@Override
public CardHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//inflate the single recycler view layout(item)
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.card_product, parent, false);
final CardHolder cardViewHolder = new CardHolder(view);
return cardViewHolder;
}
@Override
public void onDataChanged() {
super.onDataChanged();
if(progressDialog!=null)progressDialog.dismiss();initViews();
}
@Override
protected void onBindViewHolder(final CardHolder holder, int position, final CardPOJO model) {
holder.itemView.setSelected(0== position); ////where you are in the list
holder.getLayoutPosition();
switch (model.getState()){
case "free":
holder.card_image.setImageResource();
break;
case "not_free":
if(userOwnsProduct(model.getProduct_id())){
holder.card_image.setImageResource();
}
else{
holder.card_image.setImageResource();
}
break;
default:
break;
}
holder.view.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(model.getState().equals("free")){
//normal stuff1
}
else{
if (!readyToPurchase) {
DynamicToast.makeError(mContext,"Problems with Google Play",Toast.LENGTH_SHORT).show();
return;
}
root_ref.child("PurchasedProducts").child(currentUser).addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
if(dataSnapshot.hasChild(model.getProduct_id())){
//Normal stuff
}
else{
bp.purchase((Activity) mContext,model.getProduct_id());
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
}
}
});
}
};
adapter.startListening();
infiniteAdapter = InfiniteScrollAdapter.wrap(adapter);
itemPicker.setAdapter(infiniteAdapter);
//.setItemTransitionTimeMillis(DiscreteScrollViewOptions.getTransitionTime());
itemPicker.setItemTransformer(new ScaleTransformer.Builder()
.setMinScale(0.5f)
.build());
记住,始终检查组件是否为空。比执行你的代码。
示例:
if ("your_component" != null){
//your code
}
你似乎已经尝试了我能想到的几乎所有方法。这可能是 SHA-1 的问题。试试这些:
- 首先,检查您正在访问的 child 是否确实存在。(即不为空)
- 尝试检查您是否真的有权添加产品。另外,检查 Firebase 规则。
- 尝试添加具有不同类型用户的产品(如果您的应用包含不同类型的用户)。
好的,开始了!我看到代码中有一个异常可能被忽略,就像在高端 apis.In 简单的单词中 api 23 和 >23 一样,在 viewHolder 区域使用 ViewGroup Parent 获取上下文!没问题,但在小型 api 设备上我认为这将是一个问题!
所以试试这个希望这会有所帮助!
也许我是从这个角度来看的希望这对您有所帮助
public CardHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//inflate the single recycler view layout(item)
// !!!!!!!!!!!!! **the issue is here**! !!!!!!!!!!!!!!!
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.card_product, parent, false);
final CardHolder cardViewHolder = new CardHolder(view);
return cardViewHolder;
}
您的布局未正确膨胀! 像这样获取上下文 可能是 class 上的 NULL POINTER EXCEPTION 的原因!有一个简单的方法可以做到!例如通过在实例化时使用适配器的构造函数获取 activity 的上下文。
这是例子!
public class yourActivity extends AppCompatActivity{
YourAdapter mAdapter;
/// lets say you are setting it up in android ONCREATE Method
@override
public void OnCreate(....){
...........
mAdapter(data,design,YourActivity.this);
//here this will be the context going in your adapter simple
}
}
在你的适配器的构造函数中,你可以将它存储在一个全局变量中,就像这样
public class YourAdapter extends RECYCLERView.Adapter......{
Context mContext;
public YourAdapter(Data data, int design,Context mContext)
this.mContext = mContext;
}
//and now you can access without any stress about context null exception
public CardHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//inflate the single recycler view layout(item)
View view = LayoutInflater.from(mContext)
.inflate(R.layout.card_product, parent, false);
final CardHolder cardViewHolder = new CardHolder(view);
return cardViewHolder;
}
上面的代码暴露并解决了第一个异常。我希望的第二个是这样的
您正在尝试使用 RecyclerView 但没有为它提供用于保存视图的子类!
当我们为回收器视图制作适配器时,必然会有 ViewHolder 的 Subclass 来为我们做简单的回收。该 subclass 的主要工作是保存视图并使用它们的 ID
找到它们
对于通用示例,试试这个 link 我找到了!归功于 git 作者。
问题是在使用 Proguard
时,我没有在我的 pojo classes 上使用 @Keep
,所以当尝试用 [=12] 序列化 class 时=] 数据库没有找到属性,因为它们被混淆了。
我遇到了一个大问题,我不知道发生了什么,我已经将一个应用程序上传到 Play 商店,因为当我 运行 它在模拟器上,甚至在我的真实设备上时,它是崩溃了,但现在当我从 Google 下载它时,播放它说:
java.lang.NullPointerException:
at com..onBindViewHolder (ChooseCard.java)
or .onCreateViewHolder (ChooseCard.java)
at com..onBindViewHolder (ChooseCard.java)
or .onCreateViewHolder (ChooseCard.java)
at com.firebase.ui.database.FirebaseRecyclerAdapter.getItemCount (FirebaseRecyclerAdapter.java)
or .onBindViewHolder (FirebaseRecyclerAdapter.java)
or .onChildChanged (FirebaseRecyclerAdapter.java)
or .onError (FirebaseRecyclerAdapter.java)
at com.yarolegovich.discretescrollview.InfiniteScrollAdapter.access0 (InfiniteScrollAdapter.java)
or .getItemCount (InfiniteScrollAdapter.java)
or .getItemViewType (InfiniteScrollAdapter.java)
or .onAttachedToRecyclerView (InfiniteScrollAdapter.java)
or .onBindViewHolder (InfiniteScrollAdapter.java)
or .onCreateViewHolder (InfiniteScrollAdapter.java)
or .wrap (InfiniteScrollAdapter.java)
这个问题已经好几天了,我找不到,你能帮帮我吗?
这是我的 build.gradle
实现
implementation fileTree(include: ['*.jar'], dir: 'libs')
implementation 'com.android.support:appcompat-v7:27.1.1'
implementation 'com.android.support.constraint:constraint-layout:1.1.0'
implementation 'com.android.support:design:27.1.1'
implementation 'com.intuit.sdp:sdp-android:1.0.4'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.1'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
implementation 'com.android.support:cardview-v7:27.1.1'
implementation 'com.google.firebase:firebase-core:15.0.0'
implementation 'com.google.firebase:firebase-auth:15.0.0'
implementation 'com.google.android.gms:play-services-auth:15.0.0'
implementation 'com.google.firebase:firebase-database:15.0.0'
implementation 'com.anjlab.android.iab.v3:library:1.0.44'
implementation 'com.firebaseui:firebase-ui-database:3.3.1'
implementation 'com.onesignal:OneSignal:3.7.1'
implementation 'com.yarolegovich:discrete-scrollview:1.3.2'
implementation 'com.pranavpandey.android:dynamic-toasts:0.9.0'
implementation 'pl.droidsonroids.gif:android-gif-drawable:1.2.11'
implementation 'com.google.android.gms:play-services-analytics:15.0.0'
.....
dependencies {
classpath 'com.android.tools.build:gradle:3.1.2'
classpath 'com.google.gms:google-services:3.2.1'
编辑
我已经在 Google Play 上更新了我的应用程序但没有任何反应,仍然在相同的 Activity
上崩溃,我现在知道如何调试它,问题是我下载时来自 Google Play 的应用程序,在模拟器上(即使在新的模拟器设备上也不会崩溃)和我的真实设备上。
正如@Marcos Vascondelos所说,我做了构建>生成签名APK>获取应用程序-release.apk将它安装在我的设备上,问题是我无法登录它正在使用这种方法:
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
// Result returned from launching the Intent from GoogleSignInApi.getSignInIntent(...);
if (requestCode == RC_SIGN_IN) {
Task<GoogleSignInAccount> task = GoogleSignIn.getSignedInAccountFromIntent(data);
try {
// Google Sign In was successful, authenticate with Firebase
GoogleSignInAccount account = task.getResult(ApiException.class);
firebaseAuthWithGoogle(account);
} catch (ApiException e) {
// Google Sign In failed, update UI appropriately
Log.w(TAG, "Google sign in failed", e.getCause());
Toast with e.getCause is null
}
}
}
如果你想看看我如何登录才能不在这个问题上添加更多代码,我会在这个 GitHubGist
我读到它可能是 SHA-1 的问题,但我不知道为什么在模拟器上没问题,设备没问题,Google播放没问题,但如果我安装 . apk直接说null.
上次编辑
我看到问题不在 Firebase
调用上,而是在填充列表上,我的意思是产品被正确捕获,但是当我尝试放入列表时它崩溃了
我的 FirebaseRecyclerOptions
适配器看起来像
final FirebaseRecyclerOptions< CardPOJO > options =
new FirebaseRecyclerOptions.Builder< CardPOJO >()
.setQuery(products_ref, CardPOJO.class)
.build();
adapter = new FirebaseRecyclerAdapter< CardPOJO, CardHolder>(options) {
@Override
public CardHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//inflate the single recycler view layout(item)
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.card_product, parent, false);
final CardHolder cardViewHolder = new CardHolder(view);
return cardViewHolder;
}
@Override
public void onDataChanged() {
super.onDataChanged();
if(progressDialog!=null)progressDialog.dismiss();initViews();
}
@Override
protected void onBindViewHolder(final CardHolder holder, int position, final CardPOJO model) {
holder.itemView.setSelected(0== position); ////where you are in the list
holder.getLayoutPosition();
switch (model.getState()){
case "free":
holder.card_image.setImageResource();
break;
case "not_free":
if(userOwnsProduct(model.getProduct_id())){
holder.card_image.setImageResource();
}
else{
holder.card_image.setImageResource();
}
break;
default:
break;
}
holder.view.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(model.getState().equals("free")){
//normal stuff1
}
else{
if (!readyToPurchase) {
DynamicToast.makeError(mContext,"Problems with Google Play",Toast.LENGTH_SHORT).show();
return;
}
root_ref.child("PurchasedProducts").child(currentUser).addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
if(dataSnapshot.hasChild(model.getProduct_id())){
//Normal stuff
}
else{
bp.purchase((Activity) mContext,model.getProduct_id());
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
}
}
});
}
};
adapter.startListening();
infiniteAdapter = InfiniteScrollAdapter.wrap(adapter);
itemPicker.setAdapter(infiniteAdapter);
//.setItemTransitionTimeMillis(DiscreteScrollViewOptions.getTransitionTime());
itemPicker.setItemTransformer(new ScaleTransformer.Builder()
.setMinScale(0.5f)
.build());
记住,始终检查组件是否为空。比执行你的代码。 示例:
if ("your_component" != null){
//your code
}
你似乎已经尝试了我能想到的几乎所有方法。这可能是 SHA-1 的问题。试试这些:
- 首先,检查您正在访问的 child 是否确实存在。(即不为空)
- 尝试检查您是否真的有权添加产品。另外,检查 Firebase 规则。
- 尝试添加具有不同类型用户的产品(如果您的应用包含不同类型的用户)。
好的,开始了!我看到代码中有一个异常可能被忽略,就像在高端 apis.In 简单的单词中 api 23 和 >23 一样,在 viewHolder 区域使用 ViewGroup Parent 获取上下文!没问题,但在小型 api 设备上我认为这将是一个问题!
所以试试这个希望这会有所帮助!
也许我是从这个角度来看的希望这对您有所帮助
public CardHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//inflate the single recycler view layout(item)
// !!!!!!!!!!!!! **the issue is here**! !!!!!!!!!!!!!!!
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.card_product, parent, false);
final CardHolder cardViewHolder = new CardHolder(view);
return cardViewHolder;
}
您的布局未正确膨胀! 像这样获取上下文 可能是 class 上的 NULL POINTER EXCEPTION 的原因!有一个简单的方法可以做到!例如通过在实例化时使用适配器的构造函数获取 activity 的上下文。
这是例子!
public class yourActivity extends AppCompatActivity{
YourAdapter mAdapter;
/// lets say you are setting it up in android ONCREATE Method
@override
public void OnCreate(....){
...........
mAdapter(data,design,YourActivity.this);
//here this will be the context going in your adapter simple
}
}
在你的适配器的构造函数中,你可以将它存储在一个全局变量中,就像这样
public class YourAdapter extends RECYCLERView.Adapter......{
Context mContext;
public YourAdapter(Data data, int design,Context mContext)
this.mContext = mContext;
}
//and now you can access without any stress about context null exception
public CardHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//inflate the single recycler view layout(item)
View view = LayoutInflater.from(mContext)
.inflate(R.layout.card_product, parent, false);
final CardHolder cardViewHolder = new CardHolder(view);
return cardViewHolder;
}
上面的代码暴露并解决了第一个异常。我希望的第二个是这样的
您正在尝试使用 RecyclerView 但没有为它提供用于保存视图的子类!
当我们为回收器视图制作适配器时,必然会有 ViewHolder 的 Subclass 来为我们做简单的回收。该 subclass 的主要工作是保存视图并使用它们的 ID
找到它们对于通用示例,试试这个 link 我找到了!归功于 git 作者。
问题是在使用 Proguard
时,我没有在我的 pojo classes 上使用 @Keep
,所以当尝试用 [=12] 序列化 class 时=] 数据库没有找到属性,因为它们被混淆了。