CacheDependency non più sealed

di Stefano Mostarda, in .Net 2.0,

All'inizio non ci avevo fatto caso, ma la cosa era abbastanza ovvia vista l'implementazione della classe SqlDependency: finalmente è stata aperta la classe CacheDependency. Nella versione 1.x questa classe è sealed, impedendo quindi una personalizzazione per i propri fini. Nella prossima versione, invece, potremo finalmente creare delle dipendenze customizzate per gli oggetti in cache. Il primo caso che mi viene in mente è far spirare un oggetto in base ad un webservice, per un CMS può essere utile piazzare una dipendenza su un feed RSS, o altro ancora.

L'implementazione è anche piuttosto semplice e si basa su un polling effettuato sulla risorsa da cui dipende l'oggetto in cache. Nel momento in cui il risultato del polling cambia, viene invocato il metodo NotifyDependencyChanged che fa scattare l'invalidazione di tutti gli oggetti della cache che dipendono da questo. In questa implementazione la durata dell'oggetto in cache viene basata sul risultato del metodo GetData del WS WSData.

static Timer _timer;
private int _data;
public WSDependency()
{
  _timer = new Timer(new TimerCallback(CallBack), this, 20, 20000);
  _data = GetData();
}
protected override void DependencyDispose()
{
  _timer.Dispose();
  base.DependencyDispose();
}
protected void CallBack(object sender)
{
  int appData = GetData();
  if (appData != _data)
  {
    ((WSDependency)sender).NotifyDependencyChanged(sender, EventArgs.Empty);
  }
}
public int GetData()
{
  WSData ws = new WSData();
  return ws.GetData();
}
Commenti

Visualizza/aggiungi commenti

| Condividi su: Twitter, Facebook, LinkedIn

Per inserire un commento, devi avere un account.

Fai il login e torna a questa pagina, oppure registrati alla nostra community.

Nella stessa categoria
I più letti del mese