C Sharp 3.0The programming language C# version 3.0 was released on 19 November 2007 as part of .NET Framework 3.5. It includes new features inspired by functional programming languages such as Haskell and ML, and is driven largely by the introduction of the Language Integrated Query (LINQ) pattern to the Common Language Runtime.[1] It is not currently standardized by any standards organisation. C# 3.0 featuresLINQ (language-integrated query)LINQ is a new Microsoft-specific extensible, general-purpose query language for many kinds of data sources—including plain object collections, XML documents, databases, etc.—which is tightly integrated with other C# language facilities. The syntax is different from, but borrows from SQL. An example: int[] array = { 1, 5, 2, 10, 7 };
// Select squares of all odd numbers in the array sorted in descending order
IEnumerable<int> query = from x in array
where x % 2 == 1
orderby x descending
select x * x;
// Result: 49, 25, 1
To implement LINQ, a large range of new methods were added to many collections via the IEnumerable<int> query = array.Where(x => x % 2 == 1)
.OrderByDescending(x => x)
.Select(x => x * x);
// Result: 49, 25, 1 using 'array' as defined in previous example
Object initializersCustomer c = new Customer();
c.Name = "John";
can be written Customer c = new Customer { Name = "John" };
Collection initializersMyList list = new MyList();
list.Add(1);
list.Add(2);
can be written as MyList list = new MyList { 1, 2 };
assuming that Local variable type inferenceLocal variable type inference: var x = new Dictionary<string, List<float>>();
is interchangeable with Dictionary<string, List<float>> x = new Dictionary<string, List<float>>();
This feature is not just a convenient syntactic sugar for shorter local variable declarations, but it is also required for the declaration of variables of anonymous types. The contextual keyword "var", however, may only appear within a local variable declaration. Anonymous typesAnonymous types provide a convenient way to encapsulate a set of read-only properties into a single object without having to first explicitly define a type. The type name is generated by the compiler and is not available at the source code level. The type of the properties is inferred by the compiler. var x = new { FirstName = "John", LastName = "Doe" };
Anonymous types are reference types that derive directly from object. The compiler gives them a name although your application cannot access it. From the perspective of the common language runtime, an anonymous type is no different from any other reference type, except that it cannot be cast to any type except for object. If two or more anonymous types have the same number and type of properties in the same order, the compiler treats them as the same type and they share the same compiler-generated type information.[4] Lambda expressionsLambda expressions provide a concise way to write first-class anonymous function values. Compare the following C# 2.0 snippet: listOfFoo.Where(delegate(Foo x) { return x.Size > 10; });
with this C# 3.0 equivalent: listOfFoo.Where(x => x.Size > 10);
In the above examples, lambda expressions are merely shorthand syntax for anonymous delegates with type inference for parameters and return type. However, depending on the context they are used in, a C# compiler can also transform lambdas into ASTs that can then be processed at run-time. In the example above, if Expression treesExpressions, such as Automatic propertiesThe compiler generates a private instance variable and the appropriate accessor and mutator given code such as: public string Name { get; private set; }
Extension methodsDevelopers may use extension methods to add new methods to the public contract of an existing CLR type, without having to sub-class it or recompile the original type. In reality, extension methods are a form of syntactic sugar that provide the illusion of adding new methods to the existing class outside its definition. The illusion is achieved with the definition of a static method that is callable as if it were an instance method, where the receiver of the call (i.e., the instance) is bound to the first parameter of the method, decorated with keyword The requirements for an extension method are as follows:
This example class demonstrates the definition and use of a public static class StringExtensions
{
public static string Left(this string s, int n)
{
return s.Substring(0, n);
}
}
string s = "foo bar";
s.Left(3); // same as StringExtensions.Left(s, 3), which returns "foo";
Partial methodsPartial methods allow code generators to generate method declarations as extension points that are only included in the compilation if someone actually implements them in another portion of a partial class.[7] References
External links |