I am stuck on this issue ....
I keep getting this particular error in my app:
java.lang.NullPointerException: Attempt to invoke virtual method 'com.google.firebase.database.ValueEventListener com.google.firebase.database.DatabaseReference.addValueEventListener(com.google.firebase.database.ValueEventListener)' on a null object reference
Now, what i am trying to do is post the results of items listed in a Firebase database.
here is my code for the making that list:
public class WatchListFragment extends Fragment {
    private static final String TAG = "WatchListFragment";
    private static final int NUM_GRID_COLUMNS = 3;
    private static final int GRID_ITEM_MARGIN = 5;
    //widgets
    private FrameLayout mFrameLayout;
    //reference for listening when items are added or removed from the watch list
    //vars
//    private DatabaseReference mReference = FirebaseDatabase.getInstance().getReference()
//            .child(getString(R.string.node_watch_list))
//            .child(FirebaseAuth.getInstance().getCurrentUser().getUid());
    private PostAdapter mAdapter;
    private ArrayList<Post> mPosts;
    private RecyclerView mRecyclerView;
    private DatabaseReference mReference;
    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_watch_list, container, true);
        mRecyclerView = (RecyclerView) view.findViewById(R.id.watchListRecyclerView);
        mFrameLayout = (FrameLayout) view.findViewById(R.id.watch_list_container);
        Log.d(TAG, "init: initializing.");
        mPosts = new ArrayList<>();
        //set the listener to the reference
        mReference.addValueEventListener(mLisenter);
        if(isAdded()){
            getResources().getString(R.string.app_name);
            mReference = FirebaseDatabase.getInstance().getReference()
                    .child(getString(R.string.node_watch_list))
                    .child(FirebaseAuth.getInstance().getCurrentUser().getUid());
        }
        mPosts = new ArrayList<Post>();
        mAdapter = new PostAdapter(this, mPosts);
        mRecyclerView = (RecyclerView) view.findViewById(R.id.watchListRecyclerView); //unsere (Recycleriew)Liste aus dem Design wird in eine RecyclerView ungewandelt
        mRecyclerView.setHasFixedSize(true);
        mRecyclerView.setLayoutManager(new LinearLayoutManager(getActivity())); //Hier könnten wir auch verschiedene Layouts festlegen. Bei der ListView, die vorher hatten, ist das Linearlayout fest eingestellt.
        mRecyclerView.addItemDecoration(new DividerItemDecoration(getActivity(), LinearLayoutManager.VERTICAL)); // Der Divider trennt die Zeilen mit einem Strich
        mRecyclerView.setAdapter(mAdapter); //Adapter wird gesetzt
//        RecyclerViewMargin itemDecorator = new RecyclerViewMargin(GRID_ITEM_MARGIN, NUM_GRID_COLUMNS);
//        mRecyclerView.addItemDecoration(itemDecorator);
//        GridLayoutManager gridLayoutManager = new GridLayoutManager(getActivity(), NUM_GRID_COLUMNS);
//        mRecyclerView.setLayoutManager(gridLayoutManager);
//        mAdapter = new PostListAdapter(getActivity(), mPosts);
//        mRecyclerView.setAdapter(mAdapter);
        return view;
    }
    public void viewPost(String postId){
        ViewPostFragment fragment = new ViewPostFragment();
        Activity activity = getActivity();
        if (isAdded() && activity != null) {
        FragmentTransaction transaction = getActivity().getSupportFragmentManager().beginTransaction();
        Bundle args = new Bundle();
        args.putString(getString(R.string.arg_post_id), postId);
        fragment.setArguments(args);
        transaction.replace(R.id.watch_list_container, fragment, getString(R.string.fragment_view_post));
        transaction.addToBackStack(getString(R.string.fragment_view_post));
        transaction.commit();
        mFrameLayout.setVisibility(View.VISIBLE);
        }
    }
    @Override
    public void onDestroy() {
        super.onDestroy();
        mReference.removeEventListener(mLisenter);
    }
    ValueEventListener mLisenter = new ValueEventListener() {
        @Override
        public void onDataChange(DataSnapshot dataSnapshot) {
            Log.d(TAG, "onDataChange: a change was made to this users watch lits node.");
            DatabaseReference reference = FirebaseDatabase.getInstance().getReference();
            Query query = reference.child("posts")
                    .orderByKey()
                    .equalTo(FirebaseAuth.getInstance().getCurrentUser().getUid());
            reference.addValueEventListener(new ValueEventListener() {
                @Override
                public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
                    DataSnapshot dShot = dataSnapshot.getChildren().iterator().next();
                    for (DataSnapshot dShot2 : dShot.getChildren()) {
                        Post post = (Post) dShot2.getValue(Post.class);
                        mPosts.add(post);
                    }
                    mAdapter.notifyDataSetChanged();
                }
                @Override
                public void onCancelled(@NonNull DatabaseError databaseError) {
                }
            });
        }
        @Override
        public void onCancelled(DatabaseError databaseError) {
        }
    };
}
The offending line of code flagged in the logcat is this: mReference.addValueEventListener(mLisenter);
I am not totally sure it is that is the issue. I have followed the tutorials and googled for an answer and I am still stuck as to why I am getting this particular issue
 
    