Results 1 to 3 of 3

Thread: Question about Lambda Expressions

  1. #1

    Thread Starter
    PowerPoster techgnome's Avatar
    Join Date
    May 2002

    Question about Lambda Expressions

    I saw Lambda Expressions in a reply in the "What's New" thread, and have a few questions about it.

    As I understand in Lambda Expressions were added to provide functionality for LINQ. My questions are as follows:

    1) What the heck is it?
    2) What would I use it for? Bonus points for explaining why I would and/or not use it in some circumstances. Or better, a situation in which I could use it, but shouldn't.
    3) Could you provide an example of one? This is where I've had problems, most of the examples I've seen have been so esoteric, that I just don't get it.

    * I don't respond to private (PM) requests for help. It's not conducive to the general learning of others.*
    * I also don't respond to friend requests. Save a few bits and don't bother. I'll just end up rejecting anyways.*
    * How to get EFFECTIVE help: The Hitchhiker's Guide to Getting Help at VBF - Removing eels from your hovercraft *
    * How to Use Parameters * Create Disconnected ADO Recordset Clones * Set your VB6 ActiveX Compatibility * Get rid of those pesky VB Line Numbers * I swear I saved my data, where'd it run off to??? *

  2. #2
    Special Guest - Microsoft funkyonex's Avatar
    Join Date
    Dec 2007

    Re: Question about Lambda Expressions

    Hi technome,

    I actually had trouble learning them as well and am very thankful that Visual Basic provides the common ones you use in LINQ queries as query expressions instead. So I think I'll go for the "bonus points"...

    Here's an example of a simple lambda expression, or as I like to call them, inline functions, that adds x to itself:

    Dim myFunc = Function(x) x + x
    To call this, we could write:

    Which results: 4

    Extension Methods are another new feature and allow you to create methods that extend any type. For instance you could create your own Print method on the string class. The LINQ framework relies heavily on Lambda expressions as well as Extension Methods. In fact, the LINQ syntax we see in Visual Basic is really just abstracting away Extension Methods and Lambda Expressions for us in most cases. For instance, the Sum extension method accepts a lambda expression as one of it's parameters. Say we want to only sum even numbers in an array. We can do this in one line of code using a lambda expression:

    Dim x As Integer() = {1, 2, 3, 4, 5, 6}
    Dim sumofEvens = x.Sum(Function(y) If(y Mod 2 = 0, y, 0))
    Lambda functions start to get really useful (and necessary) when we start writing LINQ queries. Say we want to Sum all of the products in our products collection by multiplying the UnitPrice by the UnitsInStock. We could write this:

     Dim total = (From Product In db.Products) _
                     .Sum(Function(p As Product) p.UnitPrice * p.UnitsInStock)
    But why? (I think this is my bonus point) In Visual Basic we don't have to write lambda expressions to do aggregate operations like this. (see here: We can instead write this using Visual Basic's Query Expressions:

     Dim total = Aggregate Product In db.Products _
                     Into Sum(Product.UnitPrice * Product.UnitsInStock)
    I love it! Much easier to figure out what's going on IMHO. I hope that helps clear it up.

    Have Fun!
    Beth Massi, Visual Studio Community
    Visit the Visual Basic Developer Center

  3. #3
    Ex-Super Mod RobDog888's Avatar
    Join Date
    Apr 2001
    LA, Calif. Raiders #1 AKA:Gangsta Yoda™

    Re: Question about Lambda Expressions

    Cool deal, I like these "inline functions". Thanks for the code examples.
    VB/Office Guru™ (AKA: Gangsta Yoda®)
    I dont answer coding questions via PM. Please post a thread in the appropriate forum.

    Microsoft MVP 2006-2011
    Office Development FAQ (C#, VB.NET, VB 6, VBA)
    Senior Jedi Software Engineer MCP (VB 6 & .NET), BSEE, CET
    If a post has helped you then Please Rate it!
    Reps & Rating PostsVS.NET on Vista Multiple .NET Framework Versions Office Primary Interop AssembliesVB/Office Guru™ Word SpellChecker™.NETVB/Office Guru™ Word SpellChecker™ VB6VB.NET Attributes Ex.Outlook Global Address ListAPI Viewer utility.NET API Viewer Utility
    System: Intel i7 6850K, Geforce GTX1060, Samsung M.2 1 TB & SATA 500 GB, 32 GBs DDR4 3300 Quad Channel RAM, 2 Viewsonic 24" LCDs, Windows 10, Office 2016, VS 2019, VB6 SP6

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts

Click Here to Expand Forum to Full Width