C# срок службы объекта при инициативе в функцииC#

Место общения программистов C#
Ответить
Anonymous
 C# срок службы объекта при инициативе в функции

Сообщение Anonymous »

Я работаю над приложением .NET и задаюсь вопросом, приведет ли моя структура к утечкам памяти. Мой основной вопрос: получает ли контекст VAR внутри метода myService.getDtos, собирая мусор, собранную после того, как метод разрешается или необходимо измерить вручную. < /P>
Основная структура - < /p>
public class MyService(DataService DataService)
{
private readonly DataService _dataService = DataService;

public async Task GetDTOs()
{
var context = _dataService.GetDtoDatabaseContext();

// Do work

return [];
}
}

public class DataService(string connectionString)
{
private readonly string _connectionString = connectionString;

public DtoService GetDtoDatabaseContext()
{
return new DtoService(_connectionString);
}
}

public class DtoService(string connectionString)
{
private readonly string _connectionString = connectionString;

public async Task GetDtos()
{
using var context = new dtoContext(_connectionString);
return any;
}
}

< /code>
Как MyService, так и Dataervice вводится через di в программе. DtoService не является и вместо этого инициализируется при вызове через поставщика данных. Есть ли какие -либо проблемы с этой методологией. Основная причина, по которой я хочу, чтобы поставщик наборов наборов состоит в том, чтобы очистить инъекции DI в различных службах, которые нуждаются в многих контекстах базы данных. Легче ввести «поставщика» вместо 10 (скорее всего, не 10, просто номер) разных служб.>

Подробнее здесь: https://stackoverflow.com/questions/797 ... a-function
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»