edit # 2: Вопрос решен на полпути. Смотри ниже
В качестве дополнительного вопроса, знает ли кто-нибудь о неагрессивном способе решения того, что я пытаюсь сделать ниже (а именно, связывание объектов друг с другом без запуска бесконечных циклов)?
Я пытаюсь создать веб-приложение asp.net-mvc и получить исключение StackOverFlowException. Контроллер запускает следующую команду:
public ActionResult ShowCountry(int id)
{
Country country = _gameService.GetCountry(id);
return View(country);
}
GameService обрабатывает это следующим образом (WithCountryId является расширением):
public Country GetCountry(int id)
{
return _gameRepository.GetCountries().WithCountryId(id).SingleOrDefault();
}
GameRepository обрабатывает это так:
public IQueryable<Country> GetCountries()
{
var countries = from c in _db.Countries
select new Country
{
Id = c.Id,
Name = c.Name,
ShortDescription = c.ShortDescription,
FlagImage = c.FlagImage,
Game = GetGames().Where(g => g.Id == c.GameId).SingleOrDefault(),
SubRegion = GetSubRegions().Where(sr => sr.Id == c.SubRegionId).SingleOrDefault(),
};
return countries;
}
Метод GetGames () вызывает исключение StackOverflowException:
public IQueryable<Game> GetGames()
{
var games = from g in _db.Games
select new Game
{
Id = g.Id,
Name = g.Name
};
return games;
}
Мои бизнес-объекты отличаются от классов linq2sql, поэтому я заполняю их новым select.
Произошло необработанное исключение типа «System.StackOverflowException» в mscorlib.dll
edit # 1: Я нашел виновника, это следующий метод, он вызывает метод GetCountries (), который в свою очередь снова вызывает GetSubRegions (), ad nauseam:
public IQueryable<SubRegion> GetSubRegions()
{
return from sr in _db.SubRegions
select new SubRegion
{
Id = sr.Id,
Name = sr.Name,
ShortDescription = sr.ShortDescription,
Game = GetGames().Where(g => g.Id == sr.GameId).SingleOrDefault(),
Region = GetRegions().Where(r => r.Id == sr.RegionId).SingleOrDefault(),
Countries = new LazyList<Country>(GetCountries().Where(c => c.SubRegion.Id == sr.Id))
};
}
Здесь, возможно, придется подумать о чем-то еще :) Вот что происходит, когда вы думаете, что в ОО-мышлении слишком много кофе