Pages
Calender
<<  July 2010  >>
MoTuWeThFrSaSu
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678
Blogroll
    Pradeep Patel , Created On 10. June 2010, 19:05

     

    One of the unique features of C# is the concept of Partial, extendable to definition of a Class or a Struct, an Interface or a method.
    Using this, the definition of any class, struct, interface of method can exist in two or more source files. Each source file contains a section of the type or method definition, and all parts are combined when the application is compiled.

    To split a class definition, partial keyword modifier is used.

    For Example:

       1:      public partial class Pradeep
       2:      {
       3:          public void OnLeave()
       4:          {
       5:          }
       6:      }
       7:   
       8:      public partial class Pradeep
       9:      {
      10:          public void InMeeting()
      11:          {
      12:          }
      13:      }

    Here, it is valid to use the same name for the class and implement desired functionality separately.
    Finally, when compiled, the code is auto merged , giving a Final class named Pradeep, with the two methods that were defined separately.

    The partial keyword indicates that other parts of the class, struct, or interface can be defined in the namespace.
    Following are the points that need to be taken care of while working with Partial keyword.

    • All the parts must use the partial keyword.
    • All the parts must have the same accessibility, such as public, private, and so on.
    • All partial-type definitions meant to be parts of the same type must be defined in the same assembly and the same module (.exe or .dll file). Partial definitions cannot span multiple modules.
    • If any part is declared abstract, then the whole type is considered abstract.
    • If any part is declared sealed, then the whole type is considered sealed.
    • If any part declares a base type, then the whole type inherits that class.
    • Parts can specify different base interfaces, and the final type implements all the interfaces listed by all the partial declarations.
    • Nested types can be partial, even if the type they are nested within is not partial itself

    For Example:

        class LeaveReachTimings
        {
            partial class Residence
            {
                void TimetoReach() { }
            }
            partial class Office
            {
                void TimeToLeave() { }
            }
        }


    Here the Class LeaveReachTimings is not partial, but it is completely valid to declare partial classes Residence and Office as nested classes in it.

    • Attributes of partial-type definitions are merged

    For Example

        [SerializableAttribute]
        partial class CurrentCompany { }
    
        [Obsolete Attribute]
        partial class CurrentCompany { }
    
        These two attributes will finally merge and are equivalent to the following.
    
        [SerializableAttribute]
        [Obsolete Attribute]
        partial class CurrentCompany { }

    Enough of Theory Let us now create one partial Class to verify the concepts covered so far.

    Partial Class:

     

        public partial class Record
        {
            private int x;
            private int y;
    
            public Record(int x, int y)
            {
                this.x = x;
                this.y = y;
            }
        }
    
        public partial class Record
        {
            public int PrintSum()
            {
                return x + y;
            }
    
        }

    Partial Methods:

    Similar to Partial Classes, Partial Methods are also allowed. These are allowed in partial classes or struct.
    One part of class contains the signature and the same or other part of the partial class can contain its implementation.
    If no implementation is provided, then the method and all calls made to it are removed at compile time.

    Therefore, any code in the partial class can use a partial method, even if the implementation is not supplied. No compile-time or run-time errors will result if the method is called but not implemented.

    A partial method declaration consists of two parts: the definition, and the implementation. These may be in separate parts of a partial class, or in the same part.

    If there is no implementation declaration, then the compiler optimizes away both the defining declaration and all calls to the method.

    Following are the considerations with Partial Methods.

    • Partial method declarations must begin with the partial keyword
    • Return Type is always void.
    • out parameters are not allowed , however ref can be used.
    • Partial methods cannot be virtual as they are implicitly private.

    It means they have access modifiers such as public, private or internal. Hence, they cannot be called from outside the partial class, and cannot be declared as virtual.

    • Partial methods cannot be extern, because the presence of the body determines whether they are defining or implementing.
    • Partial methods can use static and unsafe modifiers.
    • Partial methods can be generic.
    • A delegate to a partial method which has an implementation, can be made. But, the partial method which has just a signature and no implementation can not have a delegate.


    Example:

        public partial class PartialClassTest
        {
            private string mytest = string.Empty;
    
            partial void MyPartialMethodTest();
    
        }
    
    
        public partial class PartialClassTest
        {
            partial void MyPartialMethodTest()
            {
                mytest = "Partial Method call Succeded!!";
    
            }
    
            public string returnstring()
            {
                MyPartialMethodTest();
                return mytest;
    
            }
        }

    Here the partial methods, always return void and to get the value of mytest string I have to declare yet another method(return string), which finally prints the string on the webpage if called as per the following code.

        protected void Page_Load(object sender, EventArgs e)
        {
            PartialClassTest ptest = new PartialClassTest();
            Response.Write(ptest.returnstring());
        }

    Please note: Delegate or Enumeration declarations can not use partial keyword.

    Hope this discussion was helpful.

    Till Next time we connect, Happy Coding!!!



    Ajander Singh , Created On 2. May 2010, 18:59

    About The Book
    Get expert guidance to exploit CLR capabilities and the Microsoft .NET Framework 4.0.

    Dig deep and master the intricacies of the common language runtime (CLR) and the .NET Framework 4.0. Written by a highly regarded programming expert and consultant to the Microsoft .NET team, this guide is ideal for developers building any kind of application—including Microsoft ASP.NET, Windows® Forms, Microsoft SQL Server®, Web services, and console applications. You’ll get hands-on instruction and extensive C# code samples to help you tackle the tough topics and develop high-performance applications.

    CLR VIA C# Jeffrey Richter

    About the Author: Jeffrey Richter

    Dig deep and master the intricacies of the common language runtime (CLR) and the .NET Framework 4.0. Written by a highly regarded programming expert and consultant to the Microsoft® .NET team, this guide is ideal for developers building any kind of application-including Microsoft® ASP.NET, Windows® Forms, Microsoft® SQL Server®, Web services, and console applications. You’ll get hands-on instruction and extensive C# code samples to help you tackle the tough topics and develop high-performance applications. It is October 2009 as I write this text, making it 10 years now that I’ve worked with the .NET Framework and C#. Over the 10 years, I have built all kinds of applications and, as a consultant to Microsoft, have contributed quite a bit to the .NET Framework itself. As a partner in my own company, Wintellect (http://Wintellect.com), I have worked with numerous customers to help them design software, debug software, performance-tune software, and solve issues they have with the .NET Framework. All these experiences have really helped me learn the spots that people have trouble with when trying to be productive with the .NET Framework. I have tried to sprinkle knowledge from these experiences through all the topics presented in this book.

    Information gathered from Microsoft Site or log on to http://www.microsoft.com/learning/en/us/books.aspx?ID=13874&Locale=en-us

    Publisher: Microsoft Press | ISBN: 0735627045 | Feb 2010 | PDF | 896 pages | 18.6 Mb

    Download: Here




    C# doesn't support multiple inheritances but it is been achieved using interfaces. A class in C# has the option to implement one or more interface(S). There is only one challenge when class implements multiple interfaces is that they may include methods with same name and signature as existing class members or other interfaces' members.

    Explicit interface implementation gives the ability to hide the details of an interface and it is only available by casting to the interface type. Explicit interface implementation can be used to disambiguate class members and interface members otherwise they will conflict.

    Lets take an example, If a class implements two interfaces that contain a member with the same signature, then implementing that member on the class will cause both interfaces to use that member as their implementation.

    interface IInterfaceA
     
    {
     
        void Paint();
     
    }
     
    interface IInterfaceB
     
    {
     
       void Paint();
     
    }
     
    class SampleClassA : IInterfaceA, IInterfaceB
     
    {
     
        // Both IInterfaceA.Paint and IInterfaceA.Paint call this method.
     
        public void Paint()
     
        {
     
        }
     
    }
     

    The class member IInterfaceA.Paint is only available through the IInterfaceA interface, and IInterfaceB.Paint is only available through IInterfaceB. Both method implementations are separate, and neither is available directly on the class. For example:

    SampleClass obj = new SampleClass();
    //obj.Paint();  // Compiler error.

    IInterfaceA c = (IInterfaceA)obj;
    c.Paint();  // Calls IInterfaceA.Paint on SampleClass.

    IInterfaceB s = (IInterfaceB)obj;
    s.Paint(); // Calls IInterfaceB.Paint on SampleClass.

    It is possible to implement an interface member explicitly. Create a class member that is only called through the interface, and is specific to that interface. This can be achieved by naming the class member with the name of the interface and a period. For example:

    public class SampleClass : IInterfaceA, IInterfaceB
     
    {
     
       void IInterfaceA.Paint()
     
       {
     
            System.Console.WriteLine("IInterfaceA.Paint");
     
       }
     
       void IInterfaceB.Paint()
     
       {
     
            System.Console.WriteLine("IInterfaceB.Paint");
     
       }
     
    }