Windows IT Pro is the authoritative and independent resource for windows nt, windows 2000, windows 2003, windows xp. Features a collection of resources and magazines for windows IT professionals.
  
  
  Advanced Search 


July 11, 2002

Assemblies in .NET Applications


RSS
Subscribe to Windows IT Pro | See More .NET Articles Here | Reprints | Or get the Monthly Online Pass—only $5.95 a month!

How .NET Applications organize the code they use

I'm still sorting through replies to my call for real-world .NET applications. (If you've got more, email them to me and add to the pile.) While I'm doing that, let's take a look at how .NET applications organize the code they use. Logically, the .NET organizational unit (OU) is the namespace. Physically, the OU is the assembly.

Let's start with assemblies. I touched on the assembly concept in a previous column. An assembly is a collection of types and resources, typically stored as a single .exe or .dll file. (Technically, an assembly can span more than one file, but most assemblies don't.) All types in the .NET Framework must exist in assemblies; the Common Language Runtime (CLR) doesn't support types outside of assemblies. Also, all the types defined in a single assembly are unique to that assembly; a type can have the same name as another type, but if those types are in different assemblies, they're not the same. Each time you create any kind of application or service with Visual Basic .NET, you're building an assembly. Assemblies can be static or dynamic.

An assembly isn't just a file with executable code, however: It's also the tool you use to establish security, type identity, reference, version, and deployment boundaries for the application. The assembly's manifest stores all this information.

The security boundaries in the manifest specify the (optional) rules under which an assembly can run. By default, assemblies aren't secured, but the .NET Framework supports two mechanisms for assembly security. First, signing an assembly with a strong name adds public key encryption to the assembly, which lets you make sure that the code is what you think it is and hasn't been replaced by another assembly with the same name. Second, you can protect an assembly with certificates, which gives you a greater degree of granularity over the security associated with the assembly. For example, a security policy for a particular secured assembly might let the assembly execute but not write to the hard disk.

To avoid name confusion, the type identity information associates a particular type's name with the assembly it belongs to. Think of the type name as the type's first name and the assembly name as the type's surname, which distinguishes it from other types with the same first name.

The reference scope information helps the assembly find types and resources outside the assembly and lists any other assemblies that the current one depends on. The version information describes any version dependencies for the assembly. The default settings for the version information ensure that the .NET application attempts to run only by using the files that it has been tested with, thus avoiding DLL mismatches.

Finally, the deployment information helps the application to be as thin as possible by downloading from the server only the components that the application needs to start. This setup is equivalent to your favorite word processor starting with only the pieces it needs to display and accept text, delaying loading a spell checker until you request that tool.

I've given you a high-level view of assemblies and the role of the manifest, and I'll refer to this information in future columns. Those columns will explore these functions in more detail.

End of Article



Reader Comments
Excellent coverage of material and doubts as this provides lot of information and queries solved.

Thank U

srinivas January 10, 2004


gfhfhgfh

Anonymous User December 25, 2004


good article.

Anonymous User May 17, 2005 (Article Rating: )


It is noty proper decsription of assemblies. It should cover about global assemblies also.


Anonymous User June 08, 2005 (Article Rating: )


best

Anonymous User July 15, 2005 (Article Rating: )


You must log on before posting a comment.

If you don't have a username & password, please register now.




Top Viewed ArticlesView all articles
No Jobs, No Excitement at Apple's Last Macworld Keynote

Apple CEO Steve Jobs made the right move in skipping out on his company's last appearance at Macworld: In a Tuesday keynote address at the conference, Apple had no interesting new products to sell, opting instead to spend mind-numbing amounts of time on ...

Where is Microsoft NetMeeting in Windows XP?

...

Command Prompt Tricks

One reader shares his tip for setting up the command prompt to reflect a remote path. ...


.NET Whitepapers Batch Job Scheduling and .NET in 2008

Related Events Top 11 Reasons Why Oracle Database 11g on Windows is Right For You

Check out our list of Free Email Newsletters!

Related .NET Resources Become a VIP member of the Windows IT Pro community!
Get it all with the VIP CD and VIP access. A $500+ value for only $279!

Subscribe to Windows IT Pro!
Solve your toughest technical problems with our experts and access 10,000 + articles online. 30% off

Monthly Online Pass - Only $5.95!
Get instant access to 10,000+ articles from Windows IT Pro Magazine!

TechNet Virtual Labs
Evaluate and test Microsoft's newest products.


Windows IT Pro Home Register FAQ for Windows WinInfo News
Europe Edition About Us Contact Us/Customer Service Media Kit Affiliates / Licensing  
SQL Server Magazine Office & SharePoint Pro Windows Dev Pro IT Job Hound ITTV
IT Library Technology Resource Directory Connected Home Windows Excavator Windows SuperSite 
 
 Windows IT Pro is a Division of Penton Media Inc.
 Copyright © 2009 Penton Media, Inc., All rights reserved. Terms and Use | Privacy Statement | Reprints and Licensing