SIGN UP MEMBER LOGIN:    
ARTICLE

Creating C# Class Library (DLL) Using Visual Studio .NET

Posted by Mahesh Chand Articles | Articles December 09, 2000
This tutorial explains how to create a C# class library(dll) and call it from a C# console client application.
Reader Level:
Download Files:
 

Creating a DLL using Visual C# is piece of cake. Believe me its much easier than VC++. I have divided this tutorial in two parts. 1. Building a Class Library, and 2. Building a client application to test the DLL.

Part 1: Creating a Class Library (DLL)

Create an Empty Class Library Project

Select File->New->Project->Visual C# Projects->Class Library. Select your project name and appropriate directory using Browse button and click OK. See Figure 1.

Figure 1.

Project and Its files

The Solution Explorer adds two C# classes to your project. First is AssemblyInfo.cs and second is Class1.cs.  We don't care about AssemblyInfo. We will be concentrating on Class1.cs. See Figure 2.

Figure 2.

The mcMath Namespace

When you double click on Class1.cs, you see a namespace mcMath. We will be referencing this namespace in our clients to access this class library.

using System;

namespace
mcMath
{

///
<summary>

///
Summary description for Class1.
/// </summary>

public class
Class1
{

public
Class1()
{
//
// TODO: Add constructor logic here
//
}
}
}

Now build this project to make sure every thing is going OK. After building this project, you will see mcMath.dll in your project's bin/debug directory. 

Adding Methods 

Open ClassView from your View menu. Right now it displays only Class1 with no methods and properties. Lets add one method and one property. See Figure 3.

Figure 3.

Right click on Class1->Add->Add Method...  See Figure 4.

Figure 4.

C# Method Wizard pops up. Add your method name, access type, return type, parameters, and even comments.  Use Add and Remove buttons to add and remove parameters from the parameter list respectively. I add one test method called mcTestMethod with no parameters. See Figure 5.

Figure 5.

I am adding one more method long Add( long val1, long val2 ). This method adds two numbers and returns the sum. Click Finish button when you're done. See Figure 6.

Figure 6.

The above action adds two method to the class and methods look like following listing:

/// <summary>
/// //This is a test method
/// </summary>
public void mcTestMethod()
{  
}

public long
Add(long val1, long val2)
{  
}

Adding Properties

Open C# Property Wizard in same manner as you did in the case of method and add a property to your class. See Figure 7.

Figure 7.

This action launches C# Property Wizard. Here you can type your property name, type and access. You also have options to choose from get only, set only or get and set both. You can even select if a property is static or virtual. I add a property Extra with public access and bool type and get/set option set. See Figure 8.

Figure 8.

After adding a method and a property, our class looks like Figure 9 in Class View after expanding the class node.

Figure 9.

If you look your Class1 class carefully, Wizards have added two functions to your class. 

/// <summary>
/// //This is a test property
/// </summary>
public bool Extra
{
get
{
return true;
}
set
{
}
}

Adding Code to the Class 

Add this code ( bold ) to the methods and property now. And now I want to change my Class1 to mcMathComp because Class1 is quite confusing and it will create problem when you will use this class in a client application. Make sure you change class name and its constructor both.

Note: I'm not adding any code to mcTestMethod, You can add any thing if you want.

using System;

namespace
mcMath
{

///
<summary>

///
Summary description for Class1.
/// </summary>

public class
mcMathComp
{
private bool bTest = false
;

public mcMathComp()
{
// TODO: Add constructor logic here
}

///
<summary>

///
//This is a test method
/// </summary>

public void
mcTestMethod()
{ }

public long Add(long val1, long val2)
{
return
val1 + val2;
}

/// <summary>
///
//This is a test property
/// </summary>

public bool
Extra
{
get

{
return
bTest;
}
set

{
bTest = Extra ;
}
}
}
}

Build the DLL

Now build the DLL and see bin\debug directory of your project. You will see your DLL. Piece of cake? Huh? :). 

Part 2: Building a Client Application

Calling methods and properties of a DLL from a C# client is also an easy task. Just follow these few simple steps and see how easy is to create and use a DLL in C#.

Create a Console Application 

Select File->New->Project->Visual C# Projects->Console Application. I will test my DLL from this console application. See Figure 10.

Figure 10.

Add Reference of the Namespace

Now next step is to add reference to the library. You can use Add Reference menu option to add a reference. Go to Project->Add reference. See Figure 11.

Figure 11.

Now on this page, click Browse button to browse your library. See Figure 12.

Figure 12.

Browse for your DLL, which we created in part 1 of this tutorial and click Ok. See Figure 13.

Figure 13.

Add Reference Wizard will add reference of your library to the current project. See Figure 14.

Figure 14.

After adding reference to mcMath library, you can see it as an available namespace references. See Figure 15.

Figure 15.

Call mcMath Namespace, Create Object of mcMathComp and call its methods and properties.

You are only one step away to call methods and properties of your component. You follow these steps:

1. Use namespace

Add using mcMath in the beginning for your project.

using mcMath;

2. Create an Object of mcMathComp

mcMathComp cls = new mcMathComp();

3. Call Methods and Properties

Now you can call the mcMathComp class method and properties as you can see I call Add method and return result in lRes and print out result on the console.

mcMathComp cls = new mcMathComp();
long lRes = cls.Add( 23, 40 );
cls.Extra = false;
Console.WriteLine(lRes.ToString());

Now you can print out the result.

The entire project is listed in the following Listing:

using System;
using mcMath;

        namespace
mcClient
{
/// <summary>
/// Summary description for Class1.
/// </summary>

        class
Class1
{

        ///
<summary>
/// The main entry point for the application.
/// </summary>
[STAThread]
static void Main(string[] args)
{
mcMathComp cls = new mcMathComp();
long lRes = cls.Add( 23, 40 );
cls.Extra = false;
Console.WriteLine(lRes.ToString());
}
}
}

Now build and run the project. The output looks like Figure 16.

Figure 16.

share this article :
post comment
 

Hello, Mr. Chand I am working on a Window CE based project. I wnat to call a compact .NET DLL method from a compact .NET application both are on our handheld device. And the DLL resides in a folder different from the one where the application resides. I am developing the DLL and application on a desktop computer. When I build the application, I can use reference to the DLL. But on the device, how will I be able to load the DLL and call the method when the DLL is in a obscure folder. If I use Aseembly.LoadFrom() and then what can I do with it to call a method called aDLLMethod() of the DLL. Jun

Posted by Jun Apr 03, 2012

hi i want import a dll file to my program.(note that i want import a external dll file to program, no build a dll file or class library in c#)

Posted by yaquza yaquza Oct 25, 2011

d

Posted by mani honey Jul 06, 2011

Very very good article very helpful....

Posted by Gaurav Kumar Jun 04, 2011

Hello Mahesh, Great article and easy example that helps to grasp a cool development idea. MS themselves do not have such thing although it would not hurt. Please help in my thinking. Say I have in development one class library project and one web application project. After adding reference in my Web App to the Class Libr Project I can see a copy of the Cl Li Pr's DLL into the Web App's Bin folder. Now, when I go to deploy my Web App to the Production Server - Do I need anything else exept that that DLL into my Web App's Bin folder. Is there something that shuld be doen with the original CLP. Does it just stay and help only on the Dev side. If I make some changes into the CLP (say that do not break the external methods' structure) can I just replace the CLP's DLL on the Prod server or again I need to replace both Web App's DLL with the CLP's DLL. Thank you very much.

Posted by ILIIA CHTEREV Mar 24, 2011
Team Foundation Server Hosting
Become a Sponsor
PREMIUM SPONSORS
  • Finally – a virtual platform that delivers next-generation Windows Server 2008 Hyper-V virtualization technology from a managed hosting partner you can truly depend on. Visit www.maximumasp.com/max for a FREE 30 day trial. Hurry offer ends soon. Climb aboard the MaxV platform and take advantage of High Availability, Intelligent Monitoring, Recurrent Backups, and Scalability – with no hassle or hidden fees. As a managed hosting partner focused solely on Microsoft technologies since 2000, MaximumASP is uniquely qualified to provide the superior support that our business is built on. Unparalleled expertise with Microsoft technologies lead to working directly with Microsoft as first to offer IIS 7 and SQL 2008 betas in a hosted environment; partnering in the Go Live Program for Hyper-V; and product co-launches built on WS 2008 with Hyper-V technology.
    The leading .NET charting control now features PDF, Flash and Silverlight export, visualization of large datasets and more. Deliver true charting functionality to your BI, Scorecard, Presentation or Scientific apps. Download evaluation now.
Nevron Gauge for SharePoint
Become a Sponsor