c# - 堆栈溢出 ToArray()

标签 c# linq-to-sql stack-overflow

我从下面代码的最后一行得到一个堆栈溢出错误。我不明白为什么。有什么想法吗?

        var slots = from a in db.AvailableAppointments
                    where a.RequestID == reqId
                    select new
                    DataLayer.DateAndTimeslot
                    {
                        date = a.Date.ToShortDateString(),
                        timeSlot = a.Timeslot
                    };

        returnValue.DateAndTimeslot = slots.ToArray();

我的类(class);

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Runtime.Serialization;

namespace DataLayer
{
    [DataContract(Namespace = "http://wholesale.fluidata.co.uk/bt/AppointmentAvailabilityResponse")]

    public class AppointmentAvailabilityResponse : DataLayer.WebserviceMessage
    {
        DateAndTimeslot[] _dateAndTimeSlot;

        [DataMember]
        public DateAndTimeslot[] DateAndTimeslot
        {
            get { return _dateAndTimeSlot; }
            set { _dateAndTimeSlot = value; }
        }

    }

    public class DateAndTimeslot
    {
        private String _date;
        private String _timeSlot;

        [DataMember]
        public string date 
        {
            get { return this._date; }
            set {_date = value;}
        }

        [DataMember]
        public string timeSlot
        {
            get { return this.timeSlot; }
            set {_timeSlot = value;}
        }

    }
}

我的表(带有示例数据)

ID  RequestID   Date            Timeslot
171 3214    2005-12-28 00:00:00.000 EV
172 3214    2005-12-28 00:00:00.000 EV
173 3214    2005-12-29 00:00:00.000 EV
174 3214    2005-12-29 00:00:00.000 EV
175 3214    2005-12-30 00:00:00.000 EV
176 3214    2005-12-30 00:00:00.000 EV


CREATE TABLE [dbo].[AvailableAppointments](
    [ID] [int] IDENTITY(1,1) NOT NULL,
    [RequestID] [int] NOT NULL,
    [Date] [datetime] NOT NULL,
    [Timeslot] [varchar](21) NOT NULL,
 CONSTRAINT [PK_AvalibleAppointments] PRIMARY KEY CLUSTERED 
(
    [ID] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

最佳答案

这里:

[DataMember]
public string timeSlot
{
    get { return this.timeSlot; }
    set { _timeSlot = value; }
}

注意到 getter 和递归调用中缺少的 _ 了吗?

应该是:

[DataMember]
public string timeSlot
{
    get { return this._timeSlot; }
    set { _timeSlot = value; }
}

顺便说一下,自从我开始使用 Auto implemented properties在 C# 中,这些类型的错误被遗忘了:

[DataMember]
public string TimeSlot { get; set; }

只是一个挑剔的旁注:让属性名称以大写字母开头(TimeSlot 而不是 timeSlot)是一种很好的编码习惯。

关于c# - 堆栈溢出 ToArray(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6695838/

相关文章:

c# - 如何在 C# 中退出非 void 方法

join - 如何使用 LINQ-to-SQL 连接多个表?

c# - 使用 Expression<Func<...>> 的 linq to sql 自定义方法

c# - linq在groupby之后排序分组元素

c# - 在 LINQ to SQL 中选择 "IN"

c++ - .NET 异常处理程序在 Visual C++ 6.0 异常中导致堆栈溢出

arrays - 为什么堆栈溢出取决于Go中如何访问数组?

c - 我的程序在 C 中实现堆栈有什么问题

c# - Azure 函数最佳实践

c# - 将已安装的 C# 应用程序连接到本地 SQL Server 2005 Express - 用户未与受信任的 sql 连接相关联