linq ed oltre

27
LINQ ed oltre Verso lo spazio profondo (dove vi aspetta Raf ) Ricci Gian Maria:[email protected]

Upload: gian-maria-ricci

Post on 10-May-2015

1.064 views

Category:

Technology


5 download

DESCRIPTION

Slide e codice della presentazione del 18° workshop dotnetmarche

TRANSCRIPT

Page 1: Linq ed oltre

LINQ ed oltreVerso lo spazio profondo

(dove vi aspetta Raf )

Ricci Gian Maria:[email protected]

Page 2: Linq ed oltre

LINQ in un evento sul C# 4.0?

• Gran parte delle funzionalità delle parallel libraries è comunque basata su LINQ

• Rinforzare le basi non fa mai male• Iniziamo sul leggero, perchè poi c’è

Raf

Page 3: Linq ed oltre

• Sebbene gli anonymous delegate siano una funzionalità del 2.0 alcuni concetti sono necessari per LINQ

• È importante capire bene cosa sia una closure• Grazie alle closure è possibile facilitare

l’operazione di Currying [schönfinkeling] (cambio di arità di una funzione)

• Che brutte parole ……..

Lambda expressionAnonymous delegate

Page 4: Linq ed oltre

Anonymous delegates

Page 5: Linq ed oltre

LINQ

• Vedremo ora una presentazione di LINQ collegata ad un ripasso delle funzionalità di C# 3.0

• Quello che verrà fatto è mostrare come le nuove caratteristiche di C# 3.0 sono state introdotte principalmente al servizio di LINQ

Page 6: Linq ed oltre

Possibile genesi di LINQ

Page 7: Linq ed oltre

• A lambda expression is an anonymous function that can contain expressions and statements, and can be used to create delegates or expression tree types.

• All’apparenza è solamente Syntactic Sugar • Ma…….

Lambda expressionLambda expression

Page 8: Linq ed oltre

Lambda expressionMagia o trucco?

Page 9: Linq ed oltre

• Questa «magia» accade perché il compilatore ha due modi distinti di rappresentare una lambda• Funzione anonima• Expression Tree: ovvero la rappresentazione

dell’espressione con oggetti .NET organizzati in un normale «expression tree»

Lambda expressionLambda expression

Page 10: Linq ed oltre

Lambda expressionExpression Tree

+5 * 1 + 4

*

5 1

4

Page 11: Linq ed oltre

Lambda expressionExpression Tree .NET

• Quella appena vista è una Expression Tree relativa ad una espressione numerica

• Una Expression Tree in .NET è sostanzialmente più complessa, perché deve rappresentare accesso ad oggetti, chiamata a metodi, Etc.

• Una lambda MultiRiga non può essere convertita dal compilatore in Expression Tree.

Page 12: Linq ed oltre

Lambda expressionExpression Tree .NET

• o.Customer.Name.StartsWith("A")Lambda

Call

Member Access

Member Access

Parameter

Constant

Esprime la chiamata a funzione StartsWith, necessita di un oggetto su cui chiamarlo e di una serie di parametri, in questo caso la stringa “A”

Nel primo ramo si indica l’oggetto su cui va invocata la funzione.

Il parametro della query, l’ordine o.

Accesso al membro Customer dell’oggetto Order.

Accesso al membro Name dell’oggetto Customer

L’unico parametro del metodo StartsWith()

Page 13: Linq ed oltre

Expression Trees

Expression<Func<int, bool>> lambda = num => num < 5;

Page 14: Linq ed oltre

Lambda expressionChi usa le Expression Tree

• I primi utilizzatori delle Expression Tree sono i Provider LINQ

• Un provider LINQ implementa la IQueryable<T> per tradurre una query LINQ in un qualcosa comprensibile alla sorgente

• ES. LINQ to NHibernate converte in query NHibernate, LINQ to LDAP converte in query LDAP, Etc.

Page 15: Linq ed oltre

Lambda expressionProvider LINQ

• Un provider linq deve quindi solamente tradurre una Expression Tree in qualche cos’altro

LINQ QUERY

Exp TreeCompiler Provider SQL

HQLLDAP

Page 16: Linq ed oltre

Lambda expressionProvider LINQ

• È grazie al compilatore che produce una Expression Tree che il provider per EF/NH/SQL quando vede una chiamata al metodo String.StartsWith() decide di generare una query SQL con operatore LIKE

• Alcuni provider, come il LINQ to XML sono invece implementati tramite IEnumerable<T>

• Se siete interessati a come si implementa un provider LINQ magari un prossimo WS

Page 17: Linq ed oltre

Expression Trees - Le usero mai?

Page 18: Linq ed oltre

• La static reflection è un uso “intelligente” degli expression tree per evitare reflection

Lambda expressionStatic Reflection

Page 19: Linq ed oltre

Static Reflection

Page 20: Linq ed oltre

• Accedere tramite reflection ad un metodo può essere lento.

• Si possono usare le Expression Tree per generare una funzione dinamicamente

Lambda expressionCompilazione di expressionTree

Page 21: Linq ed oltre

Lambda expressionCompilazione di expressionTree

Page 22: Linq ed oltre

Compilazione di Expression Tree

Page 23: Linq ed oltre

Lambda expressionOrderBy dinamici su LINQ

• Si ha un repository basato su IQueryable<T>• Si vuole ordinare per una proprietà che è

passata come stringa• L’operatore OrderBy di LINQ non accetta una

stringa, ma una Expression Tree

Page 24: Linq ed oltre

Lambda expressionOrderBy dinamici su LINQ

• La soluzione è generare run-time l’expression tree che si attenderebbe la OrderBy

• Ad esempio scrivendo customers.OrderByProperty("Name", false) si deve generare la stessa Expression che si avrebbe scrivendo customers.OrderBy(c => c.Name)

Page 25: Linq ed oltre

Order by dinamici su LINQ

Page 26: Linq ed oltre

Lambda expressionConclusioni

• Una buona padronanza delle Expression Tree può aiutare a risolvere problemi “quotidiani”

• Conoscere le Expression Tree non è quindi solo appannaggio di chi scrive un provider LINQ

• Grazie alle Lambda Expression anche in C# si può adottare una programmazione in stile «funzionale»

Page 27: Linq ed oltre

?