About C#
C# is an object oriented, event driven, strongly typed programming language. It is the language of preference for .NET developers. In fact, C# was used for much of the development of the .NET framework class libraries. The language is often considered similar to Java, C, and C++. It includes GUI development ability akin to Visual Basic, and object-oriented class libraries, like Java. Visual Studio is the preferred IDE for many C# programmers.
C# supports strongly typed variables with relatively few implicit conversions. Array bounds and variable initialization are checked for validity. Memory de-allocation is unnecessary as C# provides for automatic garbage collection. Safe object references are used to ensure all references are made to live objects or null objects. Random memory location access, as well as a dead pointer, is impossible.
Hello World Program
using namespace System;
class HelloWorld
{
public static void Main(string[] args)
{
Console.WriteLine("Hello World!");
}
}
Data Types and Variables
C# utilizes the common type system (CTS) of the .NET framework. These types are divided into two categories: Value types and Reference types. The following are the primitive value types:
- int
- char
- double
- char
- decimal
- bool
- byte
In addition to the primitive types, Classes, including user designed classes, structs, and enumerated types are also allowed. Type conversion must be done explicitly, usually through casting.
Variables in C# must be declared with a type and identifier. The type must be one of the primitive types or declared types from above. The identifier can be any unique string of alphabetic, numeric, and the underscore ('_') character. Identifiers may not begin with a number. Variables may also be initialized at declaration, but are not required to.
//integer declaration
int num;
//integer declaration and initialization
int num = 22;
C# supports implicitly typed variable declaration with the var keyword. The declared variable is assigned a type at compile time, and does not change (strongly typed).
//implicit variable declaration and initialization
var expr1 = 13 + (11 % 3);
var expr2 = 10.4 + (3 * 2);
In the code above the first variable declaration results in expr1 being declared with type int. In the second line of code expr2 is similarly declared as type double.
Statements
C# programs consist of a series of executable statements. Statements are often defined in terms of other embedded statements. A block allows a series of statements placed inside curly braces to replace a single statement. All statements must be separated by a semicolon. Spacing is not specified, but usually conforms to style much like that of Java. Statements can be any of the following:
- Declarations
- Expressions
- Selection Statements
- Iteration Statements
- Jump Statements
- Exception Handling
Declaration Statements
These statements are used to declare a local variable. Often this statement is used in conjunction with an immediate assignment of the declared variable.
int number; //variable declaration
const int NUMBER; //variable declared as a constant value
int number = 16; //variable declared and assigned value of 16
Expression Statements
Expression statements are used to evaluate expressions. Expressions that can be evaluated include arithmetic operations, assignments using =, as mentioned above, method calls, increment and decrement operations, and object allocations.
int number = 11; //assignments
number = (14 + 4) / 2; //arithmetic expression
Console.WriteLine("Output"); //method invocation
number++; //increment
object name = new object(); //memory allocation for a new instance of an object
Selection Statements
Selection statements, often called conditional statements, select an action based on the value of some condition. These statements allow programs to make decisions. C# utilizes two decision making structures: if (including if...else, and if...else if...else) and switch.
If statements test a condition, and only perform the following action when the condition is met. These statements can also be followed by an optional else statement whose contents is executed only if the condition is not met. If...else statements can be chained in the following form to test for a series of conditions: if...else if...else. Any number of 'else if' statements can be included.
if (number > 5)
Console.WriteLine("The number is larger than five");
if (number > 5)
Console.WriteLine("The number is larger than five");
else
Console.WriteLine("The number is smaller than five");
if (number < 3)
Console.WriteLine("The number is small.");
else if (number < 7)
Console.WriteLine("The number is medium.");
else
Console.WriteLine("The number is large.");
Switch statements choose between a series of mutually exclusive options, based on the value of an evaluated expression. If the value of each case matches the value of the condition, statements that follow are executed. If nocase matches, a default reult may be provided. Each case ends with a break statement, which exits the switch construct.
int n = Result(expression); //n has a value calculated in the Result() method
switch (n)
{
case 0:
Console.WriteLine("Result = 0");
break;
case 1:
Console.WriteLine("Reslut = 1");
break;
default:
Console.WriteLine("Result non-binary");
break;
}
Iteration Statements
Iteration statements, often called loops, are those which allow a statement, or a block of statements, to be repeated. C# has a number of different iteration statements, each for different applications. While, for, and foreach will be discussed here.
While statements allow a block to be repeated until a condition is met. Each pass through the loop begins with an evaluation of a conditional expression. If the expression evaluates to true, the actions contained in the loop are executed, then the loop starts over. A do statement may be added at the beginning to ensure the loop executes at least once.
int i = 64;
while (i > 8)
{
i = i / 2;
}
For loops are constructed to iterate over a loop a specific number of times. A for command contains the iterator variable, often i or j, the condition to evaluate, and some sort of modification of the iterator, usually an increment or decrement.
for (int i = 0; i < 100; i++)
{
total += i;
}
The final iteration statement, foreach, iterates a block of code over the members of a collection. This is often used to perform a calculation on all members of a specified or calculated list, without the necessity of knowing the length ofthe collection.
foreach (string word in A) //assume string[] A has been
{ //has been previously defined
result += string;
}
Jump Statements
Jump statements transfer control to another portion of the program. Previously, we have seen break used to end a switch statement. Its counterpart, continue, is used when a potential outcome of a selection results in no code to execute. Also commonly used is return, which sends control back to where a method was called.
Exception Handling
These statements are used to isolate a portion of code and allow runtime exceptions to be handled programmatically, rather than cause termination. In C#, try, catch, throw, and finally are used for exception handling.
Object-Oriented Features
C# is designed to be object-oriented. A class structure defines the language. All statements must be part of a class. Classes can inherit from another class, but may only inherit from one class. Abstract classes may be defined. Classes inheriting from these must implement all methods declared in the abstract class. Methods may be overridden in inherited classes and virtual methods requiring implementation may be declared.
Interfaces can be used to force common functionality onto a class. They contain only the signature of members that must be implemented by any class that implements the interface. A class can implement any number of interfaces. The .NET framework relies heavily on interfaces to provide common functionality to many of its included classes.
Polymorphism is achieved not only through overriding inherited class members, but also through generics. Generic classes or methods use one definition to operate on multiple types. For example, Stack<T>, defines a stack structure that can accomodate any type, indicated by T.
Windows Programming
C#, used in conjunction with Visual Studio allows for easy drag-and-drop construction of Windows programs with interactive graphical user interfaces, much like in Visual Basic. The System.Windows.Forms namespace contains many classes for Windows Form control. Included among these are the typical button, label, and textbox controls familiar to Windows users.
Windows applications are usually event-driven. Rather than execute code sequentially, these applications remain in a process loop and execute sections of code based on events such as mouse clicks, data entry, and clock-based events. When an event is registered, a method known as an event-handler is executed. These event-handlers can range from very simple, to extremely complex, and may update properties, data, or invoke other methods. After completion, control is returned to the process loop to execute the next event, or wait for an event to be registered.
Web Programming
Web applications are developed using Active Server Pages, or ASP.NET. Drag-and-drop GUI design is done similarly to Windows programs, with use of the many control classes familiar to web users. Web applications are usually event-driven as well to allow much user interaction.
Web programs are executed in a browser, such as Chrome or Firefox. The browser interprets an HTML, Hyper-Text Markup Language, file, and renders the content to be viewed. More precisely, ASP.NET uses XHTML, rather than HTML, with the X meaning extensible. This platform allows both client-side scripting and processing done on the server. Client-side processing occurs with embedded scripts using a scripting language, most commonly JavaScript.
When a web page is desired, a request is sent to the server, where the files are stored, which sends a response to the client that includes the mark-up code for the web page. When an action like filling out a form field or clicking a button requires action from the application a new request is sent to the server to process and return to the client. Each subsequent update requires a similar round-trip to the server. Server side processing uses C# to execute program logic at the server to be sent to the client.
ADO.NET
ADO.NET stands for ActiveX Data Objects for .NET. These classes are used for interaction with databases, including Microsoft Access, Oracle, and SQL Server. ADO.NET uses a feature called data providers to allow access to multiple database architecture. Each data provider implements many classes to retrieve, manipulate, and update data. The following are core classes that make up each ADO.NET data provider:
- Connection
- Command
- DataReader
- DataAdapter
The Connection class is used to instantiate a connection object based on the type of database being referenced. A platform specific connection string is required along with a data source. This object then represents an open database connection. The Command class holds a SQL statement used for data retrieval. DataReader classes retrieve rows from a database using its connection and command objects. DataAdapter objects exhange data between data sources and the dataset, which is the in-memory representation of the data.
Other classes and objects beyond the core classes are available as well. These, in fact, barely scratch the surface of datbase operations using C#. One of these, the DataGridView class, is widely used to format and display data in a familiar row and column structure for Windows Forms.
LINQ
LINQ, or Language Integrated Query, is a way to query over a collection. Using queries natural to relational databases in the programming language allows data manipulation independently of data sources. In other words, the differences in database systems are smoothed out by writing queries in (usually) server side code.
Queries can also be written against collections of objects. Any data type
that implements the IEnumerable
C# maintains a number of contextual keywords to facilitate these operations. In other circumstances they are not considered keywords, but in a query the following keywords are also recognized:
- from
- select
- where
- equals
- in
- on
- into
- let
- join
- orderby
- group
- by
- ascending
- descending