Reflection.NET Support for Reflection. What is Reflection Reflection: the process by which a program can observe and modify its own structure and behavior.

Slides:



Advertisements
Similar presentations
Slide 11.1 Advanced Programming 2004, based on LY Stefanus’s Slides Reflection Reflection is the ability for a class or object to examine itself. Java.
Advertisements

CSE 1302 Lecture 8 Inheritance Richard Gesick Figures from Deitel, “Visual C#”, Pearson.
Creating Classes from Other Classes Chapter 2 Slides by Steve Armstrong LeTourneau University Longview, TX  2007,  Prentice Hall.
C#.NET C# language. C# A modern, general-purpose object-oriented language Part of the.NET family of languages ECMA standard Based on C and C++
1 Inheritance and Polymorphism. 2 Motivations Suppose you will define classes to model circles, rectangles, and triangles. These classes have many common.
.NET Attributes and Reflection “What a developer needs to know……” Dan Douglas Blog:
Differences between C# and C++ Dr. Catherine Stringfellow Dr. Stewart Carpenter.
OOP Languages: Java vs C++
Inheritance. Types of Inheritance Implementation inheritance means that a type derives from a base type, taking all the base type’s member fields and.
Programming Languages and Paradigms Object-Oriented Programming.
1 Classes- Inheritance Multiple Inheritance It is possible to derive a new class from more than one base class. This is called Multiple Inheritance. Under.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Taken from slides of Starting Out with C++ Early Objects Seventh Edition.
“is a”  Define a new class DerivedClass which extends BaseClass class BaseClass { // class contents } class DerivedClass : BaseClass { // class.
220 FINAL TEST REVIEW SESSION Omar Abdelwahab. INHERITANCE AND POLYMORPHISM Suppose you have a class FunClass with public methods show, tell, and smile.
Lecture 8 Inheritance Richard Gesick. 2 OBJECTIVES How inheritance promotes software reusability. The concepts of base classes and derived classes. To.
Lecture 9 Polymorphism Richard Gesick.
Kalpesh Padia Reflection in.Net. OVERVIEW 9/19/
Reflection in.Net Siun-Wai Seow. Objective Explain.NET Reflection When to use it? How to use it? Topic is in the final exam.
Introduction to Java Prepared by: Ahmed Hefny. Outline Classes Access Levels Member Initialization Inheritance and Polymorphism Interfaces Inner Classes.
All types in the CLR are self-describing – CLR provides a reader and writer for type definitions System.Reflection & System.Reflection.emit – You can ‘read’
Liang, Introduction to Java Programming, Ninth Edition, (c) 2013 Pearson Education, Inc. All rights reserved. 1 Chapter 11 Inheritance and Polymorphism.
Reflection Leveraging the Power of Metadata. Objectives Provide an introduction to.NET Reflection Explain how applications can use Reflection to explore.
Tuc Goodwin  Object and Component-Oriented Programming  Classes in C#  Scope and Accessibility  Methods and Properties  Nested.
ABHISHEK BISWAS.NET Reflection Dynamically Create, Find and Invoke Types.
Effective C# 50 Specific Way to Improve Your C# Item 42, 43.
An Object-Oriented Approach to Programming Logic and Design Chapter 3 Using Methods and Parameters.
OOP in Java : © W. Milner 2005 : Slide 1 Java and OOP Part 2 – Classes and objects.
Copyright 2006 Oxford Consulting, Ltd1 February Polymorphism Polymorphism Polymorphism is a major strength of an object centered paradigm Same.
Programming in Java CSCI-2220 Object Oriented Programming.
Module 14: Attributes. Overview Overview of Attributes Defining Custom Attributes Retrieving Attribute Values.
Inheritance. Inheritance - Introduction Idea behind is to create new classes that are built on existing classes – you reuse the methods and fields and.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All rights reserved Chapter 9 Inheritance and.
Attributes C#.Net Software Development Version 1.0.
Chapter 8 Class Inheritance and Interfaces F Superclasses and Subclasses  Keywords: super F Overriding methods  The Object Class  Modifiers: protected,
Introduction to Object-Oriented Programming Lesson 2.
CSI 3125, Preliminaries, page 1 Overloading Methods In Java it is possible to define two or more methods within the same class that share the same name,
CSCE 314 Programming Languages Reflection Dr. Hyunyoung Lee 1.
Interfaces F What is an Interface? F Creating an Interface F Implementing an Interface F What is Marker Interface?
Reflection Bibliografie: Sun: The Java Tutorials – The Reflection API IBM developerWorks:
Reflection Programming under the hood SoftUni Team Technical Trainers Software University
POLYMORPHISM Chapter 6. Chapter Polymorphism  Polymorphism concept  Abstract classes and methods  Method overriding  Concrete sub classes and.
Reflection Mehdi Einali Advanced Programming in Java 1.
Delivering Excellence in Software Engineering ® EPAM Systems. All rights reserved. Reflection and Attributes.
C# Fundamentals An Introduction. Before we begin How to get started writing C# – Quick tour of the dev. Environment – The current C# version is 5.0 –
.Net Reflection Taipan Tamsare. Overview Reflection core concepts Exploring metadata Detail information Attributes Building Types at runtime.
METADATA IN.NET Presented By Sukumar Manduva. INTRODUCTION  What is Metadata ? Metadata is a binary information which contains the complete description.
CHARLES UNIVERSITY IN PRAGUE faculty of mathematics and physics Advanced.NET Programming I 7 th Lecture Pavel Ježek
INTRODUCTION BEGINNING C#. C# AND THE.NET RUNTIME AND LIBRARIES The C# compiler compiles and convert C# programs. NET Common Language Runtime (CLR) executes.
Inheritance Modern object-oriented (OO) programming languages provide 3 capabilities: encapsulation inheritance polymorphism which can improve the design,
Modern Programming Tools And Techniques-I
NESTED CLASSES REFLECTION PROXIES.
Ch 10- Advanced Object-Oriented Programming Features
15: Object Object Programming C# © 2003 DevelopMentor, Inc. 12/1/2003.
Object-Oriented Programming
Reflection SoftUni Team Technical Trainers C# OOP Advanced
Reflection SoftUni Team Technical Trainers C# OOP Advanced
Advanced .NET Programming I 7th Lecture
Microsoft .NET 3. Language Innovations Pan Wuming 2017.
CS360 Windows Programming
Lecture 23 Polymorphism Richard Gesick.
Chapter 9 Inheritance and Polymorphism
Java Programming Language
Lecture 22 Inheritance Richard Gesick.
.NET and .NET Core 10. Enabling Contracts Pan Wuming 2017.
CIS 199 Final Review.
What is Reflection? Some Definitions….
What is Reflection? Some Definitions….
CSCE 314: Programming Languages Dr. Dylan Shell
Advanced .NET Programming I 8th Lecture
Static Binding Static binding chooses the function in the class of the base class pointer, ignoring any versions in the class of the object actually.
Presentation transcript:

Reflection.NET Support for Reflection

What is Reflection Reflection: the process by which a program can observe and modify its own structure and behavior at runtime. What kind of tasks are specific to Reflection: –Inspection: analyzing objects and types to gather information about their definition and behavior. Typically this is done with little or no prior knowledge about them. (For instance, in the.NET Framework, everything inherits from System.Object and an object-typed reference is the typical starting point for reflection.) –Manipulation: uses the information gained through inspection to invoke code dynamically, create new instances of discovered types, or even restructure types and objects on the fly Manipulating types and objects at run time incurs a performance penalty when compared to the equivalent operations done statically in the source code ! Reflective capabilities need language and compiler-support (vezi exemplul de la Reflection Pattern – curs sapt 6)

Introduction to.NET Reflection System.Reflection: namespace containing several types that allow to reflect over (parse) the metadata tables in assemblies What can you do by reflection ? –Enumerate modules and types of an assembly; –For each type, obtain its base type, implemented interfaces, fields, methods, properties, events –Create instances of types, dynamically invoke methods What you cannot do by reflection: –Get information from the reference metadata tables You could parse the assembly file directly to extract this type of information (as ILDASM does)

Where to use reflection ? Class libraries that need to understand a type’s definition: typical example – Serialization Late binding: the types and methods an application uses are not known at compile time; –example: application gets at runtime the names of an assembly and the name of a type contained in it. The application loads the assembly, constructs an instance of the type and calls methods on it.

The Reflection Logical Hierarchy Classes that implement metaobjects Class Type is defined in the namespace System. All others are defined in System.Reflection

Reflecting Over an Assembly’s Types public class Reflector { public static void ReflectOnAssembly(Assembly assem) { WriteLine(0, "Assembly: {0}", assem); // Find Modules foreach (Module m in assem.GetModules()) { WriteLine(1, "Module: {0}", m); // Find Types foreach (Type t in m.GetTypes()) { WriteLine(2, "Type: {0}", t); // Find Members foreach (MemberInfo mi in t.GetMembers()) WriteLine(3, "{0}: {1}", mi.MemberType, mi); } … } [Richter] – ex. Chap. 20 Example: starting from an Assembly metaobject, we can determine the modules that it contains. For each module, we can determine the types defined there. C#

Get a reference to the executing assembly using System; using System.Reflection; class App { static void Main() { Assembly assem = Assembly.GetExecutingAssembly(); Reflector.ReflectOnAssembly(assem); } public class Reflector { … } [Richter] – ex. Chap. 20 Determines which assembly contains the method that’s making the call and returns its metaobject C#

Explicitly Loading Assemblies using System; using System.Reflection; class App { static void Main(string[] args) { Console.WriteLine("Loading assembly: {0}",args[0]); Assembly a = Assembly.LoadFile(args[0]); Reflector.ReflectOnAssembly(a); } public class Reflector { … } Loads an assembly specified by the name of its file. The assembly is loaded as a ”data file” C#

Obtaining a Reference to a System.Type Object Reflection can be used to learn about types or to manipulate objects using information available only at runtime, not at compile time How to obtain a reference to a System.Type object: –From a System.Object : defines a method GetType which determines the type of the specified object and returns a reference to its metaobject –From System.Type: defines a static method GetType(String Name) which checks the calling assembly for the defined type and returns a reference to its metaobject –From System.Module as presented in the example before What can you do with this reference: –You can query the type’s properties: Flags: IsPublic, IsAbstract, IsClass. Names: Name, Assembly, FullName, Module BaseType Interfaces that are implemented by this type –You can reflect over the type’s members : GetConstructors(), GetEvents(), GetFields(), GetMembers(), GetMethods(), GetProperties() –You can invoke its methods or set values to its properties InvokeMember()

Example demonstrates that Object.GetType returns the runtime type of the current instance // GetTypeExample.jsl import System.*; public class MyBaseClass extends Object { } //MyBaseClass public class MyDerivedClass extends MyBaseClass { } //MyDerivedClass public class Test { public static void main(String[] args) { MyBaseClass myBase = new MyBaseClass(); MyDerivedClass myDerived = new MyDerivedClass(); Object o = myDerived; MyBaseClass b = myDerived; Console.WriteLine("mybase: Type is {0}", myBase.GetType()); Console.WriteLine("myDerived: Type is {0}", myDerived.GetType()); Console.WriteLine("object o = myDerived: Type is {0}", o.GetType()); Console.WriteLine("MyBaseClass b = myDerived: Type is {0}", b.GetType()); } //main } //Test This code produces the following output: mybase: Type is MyBaseClass myDerived: Type is MyDerivedClass object o = myDerived: Type is MyDerivedClass MyBaseClass b = myDerived: Type is MyDerivedClass [MSDN Library] J#

Reflecting over a type’s members Members of a type: Fields, constructors, methods, properties, events, and nested types. The FCL contains a type called System.Reflection.MemberInfo. Can be obtained from Type: method GetMembers() returns an array of MemberInfo Table shows some properties and methods offered by the MemberInfo type. These properties and methods are common to all type members. Member NameMember TypeDescription NameString propertyName of the member MemberTypeMemberTypes (enum) property Returns the kind of member (Fields, constructors, methods, properties, events, and nested types) DeclaringTypeType propertyReturns the Type that defined the member (different from ReflectedType in case of inherited members) ReflectedTypeType propertyReturns the type that was used to obtain the member

Hierarchy of the reflection types derived from MemberInfo MemberInfo is abstract GetMembers() method in Type returns an array of elements that are of the concrete subtypes Type offers also specific methods: GetFields(), GetConstructors(), GetMethods(), GetProperties(), GetEvents()

Example demonstrates how to retrieve informations about a type’s members // TypeGetMembersExample.jsl class MyClass { public int myInt = 0; public String myString = null; public MyClass() { } //MyClass public void Myfunction() { } //Myfunction private void MySecret() { } //MySecret } //MyClass class Type_GetMembers { public static void main(String[] args) { MyClass myObject = new MyClass(); MemberInfo myMemberInfo[]; // Get the type of 'MyClass'. Type myType = myObject.GetType(); // Get the info related to all public member's of 'MyClass'. myMemberInfo = myType.GetMembers(); Console.WriteLine( "\nThe members of class '{0}' are :\n", myType); for (int i = 0; i < myMemberInfo.length; i++) { // Display name and type of the concerned member. Console.WriteLine("'{0}' is a {1}", myMemberInfo[i].get_Name(), myMemberInfo[i].get_MemberType()); } } //main } //Type_GetMembers [MSDN Library] J#

Selecting kinds of reflected members GetMembers methods can take a BindingFlags parameter: –IgnoreCase: Search using case-insensitivity. –DeclaredOnly: Only search members on the declared type. (Ignore inherited members.) –Instance: Search instance members. –Static: Search static members. –Public: Search public members. –NonPublic: Search nonpublic members. –FlattenHierarchy: Search static members defined by base types. Code Acess Security and Reflection –Reflection makes it possible to bind to a nonpublic member and invoke the member, allowing application code a way to access private members that a compiler would normally prohibit the code from accessing. –However, reflection uses Code Access Security to ensure that its power isn’t abused or exploited. –Code with the appropriate System.Security.Permissions.ReflectionPermission can have access to the public, protected, and even private members of any loaded Type. –Security ReflectionPermissions in.NET can be set/enforced at assembly and/or type level

Example demonstrates how to retrieve private information class Type_GetMembers { public static void main(String[] args) { try { MyClass myObject = new MyClass(); MemberInfo myMemberInfo[]; // Get the type of 'MyClass'. Type myType = myObject.GetType(); // Get the info related to all public+private member's of 'MyClass'. BindingFlags bf = BindingFlags.DeclaredOnly | BindingFlags.NonPublic | BindingFlags.Public | BindingFlags.Instance | BindingFlags.Static; myMemberInfo = myType.GetMembers(bf); Console.WriteLine("\nThe members of class '{0}' are :\n", myType); for (int i = 0; i < myMemberInfo.length; i++) { // Display name and type of the concerned member. Console.WriteLine("'{0}' is a {1}", myMemberInfo[i].get_Name(), myMemberInfo[i].get_MemberType()); } catch (SecurityException e) { Console.WriteLine("Exception : " + e.get_Message()); } } //main } //Type_GetMembers [MSDN Library] J#

Creating an Instance of a Type Once you have a reference to a Type object, there are several mechanisms to create an instance of this type: –System.Activator: defines several overloaded CreateInstance method that get as parameters a Type object or a string that identifies the type. Creates an instance of the specified type using the constructor that best matches the specified parameter. Returns a reference to the new created Object –System.Reflection.ConstructorInfo: defines several overloaded Invoke method that invokes the constructor reflected by this instance. Returns an instance of the class associated with the constructor. –Special cases: System.Array: static CreateInstance method in Array

Calling a Type’s Members InvokeMember method in Type Several overloaded versions; the maximum of parameters are: public Object InvokeMember( String name, // Name of member BindingFlags invokeAttr, // How to look up members Binder binder, // How to match members and arguments Object target, // Object to invoke member on or null if it is a static member Object[] args, // Arguments to pass to method CultureInfo culture); // Culture used by some binders Internally, InvokeMember performs two operations: –Binding: select the appropriate member to be called –Invoking: actually invokes the member invokeAttr: A bitmask comprised of one or more BindingFlags that specify how the search is conducted. The access can be one of the BindingFlags such as Public, NonPublic, Private, CreateInstance, InvokeMethod, GetField, SetField, DeclaredOnly, ExactBinding, etc. The type of lookup need not be specified. If the type of lookup is omitted, BindingFlags.Public| BindingFlags.Instance will apply. Binder: A Binder object that defines a set of properties and enables binding, which can involve selection of an overloaded method, coercion of argument types, and invocation of a member through reflection. If it is not specified or null, the DefaultBinder is used.

Bind once, invoke multiple times Every time you call InvokeMember, it must bind to a particular member and then invoke it. Consequence: Having the binder select the right member each time you want to invoke a member is time-consuming. So if you plan on accessing a member frequently, you’re better off binding to the desired member once and then accessing that member as often as you want. You bind to a member (without invoking it) by calling one of the following Type’s methods: GetFields, GetConstructors, GetMethods, GetProperties, GetEvents methods, or any similar method. All these methods return references to objects whose type offers methods to access the specific member directly: –FieldInfo: GetValue, SetValue –ConstructorInfo: Invoke –MethodInfo: Invoke –PropertyInfo: GetValue, SetValue –EventInfo: AddEventHandler, RemoveEventHandler

Example demonstrates how to create an instance of a type and call it’s methods // InvokeMethod.jsl import System.*; import System.Reflection.*; class MyClass { public int myInt = 0; public String myString = null; public MyClass() { } //MyClass public void MyFunction() { Console.WriteLine("My function"); } //Myfunction private void MySecret() { Console.WriteLine("My secret"); } } //MyClass class TestInvokeMethod { public static void main(String[] args) { // get somehow the Type metaobject Type myType = Type.GetType ("MyClass"); //create instance obj Object obj = Activator.CreateInstance(myType); // bind to method MyFunction MethodInfo mi = myType.GetMethod("MyFunction"); // invokes MyFunction on obj if (mi!=null) mi.Invoke(obj, null); mi = myType.GetMethod("MySecret"); if (mi!=null) mi.Invoke(obj, null);} } //main } J#