Infinite Coders Ответов: 1

Я получаю объект error, установленный в экземпляр ссылки проекта объекта - https://drive.google.com/drive/folders/1nu7huhfjgowxc22aptlhlwienyth_lcx-что? УСП=обмен


using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using FireSharp.Config;
using FireSharp.Response;
using FireSharp.Interfaces;

namespace vbEngC
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        IFirebaseConfig fcon = new FirebaseConfig()
        {
            AuthSecret = "NK4r2FbHGqMpmEPfPMgRkmaqOBjEzYeJYCvpmn0q",
            BasePath = "https://cfireeng-6efa8.firebaseio.com/"
        };

        IFirebaseClient client;

        private void Form1_Load(object sender, EventArgs e)
        {
            try 
            {
                client = new FireSharp.FirebaseClient(fcon);
            }
            catch
            {
                MessageBox.Show("there was problem in the internet.");
            }
        }

        private void InsertBtn_Click(object sender, EventArgs e)
        {
            #region store in the studentlist
            Student std = new Student()
            {
                FullName = nameTbox.Text,
                RollNo = rollTbox.Text,
                Grade = gradeTobx.Text,
                Section = secTbox.Text
            };
            var setter = client.Set("StudentList/"+rollTbox.Text,std);
            MessageBox.Show("data inserted successfully");
            #endregion

            //store in sno
            FirebaseResponse res = client.Get(@"Counter");
            int Counter = int.Parse(res.ResultAs<string>());

            MyRoll roll = new MyRoll()
            {
                RollNo = rollTbox.Text
            };

            var set2 = client.Set(@"Counter", ++Counter);
            var set3 = client.Set(@"Sno/" + Counter, roll);

            MessageBox.Show("INSERTED SUCCESSFULLY");
        }

        private void SelectBtn_Click(object sender, EventArgs e)
        {
            var result = client.Get("StudentList/" + rollTbox.Text);
            Student std = result.ResultAs<student>();
            nameTbox.Text = std.FullName;
            gradeTobx.Text = std.Grade;
            secTbox.Text = std.Section;
            MessageBox.Show("data retrieved successfully");
        }

        private void UpdateBtn_Click(object sender, EventArgs e)
        {
            Student std = new Student()
            {
                FullName = nameTbox.Text,
                RollNo = rollTbox.Text,
                Grade = gradeTobx.Text,
                Section = secTbox.Text
            };
            var setter = client.Update("StudentList/" + rollTbox.Text, std);
            MessageBox.Show("data inserted successfully");
        }

        private void DeleteBtn_Click(object sender, EventArgs e)
        {
            var result = client.Delete("StudentList/" + rollTbox.Text);
            MessageBox.Show("data deleted successfully");
        }

        //show all records
        private void button1_Click(object sender, EventArgs e)
        {
            DataTable dt = new DataTable();
            dt.Columns.Add("Full Name");
            dt.Columns.Add("Roll No");
            dt.Columns.Add("Grade");
            dt.Columns.Add("Section");

           
            FirebaseResponse res = client.Get(@"Counter");
            int Counter = int.Parse(res.ResultAs<string>());

            for (int i = 1; i <= Counter; i++)
            {
                FirebaseResponse res2 = client.Get(@"Sno/" + i + "/RollNo");
                string RollNo = res2.ResultAs<string>();

                var res3 = client.Get(@"StudentList/" + RollNo);
                Student std = res3.ResultAs<student>();

                if(1==1) // (std!=null)
                {
                    dt.Rows.Add(std.FullName, std.RollNo, std.Grade, std.Section);
                }
            }

            foreach (DataRow item in dt.Rows)
            {
                dataGridView1.Rows.Add(item.ItemArray);
            }
        }
    }
}


Что я уже пробовал:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using FireSharp.Config;
using FireSharp.Response;
using FireSharp.Interfaces;

namespace vbEngC
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        IFirebaseConfig fcon = new FirebaseConfig()
        {
            AuthSecret = "NK4r2FbHGqMpmEPfPMgRkmaqOBjEzYeJYCvpmn0q",
            BasePath = "https://cfireeng-6efa8.firebaseio.com/"
        };

        IFirebaseClient client;

        private void Form1_Load(object sender, EventArgs e)
        {
            try 
            {
                client = new FireSharp.FirebaseClient(fcon);
            }
            catch
            {
                MessageBox.Show("there was problem in the internet.");
            }
        }

        private void InsertBtn_Click(object sender, EventArgs e)
        {
            #region store in the studentlist
            Student std = new Student()
            {
                FullName = nameTbox.Text,
                RollNo = rollTbox.Text,
                Grade = gradeTobx.Text,
                Section = secTbox.Text
            };
            var setter = client.Set("StudentList/"+rollTbox.Text,std);
            MessageBox.Show("data inserted successfully");
            #endregion

            //store in sno
            FirebaseResponse res = client.Get(@"Counter");
            int Counter = int.Parse(res.ResultAs<string>());

            MyRoll roll = new MyRoll()
            {
                RollNo = rollTbox.Text
            };

            var set2 = client.Set(@"Counter", ++Counter);
            var set3 = client.Set(@"Sno/" + Counter, roll);

            MessageBox.Show("INSERTED SUCCESSFULLY");
        }

        private void SelectBtn_Click(object sender, EventArgs e)
        {
            var result = client.Get("StudentList/" + rollTbox.Text);
            Student std = result.ResultAs<Student>();
            nameTbox.Text = std.FullName;
            gradeTobx.Text = std.Grade;
            secTbox.Text = std.Section;
            MessageBox.Show("data retrieved successfully");
        }

        private void UpdateBtn_Click(object sender, EventArgs e)
        {
            Student std = new Student()
            {
                FullName = nameTbox.Text,
                RollNo = rollTbox.Text,
                Grade = gradeTobx.Text,
                Section = secTbox.Text
            };
            var setter = client.Update("StudentList/" + rollTbox.Text, std);
            MessageBox.Show("data inserted successfully");
        }

        private void DeleteBtn_Click(object sender, EventArgs e)
        {
            var result = client.Delete("StudentList/" + rollTbox.Text);
            MessageBox.Show("data deleted successfully");
        }

        //show all records
        private void button1_Click(object sender, EventArgs e)
        {
            DataTable dt = new DataTable();
            dt.Columns.Add("Full Name");
            dt.Columns.Add("Roll No");
            dt.Columns.Add("Grade");
            dt.Columns.Add("Section");

           
            FirebaseResponse res = client.Get(@"Counter");
            int Counter = int.Parse(res.ResultAs<string>());

            for (int i = 1; i <= Counter; i++)
            {
                FirebaseResponse res2 = client.Get(@"Sno/" + i + "/RollNo");
                string RollNo = res2.ResultAs<string>();

                var res3 = client.Get(@"StudentList/" + RollNo);
                Student std = res3.ResultAs<Student>();

                if(1==1) // (std!=null)
                {
                    dt.Rows.Add(std.FullName, std.RollNo, std.Grade, std.Section);
                }
            }

            foreach (DataRow item in dt.Rows)
            {
                dataGridView1.Rows.Add(item.ItemArray);
            }
        }
    }
}

1 Ответов

Рейтинг:
2

OriginalGriff

Это одна из самых распространенных проблем, которые нам задают, и это также та, на которую мы меньше всего готовы ответить, но вы больше всего готовы ответить сами.

Позвольте мне просто объяснить, что означает ошибка: вы пытались использовать переменную, свойство или возвращаемое значение метода, но оно содержит null - что означает, что в переменной нет экземпляра класса.
Это немного похоже на карман: у вас есть карман в рубашке, который вы используете, чтобы держать ручку. Если вы сунете руку в карман и обнаружите, что там нет ручки, вы не сможете подписать свое имя на листе бумаги - и вы получите очень смешные взгляды, если попытаетесь! Пустой карман дает вам нулевое значение (здесь нет ручки!), поэтому вы не можете сделать ничего, что обычно делали бы, когда вы извлекли свою ручку. Почему он пуст? Вот в чем вопрос - может быть, вы забыли взять ручку, когда уходили из дома сегодня утром, или, возможно, вы оставили ручку в кармане вчерашней рубашки, когда снимали ее вчера вечером.

Мы не можем сказать, потому что нас там не было, и, что еще важнее, мы даже не можем видеть вашу рубашку, не говоря уже о том, что находится в кармане!

Вернемся к компьютерам, и вы каким - то образом сделали то же самое-и мы не можем увидеть ваш код, а тем более запустить его и узнать, что содержит null, когда это не должно быть.
Но вы можете - и Visual Studio поможет вам здесь. Запустите свою программу в отладчике, и когда она выйдет из строя, VS покажет вам строку, в которой она обнаружила проблему. Затем вы можете начать просматривать различные его части, чтобы увидеть, какое значение равно null, и начать просматривать свой код, чтобы узнать, почему. Поэтому поставьте точку останова в начале метода, содержащего строку ошибки, и снова запустите программу с самого начала. На этот раз VS остановится перед ошибкой и позволит вам изучить, что происходит, пройдя через код, глядя на ваши значения.

Но мы не можем этого сделать - у нас нет вашего кода, мы не знаем, как его использовать, если бы он у нас был, у нас нет ваших данных. Так что попробуйте - и посмотрите, сколько информации вы можете узнать!