Subscribe

RSS Feed (xml)

Powered By

Skin Design:
Free Blogger Skins

Powered by Blogger

Search Your Question

Monday, May 26, 2008

Dot Net Interview Questions - Part 4 Interview question

  1. What is the new three features of COM+ services, which are not there in COM (MTS)?
  2. Is the COM architecture same as .Net architecture? What is the difference between them?
  3. Can we copy a COM dll to GAC folder?
  4. What is Pinvoke?
    Platform invoke is a service that enables managed code to call unmanaged functions implemented in dynamic-link libraries (DLLs), such as those in the Win32 API. It locates and invokes an exported function and marshals its arguments (integers, strings, arrays, structures, and so on) across the interoperation boundary as needed.
  5. Is it true that COM objects no longer need to be registered on the server?
    Answer: Yes and No. Legacy COM objects still need to be registered on the server before they can be used. COM developed using the new .NET Framework will not need to be registered. Developers will be able to auto-register these objects just by placing them in the 'bin' folder of the application.
  6. Can .NET Framework components use the features of Component Services?
    Answer: Yes, you can use the features and functions of Component Services from a .NET Framework component.
  7. What are the OOPS concepts?
    1) Encapsulation: It is the mechanism that binds together code and data in manipulates, and keeps both safe from outside interference and misuse. In short it isolates a particular code and data from all other codes and data. A well-defined interface controls the access to that particular code and data.
    2) Inheritance: It is the process by which one object acquires the properties of another object. This supports the hierarchical classification. Without the use of hierarchies, each object would need to define all its characteristics explicitly. However, by use of inheritance, an object need only define those qualities that make it unique within its class. It can inherit its general attributes from its parent. A new sub-class inherits all of the attributes of all of its ancestors.
    3) Polymorphism: It is a feature that allows one interface to be used for general class of actions. The specific action is determined by the exact nature of the situation. In general polymorphism means "one interface, multiple methods", This means that it is possible to design a generic interface to a group of related activities. This helps reduce complexity by allowing the same interface to be used to specify a general class of action. It is the compiler's job to select the specific action (that is, method) as it applies to each situation.
  8. What is the difference between a Struct and a Class?
    • The struct type is suitable for representing lightweight objects such as Point, Rectangle, and Color. Although it is possible to represent a point as a class, a struct is more efficient in some scenarios. For example, if you declare an array of 1000 Point objects, you will allocate additional memory for referencing each object. In this case, the struct is less expensive.
    • When you create a struct object using the new operator, it gets created and the appropriate constructor is called. Unlike classes, structs can be instantiated without using the new operator. If you do not use new, the fields will remain unassigned and the object cannot be used until all of the fields are initialized.
    • It is an error to declare a default (parameterless) constructor for a struct. A default constructor is always provided to initialize the struct members to their default values.
    • It is an error to initialize an instance field in a struct.
    • There is no inheritance for structs as there is for classes. A struct cannot inherit from another struct or class, and it cannot be the base of a class. Structs, however, inherit from the base class Object. A struct can implement interfaces, and it does that exactly as classes do.
    • A struct is a value type, while a class is a reference type.
  9. Value type & reference types difference? Example from .NET. Integer & struct are value types or reference types in .NET?
    Most programming languages provide built-in data types, such as integers and floating-point numbers, that are copied when they are passed as arguments (that is, they are passed by value). In the .NET Framework, these are called value types. The runtime supports two kinds of value types:
    • Built-in value types
      The .NET Framework defines built-in value types, such as System.Int32 and System.Boolean, which correspond and are identical to primitive data types used by programming languages.
    • User-defined value types
      Your language will provide ways to define your own value types, which derive from System.ValueType. If you want to define a type representing a value that is small, such as a complex number (using two floating-point numbers), you might choose to define it as a value type because you can pass the value type efficiently by value. If the type you are defining would be more efficiently passed by reference, you should define it as a class instead.

Variables of reference types, referred to as objects, store references to the actual data. This following are the reference types:

    • class
    • interface
    • delegate

This following are the built-in reference types:

    • object
    • string
  1. What is Inheritance, Multiple Inheritance, Shared and Repeatable Inheritance?
  2. What is Method overloading?
    Method overloading occurs when a class contains two methods with the same name, but different signatures.
  3. What is Method Overriding? How to override a function in C#?
    Use the override modifier to modify a method, a property, an indexer, or an event. An override method provides a new implementation of a member inherited from a base class. The method overridden by an override declaration is known as the overridden base method. The overridden base method must have the same signature as the override method.
    You cannot override a non-virtual or static method. The overridden base method must be virtual, abstract, or override.
  4. Can we call a base class method without creating instance?
    Its possible If its a static method.
    Its possible by inheriting from that class also.
    Its possible from derived classes using base keyword.
  5. You have one base class virtual function how will call that function from derived class?
    class a
   {
      public virtual int m()
      {
         return 1;
      }
   }
   class b:a
   {
      public int j()
      {
         return m();
      }
}
  1. In which cases you use override and new base?
    Use the new modifier to explicitly hide a member inherited from a base class. To hide an inherited member, declare it in the derived class using the same name, and modify it with the new modifier.

---C# Language features---

  1. What are Sealed Classes in C#?
    The sealed modifier is used to prevent derivation from a class. A compile-time error occurs if a sealed class is specified as the base class of another class. (A sealed class cannot also be an abstract class)
  2. What is Polymorphism? How does VB.NET/C# achieve polymorphism?
  3. class Token
   {
      public string Display()
      {
       //Implementation goes here
       return "base";
      }
   }
   class IdentifierToken:Token
   {
      public new string Display() //What is the use of new keyword
      {
       //Implementation goes here
       return "derive";
      }
   }
      static void Method(Token t)
      {
        Console.Write(t.Display());
      }
      public static void Main()
      {
        IdentifierToken Variable=new IdentifierToken();
        Method(Variable); //Which Class Method is called here
        Console.ReadLine();
      }
For the above code What is the "new" keyword and Which Class Method is called here

Ans: it will call base class Display method

 
       class Token
       {
         public virtual string Display()
         {
          //Implementation goes here
          return "base";
         }
       }
       class IdentifierToken:Token
       {
         public override string Display() //What is the use of new keyword
         {
          //Implementation goes here
          return "derive";
         }
       }
       static void Method(Token t)
       {
         Console.Write(t.Display());
       }
       public static void Main()
       {
         IdentifierToken Variable=new IdentifierToken();
         Method(Variable); //Which Class Method is called here
         Console.ReadLine();
       }

A: Derive

  1. In which Scenario you will go for Interface or Abstract Class?
    Interfaces, like classes, define a set of properties, methods, and events. But unlike classes, interfaces do not provide implementation. They are implemented by classes, and defined as separate entities from classes. Even though class inheritance allows your classes to inherit implementation from a base class, it also forces you to make most of your design decisions when the class is first published.
    Abstract classes are useful when creating components because they allow you specify an invariant level of functionality in some methods, but leave the implementation of other methods until a specific implementation of that class is needed. They also version well, because if additional functionality is needed in derived classes, it can be added to the base class without breaking code.

Feature

Interface

Abstract class

Multiple inheritance

A class may implement several interfaces.

A class may extend only one abstract class.

Default implementation

An interface cannot provide any code at all, much less default code.

An abstract class can provide complete code, default code, and/or just stubs that have to be overridden.

Constants

Static final constants only, can use them without qualification in classes that implement the interface. On the other paw, these unqualified names pollute the namespace. You can use them and it is not obvious where they are coming from since the qualification is optional.

Both instance and static constants are possible. Both static and instance intialiser code are also possible to compute the constants.

Third party convenience

An interface implementation may be added to any existing third party class.

A third party class must be rewritten to extend only from the abstract class.

is-a vs -able or can-do

Interfaces are often used to describe the peripheral abilities of a class, not its central identity, e.g. an Automobile class might implement the Recyclable interface, which could apply to many otherwise totally unrelated objects.

An abstract class defines the core identity of its descendants. If you defined a Dog abstract class then Damamation descendants are Dogs, they are not merely dogable. Implemented interfaces enumerate the general things a class can do, not the things a class is.

Plug-in

You can write a new replacement module for an interface that contains not one stick of code in common with the existing implementations. When you implement the interface, you start from scratch without any default implementation. You have to obtain your tools from other classes; nothing comes with the interface other than a few constants. This gives you freedom to implement a radically different internal design.

You must use the abstract class as-is for the code base, with all its attendant baggage, good or bad. The abstract class author has imposed structure on you. Depending on the cleverness of the author of the abstract class, this may be good or bad. Another issue that's important is what I call "heterogeneous vs. homogeneous." If implementors/subclasses are homogeneous, tend towards an abstract base class. If they are heterogeneous, use an interface. (Now all I have to do is come up with a good definition of hetero/homogeneous in this context.) If the various objects are all of-a-kind, and share a common state and behavior, then tend towards a common base class. If all they share is a set of method signatures, then tend towards an interface.

Homogeneity

If all the various implementations share is the method signatures, then an interface works best.

If the various implementations are all of a kind and share a common status and behavior, usually an abstract class works best.

Maintenance

If your client code talks only in terms of an interface, you can easily change the concrete implementation behind it, using a factory method.

Just like an interface, if your client code talks only in terms of an abstract class, you can easily change the concrete implementation behind it, using a factory method.

Speed

Slow, requires extra indirection to find the corresponding method in the actual class. Modern JVMs are discovering ways to reduce this speed penalty.

Fast

Terseness

The constant declarations in an interface are all presumed public static final, so you may leave that part out. You can't call any methods to compute the initial values of your constants. You need not declare individual methods of an interface abstract. They are all presumed so.

You can put shared code into an abstract class, where you cannot into an interface. If interfaces want to share code, you will have to write other bubblegum to arrange that. You may use methods to compute the initial values of your constants and variables, both instance and static. You must declare all the individual methods of an abstract class abstract.

Adding functionality

If you add a new method to an interface, you must track down all implementations of that interface in the universe and provide them with a concrete implementation of that method.

If you add a new method to an abstract class, you have the option of providing a default implementation of it. Then all existing code will continue to work without change.

 
Q:1     interface ICommon
     {
      int getCommon();
     }
     interface ICommonImplements1:ICommon
     {
     }
     interface ICommonImplements2:ICommon
     {
     }
     public class a:ICommonImplements1,ICommonImplements2
     {
        }

How to implement getCommon method in class a? Are you seeing any problem in the implementation?

        public class a:ICommonImplements1,ICommonImplements2
  {
   public int getCommon()
   {
    return 1;
   }
  }
 
Q:2     interface IWeather
     {
       void display();
     }
     public class A:IWeather
     {
       public void display()
       {
         MessageBox.Show("A");
       }
     }
     public class B:A
     {
     }
     public class C:B,IWeather
     {
       public void display()
       {
         MessageBox.Show("C");
       }
     }

When I instantiate C.display(), will it work?

Q:3     interface IPrint
     {
       string Display();
     }
     interface IWrite
     {
       string Display();
      }
      class PrintDoc:IPrint,IWrite
      {
       //Here is implementation
      }

how to implement the Display in the class printDoc (How to resolve the naming Conflict)

Ans: no naming conflicts

   class PrintDoc:IPrint,IWrite
   {
     public string Display()
     {
      return "s";
     }
    }
 
Q:4     interface IList
      {
        int Count { get; set; }
      }
      interface ICounter
      {
        void Count(int i);
      }
      interface IListCounter: IList, ICounter {}
      class C
      {
        void Test(IListCounter x)
        {
          x.Count(1);                // Error
          x.Count = 1;               // Error
          ((IList)x).Count = 1;      // Ok, invokes IList.Count.set
          ((ICounter)x).Count(1);    // Ok, invokes ICounter.Count
        }
      }
Write one code example for compile time binding and one for run time binding? What is early/late binding?
An object is early bound when it is assigned to a variable declared to be of a specific object type. Early bound objects allow the compiler to allocate memory and perform other optimizations before an application executes.
' Create a variable to hold a new object.
Dim FS As FileStream
' Assign a new object to the variable.
FS = New FileStream("C:\tmp.txt", FileMode.Open)
By contrast, an object is late bound when it is assigned to a variable declared to be of type Object. Objects of this type can hold references to any object, but lack many of the advantages of early-bound objects.
Dim xlApp As Object
xlApp = CreateObject("Excel.Application")

Dot Net Interview Questions - Part 3

  1. What is the difference between CONST and READONLY?
    Both are meant for constant values. A const field can only be initialized at the declaration of the field. A readonly field can be initialized either at the declaration or in a constructor. Therefore, readonly fields can have different values depending on the constructor used.
    readonly int b;
    public X()
    {
    b=1;
    }
    public X(string s)
    {
    b=5;
    }
    public X(string s, int i)
    {
    b=i;
    }

    Also, while a const field is a compile-time constant, the readonly field can be used for runtime constants, as in the following example:

    public static readonly uint l1 = (uint) DateTime.Now.Ticks;
    (this can't be possible with const)
  2. What is the difference between ref & out parameters?
    An argument passed to a ref parameter must first be initialized. Compare this to an out parameter, whose argument does not have to be explicitly initialized before being passed to an out parameter.
  3. What is the difference between Array and LinkedList?
  4. What is the difference between Array and Arraylist?
    As elements are added to an ArrayList, the capacity is automatically increased as required through reallocation. The capacity can be decreased by calling TrimToSize or by setting the Capacity property explicitly.
  5. What is Jagged Arrays?
    A jagged array is an array whose elements are arrays. The elements of a jagged array can be of different dimensions and sizes. A jagged array is sometimes called an "array-of-arrays."
  6. What are indexers?
    Indexers are similar to properties, except that the get and set accessors of indexers take parameters, while property accessors do not.
  7. What is Asynchronous call and how it can be implemented using delegates?
  8. How to create events for a control? What is custom events? How to create it?
  9. If you want to write your own dot net language, what steps you will u take care?
  10. Describe the difference between inline and code behind - which is best in a loosely coupled solution?
  11. how dot net compiled code will become platform independent?
  12. without modifying source code if we compile again, will it be generated MSIL again?
  13. C++ & C# differences

  1. Interop Services?
    The common language runtime provides two mechanisms for interoperating with unmanaged code:
    • Platform invoke, which enables managed code to call functions exported from an unmanaged library.
    • COM interop, which enables managed code to interact with COM objects through interfaces.

Both platform invoke and COM interop use interop marshaling to accurately move method arguments between caller and callee and back, if required.

  1. How does u handle this COM components developed in other programming languages in .NET?
  2. What is RCW (Runtime Callable Wrappers)?
    The common language runtime exposes COM objects through a proxy called the runtime callable wrapper (RCW). Although the RCW appears to be an ordinary object to .NET clients, its primary function is to marshal calls between a .NET client and a COM object.
  3. What is CCW (COM Callable Wrapper)

A proxy object generated by the common language runtime so that existing COM applications can use managed classes, including .NET Framework classes, transparently.

  1. How CCW and RCW is working?
  2. How will you register com+ services?
    The .NET Framework SDK provides the .NET Framework Services Installation Tool (Regsvcs.exe - a command-line tool) to manually register an assembly containing serviced components. You can also access these registration features programmatically with the System.EnterpriseServicesRegistrationHelper class by creating an instance of class RegistrationHelper and using the method InstallAssembly
What is use of ContextUtil class?
ContextUtil is the preferred class to use for obtaining COM+ context information.

No comments:

Archives