CacheDependency non più sealed

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();
}

Nella stessa categoria

Commenti

Aggiungi un nuovo commento »»»
Per inserire un commento, devi registrarti alla nostra community.

© 1998-2008 - SMWorld.NET - Il blog di Stefano Mostarda

TagCloud
BLOG INFO
  • Post: 119
  • Commenti: 68
  • TrackBacks: 19
  • Feed blog e contenuti tecnici: RSS
  • Feed blog: RSS Atom OPML

MVP
CATEGORIE
I PIÙ LETTI DEL MESE
IN EVIDENZA