Skip to main content

Specialized Collections in .Net



Namespace: System.Collections.Specialized

Working with Bits:
.Net Framework provides us with two collections namely BitArray and BitVector32 to manipulate bits.

BitArray is resizable, but not dynamically resizable collection. One must specify the size to the constructor. BitVector32 is fixed size collection that provides the Complex operations over the underlying int32.

One can perform operations like and, not, or, and exclusive-or on BitArray. BitArray allows the direct access to the bits while BitVector32 allows you to create masks for each bit then access those bits.

BitArray V = new BitArray(2);                      BitArray V2 = new BitArray(2);
V[0] = false;                                                                        V[0] = false;
V[1] = true;                                                                         V[1] = false;

V = V.Xor(V2);
foreach(bool bit in V) Consolse.WriteLine(V);

Using BitVector32.

BitVector32 bv = new BitVector32();
int Bit1 = bv.CreateMask();
int Bit2 = bv.CreateMask(Bit1);
bv[Bit1] = true;
bv[Bit2] = false;

Bit Packing with BitVector32:

One can create section within a BitVector32 to store small values. Like

BitVector32.Section section1 = BitVector32.CreateSection(10);
BitVector32.Section section2 = BitVector32.CreateSection(50, section1);

BitVector32 packedBits = new BitVector32(0);
packedBits [section1] = 7;
packedBits [section2] = 41;

Console.WriteLine(packedBits [section1]);
Console.WriteLine(packedBits [section2]);
Console.WriteLine(packedBits);

StringCollection Class:
This class is just like ArrayList. It extends from IList interface. But it allows only strings to be added and retrieved. It saves the overhead involved in boxing and unboxing.

StringDictionary Class:
StringDictionary is a typed version of dictionary collection. It can be used just like a HashTable except the Key and values must be a string.

Case-Insensitive Collection:
.Net Framework provides Case-Insensitive HashTable and SortedList. They can be created by using the static methods of the CollectionsUtil class.

HashTable iTable = CollectionsUtils.CreateCaseInsensitiveHashTable();
SortedList iList = CollectionsUtils.CreateCaseInsensitiveSortedList();

Culture Invariant Collection:
By default Collections use current threads’ culture, so comparisons depend upon the rule of the current culture for ordering and uniqueness. Culture-Invariant Collection can be created by passing in the Invariant implementation of the Comparer interface. Like:

HashTable invTable = new HashTable(StringComparer.InvariantCulture);
SortedList invList = new SortedList (StringComparer.InvariantCulture);

The NameValueCollection class:
It inherits from abstract NameObjectCollectionBase class. It is similar to StringDictionary class except that NameValueCollection allows multiple values against a key and it also supports retrieve of items by index.

NameValueCollection nvc = new NameValueCollection();
Nvc.Add(“a”, “some value”);
Nvc.Add(“a”, “more value”);
Foreach(string s in nvc.GetValues(“a”))
{
                Console.WriteLine(s);
}
Nvc.Add(“b”, “b value”);

for(int i=0;i<Nvc.Count;i++)
{
                for(int j=0;j<nvc.GetValues(Nvs.GetKey(i));j++)
                                Console.WriteLine(Nvc[i][j]);
}

Comments

Popular posts from this blog

Culture Information and Localization in .NET

Namespace: System.Globalization CultureInfo Class:                 It provides information like the Format of numbers and dates, Culture’s Calendar, Culture’s language and sublanguage (if applicable), Country and region of the culture. The Basic use of CultureInfo class is shown here: • How string Comparisons are performed • How Number Comparison & Formats are performed • Date Comparison and Formats. • How resources are retrieved and used. Cultures are grouped into three categories: Invariant Culture : It’s Culture Insensitive. It can be used to build some trial application. It can be also used to build an application with hard-coded expiry date that ignores cultures. But using it for every comparison will be incorrect and inappropriate. Neutral Culture : English(en), Frensh(fr), and Spanish(sp). A neutral culture is related to language but it’s not related to specific regi...

Concept of App Domain in .Net

Creating Application Domains: Application domain is just like process, provides separate memory space, and isolates from other code. But it’s quite light weight. It also provides the following advantages: 1-       Reliability : If a domain crashes, it can be unloaded. Hence doesn’t affect the other assemblies. 2-       Efficiency : Loading all assemblies in one domain can be cumbersome and can make the process heavy but Appdomains are efficient in this manner. Important properties of AppDomain: ApplicationIdentity , ApplicationTrust , BaseDirectory , CurrentDomain , DomainManager , DomainDirectory , Evidence , FriendlyName , ID , RelativeSearchPath , SetupInformation , ShadowCopyFiles . Important methods of AppDomain: ApplyPolicy , CreateCOMInstanceFrom , CreateDomain , CreateInstance (Assembly). To create an AppDomain: AppDomain adomain = AppDomain.CreateDomain(“D”); To execute an assembly:...

Asynchronous Execution in ASP.NET

Asynchronous Execution: Two ways either implement IHTTPAsyncHandler interface or in ASP.NET 2.0 set <%@ Page Async=”true” %>. The second option implements IHTTPAsyncHandler interface automatically for the page when parsed or compiled. AddOnPreRenderCompleteAsync ( new BeginEventHandler(BeginTask), new EndEventHandler(EndTask)); AddOnPreRenderCompleteAsync() shoud be called in Page_load. The BeginEventHandler and EndEventHandler are delegates defined as follows: IAsyncResult BeginEventHandler( object sender, EventArgs e, AsyncCallback cb, object state) void EndEventHandler( IAsyncResult ar) AsyncProcess starts and completes between PreRender and PreRenderComplete. Other way to perform Async Task is using AsyncPageTask structure. It also allows multiple tasks to execute simultaneously. void Page_Load (object sender, EventArgs e) { PageAsyncTask task = new PageAsyncTask( new BeginEventHandler(BeginTask), new EndEventH...