我有以下代码:
protected void btnSave_Click(object sender, EventArgs e)
{
StarBusModel.BookingDetail1 objBooking = new StarBusModel.BookingDetail1();
objBooking.TourID = tourID;
objBooking.Name = txtName.Text;
objBooking.Phone = txtPhone.Text;
objBooking.Amount = Convert.ToDecimal(Request.Form[txtAmount.ClientID]);
string [] seats = Request.Form[txtSeatNo.ClientID].Split(new char[] {','});
for (int i = 0; i < seats.Length; i++)
objBooking.SeatDetails.Add(new StarBusModel.SeatDetail1() {SeatID = Convert.ToInt32(seats[i])});
objEntities.BookingDetail1.AddObject(objBooking);
objEntities.SaveChanges();
BindSeats();
}
我收到错误
System.NullReferenceException: Object reference not set to an instance of an object.
在以下代码中:
string [] seats = Request.Form[txtSeatNo.ClientID].Split(new char[] {','});
请告知我哪里错了。我搜索了各种答案,但无法确定我的错误。
答案 0 :(得分:2)
Request.Form[txtSeatNo.ClientID]
显然为空。通常,如果未定义给定键,NameValueCollection
(如Request.Form
)将返回空字符串。
你应该检查一下:
string seatString = Request.Form[txtSeatNo.ClientID];
string [] seats = String.IsNullOrEmpty(seatString) ? new char[]{} :
seatString.Split(new char[] {','});
答案 1 :(得分:0)
NullReferenceException是一个令人头疼的问题。即使您可以通过堆栈跟踪了解发生异常的行。但它也可能包含多种可能性。
你的案子就是一个例子。
string [] seats = Request.Form[txtSeatNo.ClientID].Split(new char[] {','});
实际上在这一行中,有2个地方可以导致null异常。它们是:
通常第二种是最有可能的。
因此最好在多行中编写代码并在使用之前检查该值。我认为Jacob Abrahams给出了一个非常好的例子。