1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

Evitando duplicidade no código assíncrono

Eu tenho um código que precisa ser executado tanto síncrono como assíncrono e eu gostaria de saber qual é a melhor prática de programação para criar um método assíncrono espelhado em um síncrono. Eu tenho o seguinte método:

public virtual int Save(TModel model)
{
    this.dbSet.Add(model);
    return this.SaveChanges();
}

Eu acabei o recriando dessa maneira:

public virtual Task<Int32> SaveAsync(TModel model)
{
    this.dbSet.Add(model);
    return this.SaveChangesAsync();
}

Esse caso é simples e possui possui poucas linhas de código, mas em casos mais complexos essa duplicidade acaba se tornando um incômodo. Então eu notei que eu poderia fazer o método de uma segunda maneira:

public virtual Task<Int32> SaveAsync(TModel model)
{
    return Task.Factory.StartNew(() => this.Save(model));
}

Eu gostaria de saber qual das duas opções é a melhor prática de programação. Por acaso usar o Task.Factory.StartNew nesse caso é um anti-padrão? Causa algum prejuízo?

  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

1 resposta

Não é a resposta que estava procurando? Procure outras perguntas com as tags c# .net ou faça a sua própria pergunta.