Thursday, August 27, 2020
Wilfed Owen :: biographies bio biography
My paper is about Wilfred Owen and his surprising capacity of conveying the repulsions of war. Wilfred Owen was conceived in Oswestry on eighteenth March 1883. In spite of the fact that he had recently thought of himself as a radical he enrolled in the craftsmen Rifles and was dispatched a second lieutenant joining the Manchester regiment in France 1917. While serving his obligation in France he started to expound wonderfully on his encounters and view of war and its results. The innovative part of his work is induced from the serious individual encounters he was liable to during the war and are amazingly depicted with brightness through his sonnets. He can connect and get the peruser and take them back to his reality, let them feel the environment of how it was in no-keeps an eye ashore when the men where gradually dieing in ?introduction?. Or on the other hand have their pulse increment as they understand the frenzy of a gas assault in ?Dulce Et Decorum Est?. This is one of the strategies that show his brightness as an artist, only one of the numerous ways he imparts the revulsions of the First World War. Upon his appearance in France one of Owens first undertakings was to hold a burrow in no-keeps an eye ashore ? a difficulty that is later depicted in sonnets ?The Sentry? what's more, ?introduction?. These encounters I think add authenticity and feeling to his sonnets however further most an imaginative permit and commitment to communicate his annoyance and sicken at artists and creators praising war. He appears easily the truth of war, giving us a view of its boorish nature not accessible in a course reading, a legit knowledge into pointlessness at its best. One of the primary motivations behind my article is to concentrate on four distinct sonnets of the writer Wilfred Owen. One of his most well known sonnets ?Dulce Et Decorum Est? is an individual understanding into the purposelessness of war Owen persevered. It is an unexpected memory unto a snapshot of tumult, to which a life is lost because of a gas assault. The sonnet tells how Owen and his men were strolling back to a channel when a gas assault is brought upon them. ?Introduction? clarifies how the men are arranged in a channel and simply trusting that the climate will execute them. In this sonnet we are watching the way toward dieing. The following sonnet I am breaking down is
Saturday, August 22, 2020
Code of Ethics Essay
The main role of a code of morals is to protect the government assistance of customers by giving what is to their greatest advantage. It is likewise intended to defend the general population and to manage experts in their work so they can offer the most ideal support. Every single proficient guide are committed to perform by a code of morals. The American Counseling Association (ACA) gives direction in settling moral issues that experts may experience, while Christian instructors not just comply with the ACA Code of Ethics yet additionally by the American Association of Christian Counselors AACC code, which advances greatness and carries solidarity to Christian advisors, and offers respect to Jesus Christ. This paper will address the expansive similitudes and contrasts between the two codes, just as examinations in the particular territories of Confidentiality, Sexual Intimacies and Discrimination. Codes of Ethics Comparison A code of morals is an efficient proclamation of moral measures that speak to the ethical feelings and guide the training conduct of a gathering (Clinton and Ohlschlager, 2002). â⬠With that at the top of the priority list, each advising discipline has a morals code which is constantly modified and refreshed to remain current with developing issue, and to advance raised lucidity and bearing to the calling. In this way, the ACA and AACC codes of morals were both made to help their individuals to all the more likely serve their customers. They additionally characterize values and social norms fundamental for moral directing. However while they are comparable in plan, they are unmistakable in their primary reason. General Similarities and Differences Both codes pressure the significance of ââ¬Å"promoting the government assistance of shoppers, rehearsing inside the extent of oneââ¬â¢s fitness, doing no damage to the customer, ensuring clientââ¬â¢s secrecy and protection, acting morally and dependably, staying away from abuse, and maintaining the uprightness of the calling by taking a stab at optimistic practice â⬠(Corey, p. 6). Be that as it may, the greatest contrast between the two codes rests in the floods of impact, while the AACC code is established in a scriptural perspective. As such, the essential objective of the AACC is ââ¬Å"to carry respect to Jesus Christ and his congregation, advance greatness in Christian guiding and carry solidarity to Christian counselorsâ⬠(AACC, 2004). Notwithstanding, the ACAââ¬â¢s objectives are instructive, logical, and proficient. It endeavors to upgrade the personal satisfaction in the public arena by advancing the advancement of expert advisors, propelling the guiding calling, and utilizing the calling and practice of directing to advance regard for human nobility and decent variety (ACA, 2005). The essential objective of the AACC is ââ¬Å"to carry respect to Jesus Christ and is church, advance greatness in Christian guiding and carry solidarity to Christian counselorsâ⬠(AACC, 2004) Specific Comparisons Both codes express a high need on customer secrecy. Additionally, they express the benefit of talking about and making sure about composed assent from the customer. They additionally both talk about the significance of customer exposure in that ensuring classified correspondence is consistently the primary reaction of the guide. The advocate is ordered to reveal data in life compromise or injurious circumstances. Be that as it may, the particular distinction between the AACC and the ACA is in the territory of special correspondence. While the two affiliations necessitate that guides don't uncover customer data as it identifies with preparing, research or distribution, the AACC includes that ââ¬Å"Christian advisors don't unveil private customer correspondences in any administrative, conference, instructing, lecturing, distributing, or other movement without composed or other lawful approval by the clientâ⬠(AACC, 2004). The ACA and the AACC codes vary enormously in the idea of sexual Intimacies. Actually, The ACA (2005) utilized the term ââ¬Å"sexual or sentimental cooperations or relationshipâ⬠. As it were The ACA (2005) doesn't prohibit, yet sets rules relating to any investment of sexual or sentimental communication with any present or formal customers for a time of 5 years following the last proficient contact. In any case, the AACC pronounced that all types of sexual communications or connections outside of marriage are exploitative. The main special case to this standard is marriage, which the AACC (2004) pronounced as ââ¬Å"honorable before Godâ⬠. Consequently, rules have been appropriated to take into account such a case. What's more, Christian guides are additionally taboo to direct present or previous sexual accomplices or potentially conjugal accomplices. (AACC, 2004 )Discrimination can bring about significant issues for both the individuals that hold them and the individuals that they are partial against. The two affiliations concur that non-segregation is the best practice, for customers ought not be refused assistance dependent on age, religion, sexual direction and so on. Nonetheless, the AACC keeps up its scriptural point of view in that advocates are to energize scriptural standards. While Christian guides must not segregate, they likewise can't excuse certain practices that contention with scriptural standards. For example, in the territory of sexual direction, Christian advisors won't refuse assistance. Anyway they will ââ¬Å"encourage sexual abstinence or scripturally recommended sexual conduct while such issues are being addressedâ⬠(AACC, 2004). End There are numerous similitudes and contrasts identifying with the code of morals for the American Association of Christian Counselors (AACC) and the American Counseling Association (ACA). Through these regions we understand that the code of morals defines limits and guidelines for every single proficient advocate and without them, instructors couldn't be viable or gainful in their actual calling.
Friday, August 21, 2020
HOW TO Report Fake Facebook Profile Account
HOW TO Report Fake Facebook Profile Account Make Money Online Queries? Struggling To Get Traffic To Your Blog? Sign Up On (HBB) Forum Now!HOW TO: Report Fake Facebook Profile AccountUpdated On 01/12/2017Author : Pradeep KumarTopic : FacebookShort URL : https://hbb.me/2BmzzM7 CONNECT WITH HBB ON SOCIAL MEDIA Follow @HellBoundBlogFacebook is the most popular social network site in the world, but unfortunately, it is also one of the popular target amongst phishers and other social engineers. Tonnes of Facebook Profiles out there and the game is to identify which one is genuine.Believe me, if you find a fake profile with your real name, then it may be a sign of serious identity theft. They would have imitated your profile and prepared it for some illegal online activities, or they may even use against you. They will also use to bully you or in other words, Cyber Bullying.THIS IS ONE OF THE MAIN REASONS WHY FAKE PROFILES ARE CREATED:Did You Ditch Your Boyfriend Recently? He Might Pay You Back Like This.Facebook fake profile holde rs have the same intention as Phishers, they will use your name to obtain more info. It is not difficult to identify Facebook fake profile, you just have to do a basic checkup. You can report a fake Facebook profile in two cases.1. You are in Facebook, and someone is impersonating you.2. You are not in Facebook, and someone is impersonating you.You can also do the same for your friend if they are facing the same issue. Try to provide exact details while reporting.1. You are on Facebook, and someone is impersonating youThe easiest way to do this to report that profile. Just go to that fake profile. Click that Settings icon and select Report/Block.READBefitting The # Tag Community : Can Facebook Count On It?And youll get another popup, there you have to select the Report type. Select This profile/timeline is pretending to be someone or fake. If you get a drop-down list, then select some option like Pretending to me. Click Continue to submit your report.Thats all you have to do. I beli eve Facebook undoubtedly checks this issue and update you if they need to convey anything.2. You are not on Facebook, and someone is impersonating youMaybe you are not the Social Media type person, or you might have quit Facebook for some reason. But still someone is impersonating you as if you are on Facebook? Then here is how you can deal with it. Just go to this form and fill the required details.You have attached the picture of Government-issued ID of the person being impersonated, in this case, that is you. Thats all. Now Facebook will see this issue dearly.IF YOU CARE ABOUT YOUR FACEBOOK PRIVACY, HERE IS A SIMPLE WAY:Simple Steps To Prevent Your Facebook Profile To Appear On Google SearchYou can see these methods to report Fake profile of your friend or anyone you know. After the rise of cyber-bullying, Im sure Facebook will take these issues very seriously.
Monday, May 25, 2020
Architecture of .Net Framework - Free Essay Example
Sample details Pages: 33 Words: 10043 Downloads: 7 Date added: 2017/09/14 Category Advertising Essay Did you like this example? Architecture of the . NET Framework Chapter 1 Architecture of the . NET Framework The . Donââ¬â¢t waste time! Our writers will create an original "Architecture of .Net Framework" essay for you Create order NET Framework development platform introduces many new concepts, technologies, and terms. The goal of this chapter is to give an overview of the . NET Framework: to show how it is architected, to introduce some of the new technologies, and to define many of the new terms. Iââ¬â¢ll also take you through the process of building your source code into an application or a set of redistributable components (types), and then explain how these components execute. Compiling Source Code into Managed Modules OK, so youââ¬â¢ve decided to use the . NET Framework as your development platform. Great! Your first step is to determine what type of application or component you intend to build. Letââ¬â¢s just assume that youââ¬â¢ve handled this minor detail, everything is designed, the specifications are written, and youââ¬â¢re ready to start development. Next, you must decide what programming language to use. This is usually a difficult task because different languages offer different capabilities. For example, in unmanaged C/C++, you have pretty low-level control of the system. You can manage memory exactly the way you want to, create threads easily if you need to, and so on. Visual Basic 6, on the other hand, allows you to build UI applications very rapidly and allows the easy control of COM objects and databases. If you use the . NET Framework, your code targets the common language runtime (CLR), which affects your decision about a programming language. The common language runtime is just what its name says it is: A runtime that is usable by different and varied programming languages. The features of the CLR are available to any and all programming languages that target it-period. If the runtime uses exceptions to report errors, then all languages get errors reported via exceptions. If the runtime allows you to create a thread, then any language can create a thread. In fact, at runtime, the CLR has no idea which programming language the developer used for the source code. This means that you should choose whatever programming language allows you to express your intentions most easily. You may develop your code in any programming language you desire as long as the compiler you use to compile your code targets the CLR. So if what I say is true, then what is the advantage of using one programming language over another? Well, I think of compilers as syntax checkers and correct code analyzers. They examine your source code, ensure that whatever youââ¬â¢ve written makes some sense, and then output code that describes your intention. Simply put, different programming languages allow you to develop using different syntax. Donââ¬â¢t underestimate the value of this. For mathematical or financial applications, expressing your intentions using APL syntax can save many days of development time when compared to expressing the same intention using Perl syntax, for example. Microsoft is creating several language compilers that target the runtime: C++ with managed extensions, C# (pronounced ââ¬Å"C sharpâ⬠), Visual Basic. NET, JScript, Java, and an intermediate language (IL) Assembler. In addition to Microsoft, there are several other companies creating compilers that produce code that targets the CLR. At this writing, I am aware of compilers for Alice, APL, COBOL, Component Pascal, Eiffel, Fortran, Haskell, Mercury, ML, Mondrian, Oberon, Perl, Python, RPG, Scheme, and Smalltalk. The figure on the next page shows the process of compiling source code files: 1 Applied . NET Framework Programming As the figure shows, you can create source code files using any programming language that supports the CLR. Then, you use the corresponding compiler to check syntax and analyze the source code. Regardless of which compiler you use, the result is a managed module. A managed module is a standard Windows portable executable (PE) file that requires the CLR to execute. In the future, other operating systems may use the PE file format as well. A Managed Module is composed of the following parts: Part PE header Description This is the standard Windows PE file header, which is similar to the Common Object File Format (COFF) header. The PE header indicates the type of fileGUI, CUI, or DLLââ¬âand also has a timestamp indicating when the ile was built. For modules that contain only IL code (see below, Intermediate Language Code), the bulk of the information in the PE header is ignored. For modules that contain native CPU code, this header contains information about the native CPU code. This header contains the information (interpreted by the CLR and utilities) that makes this a managed module. It includes the version of the CLR required, some flags, the MethodDef metadata token of the managed moduleââ¬â¢s entry point method (Main method), and the location/size of the moduleââ¬â¢s metadata, resources, strong name, some flags, and other less interesting stuff. Every managed module contains metadata tables, of which there are 2 main types: those that describe the types and members defined in your source code, and those that describe the types and members referenced by your source code. CLR header Metadata 2 Architecture of the . NET Framework Part Intermediate Language (IL) Code Description This is the code that was produced by the compiler as it compiled the source code. IL is later compiled by the CLR into native CPU instructions. Most compilers of the past produced code targeted to a specific CPU architecture, such as x86, IA64, Alpha, or PowerPC. All CLR-compliant compilers produce intermediate language (IL) code instead. IL code is sometimes referred to as managed code, because its lifetime and execution are managed by the CLR. IL code is discussed later in this chapter. In addition to emitting IL, every compiler targeting the CLR is required to emit full metadata into every managed module. In brief, metadata is simply a set of data tables that describe what is defined in the module, such as types and their members. In addition, metadata also has tables indicating what the managed module references, such as imported types and their members. Metadata is a superset of older technologies such as type libraries and IDL files. The important thing to note is that CLR metadata is far more complete than its predecessors. And, unlike type libraries and IDL, metadata is always associated with the file that contains the IL code. In fact, the metadata is always embedded in the same EXE/DLL as the code, making it impossible to separate the two. Since the metadata and code are produced by the compiler at the same time and are bound into the resulting managed module, the metadata and the IL code it describes are never out of sync with one another. Metadata has many uses. Here are some of them: â⬠¢ Metadata removes the need for header and library files when compiling, because all the information about the referenced types/members is contained in one file along with the IL that implements those type/members. Compilers can read metadata directly from managed modules. Visual Studio uses metadata to help you write code. Its IntelliSense feature parses metadata to tell you what methods a type offers and what parameters that method expects. The CLR code verification process uses metadata to ensure that your code performs only ââ¬Å"safeâ⬠operations. Verification is discussed shortly. Metadata allows an objectââ¬â¢s fields to be serialized into a memory block, remoted to another machine, and then deserialized, recreating the object and its state on the remote machine. Metadata allows the garbage collector to track the lifetime of objects. For any object, the garbage collector can determine the type of the object, and from the metadata it knows which fields within that object refer to other objects. â⬠¢ â⬠¢ â⬠¢ â⬠¢ The next chapter, ââ¬Å"Building, Packaging, Deploying, and Administering Applications and Types,â⬠will describe metadata in much more detail. And a little later in this chapter, weââ¬â¢ll explore intermediate language in more detail. Four of the compilers that Microsoft offersC#, Visual Basic, JScript, and the IL Assembleralways produce managed modules, which require the CLR to execute. That is, end users must have the CLR installed on their machines in order to execute any managed modules. This situation is similar to the one that end users face with MFC or VB 6 applications: they must have the MFC or VB DLLs installed in order to run them. The Microsoft C++ compiler, by default, builds unmanaged modules: the EXE or DLL files with which we are all familiar. These modules do not require the CLR in order to execute. However, by specifying a new command-line switch, the C++ compiler can produce managed modules that do require the CLR to execute. Of all the Microsoft compilers mentioned, C++ is unique in that it is the only language that allows the developer to write both managed and 3 Applied . NET Framework Programming unmanaged code and have it emitted into a single managed module. This can be a great feature because it allows developers to write the bulk of their applications in managed code (for type-safety and component interoperability) but continue to access their existing unmanaged C++ code. Combining Managed Modules into Assemblies The CLR doesnââ¬â¢t actually work with modules; it works with assemblies. An assembly is an abstract concept, which can be difficult to grasp at first. First, an assembly is a logical grouping of one or more managed modules or resource files. Second, an assembly is the smallest unit of reuse, security, and versioning. Depending on the choices you make with your compilers or tools, you can produce a single-file assembly or you can produce a multi-file assembly. Chapter 2, ââ¬Å"Building, Packaging, Deploying, and Administering Applications and Types,â⬠discusses assemblies in great detail, so I donââ¬â¢t want to spend a lot of time on it here. All I want to do now is make you aware that there is this extra conceptual notion that offers a way to treat a group of files as a single entity. The figure below should help explain what assemblies are about: In this figure, we are passing the file names of some managed modules and resource (or data) files to a tool. This tool produces a single PE file that represents the logical grouping of files. This PE file contains a block of data called the manifest, which is simply another set of metadata tables. These tables describe the assembly: the files that make it up, the publicly exported types implemented by the files in the assembly, and the resource or data files that are associated with it. By default, compilers actually do the work of turning the emitted managed module into an assembly. That is, the C# compiler emits a managed module that contains a manifest. The manifest indicates that the assembly consists of just the 4 Architecture of the . NET Framework one file. So for projects that have just one managed module and no resource files, the assembly will be the managed module, and you donââ¬â¢t have any additional steps to perform during your build process. If you wish to group a set of files into an assembly, then you will have to be aware of more tools (such as the assembly linker, AL. exe) and their command-line options. These tools and options are explained in the next chapter. An assembly allows you to decouple the logical and physical notions of a reusable, deployable, versionable component. The way in which you partition your code and resources into different files is completely up to you. For example, you could put rarely used types or resources in separate files that are part of an assembly. The separate files could be downloaded from the web as needed. If the files are never needed, theyre never downloaded, saving disk space and reducing installation time. An assembly lets you break up the physical deployment of the files but still treat them as a single collection. The modules in an assembly also include information, including version numbers, about referenced assemblies. This information makes an assembly self-describing. In other words, the CLR knows everything that an assembly needs in order to execute. No additional information is required in the registry or in the Active Directory, so deploying assemblies is much easier than deploying unmanaged components. Loading the Common Language Runtime Each assembly that you build can either be an executable application or a DLL containing a set of types (components) for use by an executable application. Of course, the CLR is responsible for managing the execution of code contained within these assemblies. This means that the . NET Framework must be installed on the host machine. Microsoft has created a redistribution package that you can freely ship to install the . NET Framework on your customers machines. Future versions of Windows will include the . NET Framework, at which point you will no longer need to ship it with your assemblies. You can tell whether the . NET Framework has been installed by looking for the MSCorEE. dll file in the %windir%system32 directory. The existence of this file tells you that the . NET Framework is installed. However, several versions of the . NET Framework may be installed on a single machine simultaneously. If you want to determine exactly which versions of the . NET Framework are installed, examine the subkeys under the following registry key: HKEY_LOCAL_MACHINESOFTWAREMicrosoft. NETFrameworkpolicy. When you build an EXE assembly, the compiler/linker emits some special information into the resulting assemblys PE File header and the files . text section. When the EXE file is invoked, this special information causes the CLR to load and initialize. Then the CLR locates the entry point method for the application and lets the application start executing. Similarly, if an unmanaged application calls LoadLibrary to load a managed assembly, the entry point function for the DLL knows to load the CLR in order to process the code contained within the assembly. For the most part, you do not need to know about or understand how the CLR actually gets loaded. For the curious, however, I will explain how a managed EXE or DLL starts the CLR. If youââ¬â¢re not interested in this, feel free to skip to the next section. The figure on the next page summarizes how a managed EXE loads and initializes the CLR. 5 Applied . NET Framework Programming When the compiler/linker creates an executable assembly, the following 6-byte x86 stub function is emitted into the . text section of the PE file: JMP _CorExeMain The _CorExeMain function is imported from the Microsoft MSCorEE. dll dynamic-link library, and therefore MSCorEE. dll is referenced in the import (. idata) section of the assembly file. (MSCorEE. ll stands for Microsoft Component Object Runtime Execution Engine. ) When the managed EXE file is invoked, Windows treats it just like any normal (unmanaged) EXE file: the Windows loader loads the file and examines the . idata section to see that MSCorEE. dll should be loaded into the processââ¬â¢s address space. Then, the loader obtains the address of the _CorExeMain function inside MSCorEE. dll and fixes up the stub function ââ¬â¢s JMP instruction in the managed EXE file. The primary thread for the process begins executing this x86 stub function, which immediately jumps to _CorExeMain in MSCorEE. ll. _CorExeMain initializes the CLR and then looks at the CLR header for the executable assembly to determine what managed entry point method should execute. The IL code for the method is then compiled into native CPU instructions, after which the CLR jumps to the native code (using the processââ¬â¢s primary thread). At this point, the managed application code is running. The situation is similar for a managed DLL. When building a managed DLL, the compiler/linker emits a similar 6-byte x86 stub function for a DLL assembly in the . text section of the PE file: JMP _CorDllMain Architecture of the . NET Framework The _CorDllMain function is also imported from the MSCorEE. dll, causing the . idata section for the DLL to reference MSCorEE. dll. When Windows loads the DLL, it automatically loads MSCorEE. dll (i f it isnââ¬â¢t already loaded), obtains the address of the _CorDllMain function, and fixes up the 6 byte x86 JMP stub in the managed DLL. The thread that called LoadLibrary to load the managed DLL then jumps to the x86 stub in the managed DLL assembly, which immediately jumps to the _CorDllMain in MSCorEE. dll. CorDllMain initializes the CLR (if it hasnââ¬â¢t already been initialized for the process) and then returns so that the application can continue executing as normal. These 6-byte x86 stub functions are required to run managed assemblies on Windows 98, Windows 98SE, Windows ME, Windows NT 4, and Windows 2000 because all these operating systems shipped long before the CLR became available. Note that the 6-byte stub function is specifically for x86 machines. This stub does not work properly if the CLR is ported to run on other CPU architectures. Because Windows XP and the Windows . NET Servers support both the x86 and the IA64 CPU architectures, the loader for Windows XP and the Windows . NET Servers was modified to look specifically for managed assemblies. On Windows XP and the Windows . NET Servers, when a managed assembly is invoked (typically via CreateProcess or LoadLibrary), the OS loader detects that the file contains managed code. It does this by examining directory entry 14 in the PE file header (see IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR in WinNT. h). If this directory entry exists and is not 0, then the loader ignores the fileââ¬â¢s import (. data) section entirely and knows to automatically load MSCorEE. dll into the address space for the process. Once loaded, the OS loader makes the process thread jump directly to the correct function in MSCorEE. dll. The 6-byte x86 stub functions are ignored on machines running Windows XP and the Windows . NET Servers. One last note about managed PE files: Managed PE files always use the 32-bit PE file format; th ey do not use the newer 64-bit PE file format. On 64-bit Windows systems, the OS loader detects the managed 32-bit PE file and automatically knows to create a 64-bit address space. Executing the Code in Your Assembly As mentioned earlier, managed modules contain both metadata and intermediate language (IL) code. IL is a CPUindependent machine language created by Microsoft after consultation with several external commercial and academic language/compiler writers. IL is much higher-level than most CPU machine languages. IL understands object types and has instructions that create and initialize objects, call virtual methods on objects, and manipulate array elements directly. It even has instructions that throw and catch exceptions for error handling. You can think of IL as an objectoriented machine language. Usually, developers prefer to program in a high-level language, such as C# or Visual Basic. NET. The compilers for all these high-level languages produce IL. However, like any other machine language, IL can be written in assembly language and Microsoft does provide an IL assembler, ILAsm. exe. Microsoft also provides an IL disassembler, ILDasm. exe. Some people are concerned that IL does not offer enough intellectual property protection for their algorithms. In other words, you could build a managed odule and someone else could use a tool, like an IL disassembler, to reverse engineer exactly what your application code does. Yes, itââ¬â¢s true that IL code is higher-level than most other assembly languages and, in general, reverse engineering IL code is relatively simple. However, when you implement a web service or web form 7 Applied . NET Framework Programming application, your managed module resides on your server, inacc essible to anyone outside your company. Outsiders cannot use any tool to see the IL code, so your intellectual property is completely safe. If you are concerned about any of your managed modules that you do distribute, then you can use the Microsoft obfuscator utility (OB. exe), which is downloadable from https://www. GotDotNet. com. This utility ââ¬Å"scramblesâ⬠the names of all the private symbols in your managed module metadata. It will be difficult for someone to ââ¬Å"unscrambleâ⬠the names and understand the purpose of each method. Note that the Microsoft obfuscator scrambles metadata names only and does not scramble the IL code in anyway since the CLR must be able to process unscrambled IL. If you donââ¬â¢t feel that the obfuscator offers the kind of intellectual property protection that you desire, then you can consider implementing your more-sensitive algorithms in some unmanaged module, which will contain native CPU instructions instead of IL and metadata. Then, you can use the CLRââ¬â¢s interoperability features to communicate between the managed and unmanaged portions of your application. Of course, this assumes that youââ¬â¢re not worried about people reverse engineering the native CPU instructions in your unmanaged code. Any high-level language will most likely expose only a subset of the facilities offered by the CLR. IL assembly language, however, gives a developer access to all the facilities of the CLR. So if your programming language of choice hides a CLR feature that you really wish to take advantage of, you can write that portion of your code in IL assembly or in another programming language that exposes the CLR feature you seek. The only way for you to know what facilities are offered by the runtime is to read documentation specific to the CLR itself. In this book, I try to concentrate on CLR features and how they are exposed or not exposed by the C# language. I suspect that most other books and articles will present the CLR via a particular language and that most developers will come to believe that the CLR offers only those features that the developers chosen language exposes. As long as your language allows you to accomplish what youre trying to do, this blurred perspective is not a bad thing. Personally, I feel that an ability to switch programming languages easily with rich integration between languages is an awesome feature of the CLR. I also believe that this is a feature that will, unfortunately, often be overlooked by developers. Programming languages like C# and Visual Basic. NET are excellent languages for doing I/O operations. APL is an awesome language for doing advanced engineering or financial calculations. Through the CLR, you can write the I/O portions of your application using C# and then write the engineering calculations using APL. The CLR offers a level of integration between these languages that is unprecedented, and really makes mixed-language programming worthy of consideration for many development projects. An important thing to note about IL is that it is not tied to any specific CPU platform. This means that a managed module containing IL can run on any CPU platform as long as the operating system running on that CPU platform hosts a version of the CLR. Although the initial release of the CLR will run only on 32-bit Windows platforms, developing an application using managed IL sets up a developer to be more independent of the underlying CPU architecture. In October 2000, Microsoft (along with Intel and Hewlett-Packard as co-sponsors) proposed a large subset of the . NET Frameworks to the ECMA (the European Computer Manufacturerââ¬â¢s Association) for the purpose of standardization. The ECMA accepted this proposal and created a technical committee (TC39) to oversee the standardization process. The technical committee is charged with the following duties: 8 Architecture of the . NET Framework â⬠¢ â⬠¢ â⬠¢ Technical Group 1: Develop a dynamic scripting language standard (ECMAScript). Microsoftââ¬â¢s implementation of ECMAScript is JScript. Technical Group 2: Develop a standardized version of the C# programming language. Technical Group 3: Develop a common language infrastructure (CLI) based on a subset of the functionality offered by the . NET Frameworkââ¬â¢s CLR and class library. Specifically, the CLI defines a file format, a common type system, an extensible metadata system, an intermediate language (IL), and access to the underlying platform (P/Invoke). In addition, the CLI also defines a factorable (to allow for small hardware devices) base class library designed for use by multiple programming languages. Once the standardization is completed, these standards will be contributed to ISO/IEC JTC 1 (Information Technology). At this time, the technical committee will investigate further directions for CLI, C#, and ECMAScript, as well as entertain proposals for any complementary or additional technology. For more information about ECMA, please see https://www. ECMA. ch and https://MSDN. Microsoft. com/Net/ECMA. With the standardization of the CLI, C#, and ECMAScript, Microsoft wonââ¬â¢t ââ¬Å"ownâ⬠any of these technologies. Microsoft will simply be one company of many (hopefully) that are producing implementations of these technologies. Certainly Microsoft hopes that their implementation will be the best in terms of performance and customer-demand-driven features. This is what will help sales of Windows, since the Microsoft ââ¬Å"best of breedâ⬠implementation will only run on Windows. However, other companies are free to implement these standards and compete against Microsoft. Of course, IL instructions cannot be executed directly by todayââ¬â¢s CPUs (although this may change someday). In order to execute a method, its IL code must first be converted to native CPU instructions. To make this conversion, the CLR provides a JIT (just-in-time) compiler. The figure below shows what happens the first time a method is called. 9 Applied . NET Framework Programming Just before the Main method executes, the CLR detects all the types that are referenced by the code in Main. This causes the CLR to allocate an internal data structure that is used to manage access to each referenced type. In the figure above, the Main method refers to a single type, Console, causing the CLR to allocate a single internal structure. This internal data structure contains an entry for each method defined by the type. Each entry holds the address where the method implementation can be found. When initializing this structure, the CLR sets each entry to a function contained inside the CLR itself. I call this function JITCompiler. When Main makes its first call to WriteLine, the JITCompiler function is called. The JITCompiler function is responsible for compiling a methodââ¬â¢s IL code into native CPU instructions. Since the IL is being compiled ââ¬Å"just in timeâ⬠, this component of the CLR is frequently referred to as a JITter or JIT Compiler. When called, the JITCompiler function knows what method is being called and what type defines this method. The JITCompiler function then searches the defining assemblyââ¬â¢s metadata for the called methodââ¬â¢s IL. JITCompiler verifies and compiles the IL code into native CPU instructions, which are then saved in a dynamically allocated block of memory. JITCompiler goes back to the typeââ¬â¢s internal data structure and replaces the address of the called method with the address of the block of memory containing the native CPU instructions. Finally, JITCompiler jumps to the code in the memory block. This code is the implementation of the WriteLine method (the version that takes a String parameter). When this code returns, execution resumes in Main, as normal. Suppose now that Main calls WriteLine a second time. This time, because the code for WriteLine has already been verified and compiled, the call goes directly to the native code in the memory block, skipping the JITCompiler function entirely. After the WriteLine method executes it returns to Main. The figure below shows what the situation looks like when WriteLine is called the second time: 10 Architecture of the . NET Framework The important thing to note is that the process incurs a performance hit only the first time a method is called. All subsequent calls to the method execute at the full speed of the native code: Verification and compilation to native code is not performed again. Note that the JIT compiler stores the native CPU instructions in dynamic memory: The compiled code is discarded when the application terminates. So if you run the application in the future or if you run two instances of the application simultaneously (in two different operating system processes), then the JIT compiler will have to compile the IL to native instructions again. For most applications, the performance hit incurred by JIT compilation is not significant. Most applications tend to call the same methods over and over again, so these methods will take the performance hit only once while the application executes. Also, a process normally spends more time inside the method than it spends calling the method. Be aware that the JIT compiler optimizes the native code just like the back end of an unmanaged C++ compiler. Again, the optimization may take time, but the code will execute with much better performance than unoptimized code. Developers coming from an unmanaged C or C++ background are probably thinking about the performance ramifications of all this. After all, unmanaged code is compiled for a specific CPU platform, and when invoked, the code can simply execute. In this managed environment, compiling the code is accomplished in two phases. First, the compiler passes over our source code, doing as much work as possible in producing IL. But then, in order to actually execute the code, the IL itself must be compiled into native CPU instructions at run time, requiring that more memory be allocated, and requiring addition CPU time to do the work. Believe me, I approached the CLR from a C/C++ background myself, so I was quite skeptical and concerned about this additional overhead. The truth is that this second compilation stage that occurs at runtime does hurt performance and it does allocate dynamic memory. However, Microsoft has done a lot of performance work to keep this additional overhead to a minimum. 11 Applied . NET Framework Programming If you too are skeptical, then you should certainly build some applications to test the performance for yourself. In addition, you should run some non-trivial managed applications produced by Microsoft or others and measure their performance. I think youll be surprised at how good the performance actually is. In fact, hard as this might be to believe, many people (including me) think that managed applications could actually out-perform unmanaged applications. For example, when the JIT compiler compiles the IL code into native code at runtime, the compiler knows more about the execution environment than an unmanaged compiler would know. Here are some ways that managed code could out-perform unmanaged code: â⬠¢ A JIT compiler could detect that the application is running on a Pentium 4 and produce native code that takes advantage of any special instructions offered by the Pentium 4. Usually, unmanaged applications are compiled for the lowest common denominator CPU and avoid using special instructions that would give the application a performance boost on newer CPUs. A JIT compiler could detect that a certain test is always false on the current host machine. For example, a method with code like this: if (numberOfCPUs ; 1) { } â⬠¢ could cause the JIT compiler to not generate any CPU instructions for the above code if the host machine has only 1 CPU. In this case, the native code has been fine-tuned for the host machine: the code is smaller and executes faster. â⬠¢ The CLR could profile the code execution and recompile the IL into native code while the application runs. The recompiled code could be reorganized to reduce incorrect branch predictions depending on the observed execution patterns. For these and many other reasons, you should expect future accomplishments with managed code to execute better than todays unmanaged code. As I said, the performance today is quite good for most applications, and it promises to improve as time goes on. If your experiments show that the CLRs JIT compiler does not offer your application the kind of performance it requires, then you might want to take advantage of the NGen. exe tool that ships with the . NET Framework SDK. This tool compiles all the IL code for an assembly into native code and saves the resulting native code to a file on disk. At runtime, when an assembly is loaded, the CLR automatically checks to see whether a precompiled version of the assembly also exists, and if it does, the CLR loads the precompiled code so that no compilation at runtime is required. IL and Verification IL is stack-based, which means that all its instructions push operands onto an execution stack and pop results off the stack. Accordingly, IL offers no instructions to manipulate registers. Compiler developers can easily produce IL code: They dont have to think about managing registers, and there are fewer IL instructions (since none exist for manipulating registers). And hereââ¬â¢s another simplification: IL instructions are typeless. For example, IL offers an add instruction that adds the last two operands pushed on the stack. IL does not offer a 32-bit add instruction and a 64-bit add instruction. When the add instruction executes, it determines the types of the operands on the stack and performs the appropriate operation. 12 Architecture of the . NET Framework In my opinion, the biggest benefit of IL is not that it abstracts away the underlying CPU. The biggest benefit is application robustness. While compiling IL into native CPU instructions, the CLR performs a process called verification. Verification examines the high-level IL code and ensures that everything it does is ââ¬Å"safe. â⬠For example, verification checks that no memory is read from without having previously been written to, that every method is called with the correct number of parameters, that each parameter is of the correct type, that every methodââ¬â¢s return value is used properly, that every method has a return statement, and so on. The metadata for each managed module includes all the method and type information used by the verification process. If the IL code is determined to be ââ¬Å"unsafe,â⬠then a System. Security. VerifierException exception is thrown, preventing the method from executing. By default, Microsoftââ¬â¢s C# and Visual Basic. NET compilers produce ââ¬Å"safeâ⬠code. Safe code is code that is verifiably safe. However, using C#ââ¬â¢s unsafe keyword or using other languages (such as C++ with Managed Extensions or IL Assembly language), you can produce code that cannot be verifiably safe. That is, the code might, in fact, be safe, but the verification is unable to prove it. To ensure that all methods in your managed module contain verifiably safe IL, you can use the PEVerify. exe utility that ships with the . NET Framework SDK. When Microsoft developers test their C# and Visual Basic. NET compilers, they run the resulting module through PEVerify to ensure that the compiler always produces verifiably safe code. If PEVerify detects unsafe code, then Microsoft fixes the compiler. You may want to consider running PEVerify on your own modules before you package and ship them. If PEVerify detects a problem, then there is a bug in the compiler and you should report this to Microsoft (or whatever company produces the compiler youre using). If PEVerify doesnt detect any unverifiable code, then you know that your code will run without throwing a users machine. Note that an administrator can elect to turn verification off (using the . NET Management Microsoft Management Console Snap-In). With verification off, the JIT compiler will compile unverifiable IL into native CPU instructions; however, the administrator is taking full responsibility for the codes behavior. VerifierException on the end- In Windows, each process has its own virtual address space. Separate address spaces are necessary because Windows canââ¬â¢t trust the application code. It is entirely possible (and unfortunately, all too common) that an application will read from or write to an invalid memory address. Placing each Windows process in a separate address space enhances robustness: One process cannot adversely affect another process. However, by verifying the managed code, we know that the code does not improperly access memory and cannot adversely affect another applicationââ¬â¢s code. This means that we can run multiple managed applications in a single Windows virtual address space. Because Windows processes require a lot of operating system resources, launching many processes can hurt performance and limit available OS resources. Running multiple applications in a single OS process reduces the number of processes, which can improve performance, require fewer resources, and offer equivalent robustness. This is another benefit of managed code as compared to unmanaged code. The CLR does, in fact, offer the ability to execute multiple managed applications in a single OS process. Each managed application is called an AppDomain. By default, every managed EXE will run in its own separate address space that has 13 Applied . NET Framework Programming just the one AppDomain. However, a process hosting the CLR (such as IIS or a future version of SQL Server) can decide to run AppDomains in a single OS process. The . NET Framework Class Library Included with the . NET Framework is a set of Framework Class Library (FCL) assemblies that contains several thousand type definitions, where each type exposes some functionality. All in all, the CLR and the FCL allow developers to build the following kinds of applications: â⬠¢ â⬠¢ â⬠¢ Web Services. Components that can be accessed over the Internet very easily. Web services are, of course, the main thrust of Microsofts . NET initiative. Web Forms. HTML-based applications (web sites). Typically, web form applications make database queries and web service calls, combine and filter the returned information, and then present that information in a browser using a rich HTML-based UI. Web forms provide a Visual Basic 6- and InterDevlike development environment for web applications written in any CLR language. Windows Forms. Rich Windows GUI applications. Instead of using a web form to create your applications UI, you can use the more powerful, higher-performance functionality offered by the Windows desktop. Windows form applications can take advantage of controls, menus, mouse and keyboard events, and can talk directly to the underlying operating system. Like web form applications, Windows form applications make database queries and call web services. Windows Forms provides a Visual Basic 6-like development environment for GUI applications written in any CLR language. Windows Console Applications. For applications with very simple UI demands, a console application provides a quick and easy solution. Compilers, utilities, and tools are typically implemented as console applications. Windows Services. Yes, it is possible to build service applications controllable via the Windows Service Control Manager (SCM) using the . NET Framework. Component Library. Of course, the . NET Framework allows you to build stand-alone components (types) that may be easily incorporated into any of the above mentioned application types. â⬠¢ â⬠¢ â⬠¢ Since the FCL contains literally thousands of types, a set of related types is presented to the developer within a single namespace. For example, the System namespace (which you should become most familiar with) contains the Object base type, from which all other types ultimately derive. In addition, the System namespace contains types for integers, characters, strings, exception handling, and console I/O, as well as a bunch of utility types that convert safely between data types, format data types, generate random numbers, and perform various math functions. All applications use types from the System namespace. To access any platform feature, you need to know which namespace contains the types that expose the facility youre after. If you want to customize the behavior of any type, you can simply derive your own type from the desired FCL type. The . NET Framework relies on the object-oriented nature of the platform to present a consistent programming paradigm to software developers. It also enables developers to create their own namespaces containing their own types, which merge seamlessly into the programming paradigm. Compared to Win32 programming paradigms, this greatly simplifies software development. Most of the namespaces in the FCL present types that you can use for any kind of application. The table below lists some of the more general namespaces, with a brief description of what the types in that namespace are used for: 14 Architecture of the . NET Framework Namespace System System. Collections Purpose of Types All the basic types used by every application. Managing collections of objects. Includes the popular collection types such as Stacks, Queues, Hashtables, and so on. System. Diagnostics Instrumenting and debugging your application. System. Drawing Manipulating 2D graphics. Typically used for Windows Forms applications and for creating images that are to appear in a web form. System. EnterpriseServices Managing transactions, queued components, object pooling, just-in-time activation, security, and other features to make the use of managed code more efficient on the server. System. Globalization National Language Support (NLS), such as string compares, formatting, and calendars. System. IO Doing stream I/O, walking directories and files. System. Management Managing other computers in the enterprise via WMI. System. Net Network communications. System. Reflection Inspecting metadata and late binding to types and their members. System. Resources Manipulating external data resources. System. Runtime. InteropServices Enabling managed code to access unmanaged OS platform facilities, such as COM components and functions in Win32 DLLs. System. Runtime. Remoting Accessing types remotely. System. Runtime. Serialization Enabling instances of objects to be persisted and regenerated from a stream. System. Security Protecting data and resources. System. Text Working with text in different encodings, like ASCII or Unicode. System. Threading Performing asynchronous operations and synchronizing access to resources. System. Xml Processing XML schemas and data. This book is about the CLR and about the general types that interact closely with the CLR (which would include most of the namespaces listed above). This means that the content of this book is applicable to all . NET Framework programmers regardless of the type of application theyre building. You should be aware, however, that in addition to supplying the more general namespaces, the FCL offers namespaces whose types are used for building specific application types. The table below lists some of the application-specific namespaces: Namespace System. Web. Services System. Web. UI System. Windows. Forms System. ServiceProcess Purpose of Types Building web services. Building web forms. Building Windows GUI applications. Building a Windows service controllable by the Service Control Manager. I expect many good books will be published that explain how to build specific application types (such as Windows services, web forms, or Windows forms). These books will give you an excellent start at building your application. I tend to think of these application-specific books as helping you learn from the top down because they concentrate on the application type and not on the development platform. It is my intent that this book offer information that will help you learn from the bottom up. The two types of books should complement each other: After reading this book and an 15 Applied . NET Framework Programming application-specific book, you should be able to easily and proficiently build any kind of . NET Framework application you desire. The Common Type System By now, it should be obvious to you that the CLR is all about types. Types expose functionality to your applications and components. Types are the mechanism by which code written in one programming language can talk to code written in a different programming language. Because types are at the root of the CLR, Microsoft created a formal specification ââ¬â the common type system (CTS)ââ¬âthat describes how types are defined and behave. The CTS specification states that a type may contain zero or more members. In Chapter 7, ââ¬Å"Type Member Accessibility,â⬠Ill discuss all these members in great detail. For now, I just want to give you a brief introduction to them: â⬠¢ â⬠¢ Field. A data variable that is part of the objectââ¬â¢s state. Fields are identified by their name and type. Method. A function that performs an operation on the object, often changing the objectââ¬â¢s state. Methods have a name, signature, and modifiers. The signature specifies the calling convention, number of parameters (and their sequence), the types of the parameters, and the type of value returned by the method. Property. To the caller, this member looks like a field. But to the type implementer, this member looks like a method (or two). Properties allow an implementer to validate input parameters and object state before accessing the value and to calculate a value only when necessary; they also allow a user of the type to have simplified syntax. Finally, properties also allow you to create read-only or write-only ââ¬Å"fields. â⬠Event. A notification mechanism between an object and other interested objects. For example, a button could offer an event that notifies other objects when the button is clicked. â⬠¢ â⬠¢ The CTS also specifies the rules for type visibility and for access to the members of a type. For example, marking a type as public exports the type, making it visible and accessible to any assembly. On the other hand, marking a type as assembly (called internal in C#) makes the type visible and accessible to code within the same assembly only. Thus, the CTS establishes the rules by which assemblies form a boundary of visibility for a type, and the runtime enforces the visibility rules. Regardless of whether a type is visible to a caller, the type gets to control whether the caller has access to its members. The following list shows the valid options for controlling access to a method or field: â⬠¢ â⬠¢ â⬠¢ â⬠¢ â⬠¢ Private. Callable only by other methods in the same class type. Family. Callable by derived types, regardless of whether they are within the same assembly. Note that many languages (like C++ and C#) refer to family as protected. Family and Assembly. Callable by derived types, but only if the derived type is defined in the same assembly. Assembly. Callable by any code in the same assembly. Note that many languages refer to assembly as internal. Family or Assembly. Callable by derived types in any assembly and by any types in the same assembly. Note that C# refers to family or assembly as protected internal. 6 Architecture of the . NET Framework â⬠¢ Public. Callable by any code in any assembly. In addition, the CTS defines the rules governing type inheritance, virtual functions, object lifetime, and so on. These rules have been designed to accommodate the semantics expressible in modern programming languages. In fact, you wonââ¬â¢t even need to learn the CTS rules, per se, becau se the language you use exposes its own language syntax and type rules in the same way you are familiar with today; it maps the language-specific syntax into the language of the CLR when it emits the managed module. When I first started working with the CLR, I soon realized that it is best to think of the language and the behavior of your code as two separate and distinct things. Using C++, you can define your own types with their own members. Of course, you could have used C# or Visual Basic. NET to define the same type with the same members. Sure, the syntax you use for defining this type is different depending on the language you choose, but the behavior of the type will be absolutely identical regardless of the language because the CLRââ¬âby means of the CTSââ¬âdefines the behavior of the type. To help make this clear, let me give you an example: The CTS supports single inheritance only. The C++ language supports types that inherit from multiple base types; nevertheless, the CTS cannot accept and operate on any such type. To help you, the Visual C++ compiler reports an error if it detects that youââ¬â¢re attempting to create managed code that includes a type inherited from multiple base types. Hereââ¬â¢s another CTS rule: All types must (ultimately) inherit from a predefined type, System. Object. As you can see, Object is the name of a type defined in the System namespace. This Object is the root of all other types and therefore guarantees every type instance has a minimum set of behaviors. Specifically, the System. Object type allows you to: â⬠¢ â⬠¢ â⬠¢ â⬠¢ â⬠¢ compare two instances for equality obtain a hash code for the instance query the true type of an instance perform a shallow (bitwise) copy of the instance obtain a string representation of the instances objectââ¬â¢s current state The Common Language Specification COM allows objects created in different languages to communicate with one another. The CLR goes further. It integrates all languages to let objects created in one language be treated as equal citizens by code written in a completely different language. To make this possible, the CLR defines a standard behavior for types, embeds self-describing type information (metadata), and provides a common execution environment. Language integration is a fantastic goal, of course, but the truth of the matter is that programming languages are very different from one another. For example, some languages lack features commonly used in other languages: â⬠¢ â⬠¢ â⬠¢ â⬠¢ ase-sensitivity unsigned integers operator overloading methods that support a variable number of parameters 17 Applied . NET Framework Programming If you intend to create types that are easily accessible from other programming languages, then it is important that you use only features of your programming language that are guaranteed to be available in all other languages. To help you with this, Microsoft has defined a commo n language specification (CLS) that details for compiler vendors the minimum set of features that their compilers must support if they are to target the runtime. Note that the CLR/CTS supports a lot more features than the subset defined by the common language specification, so if you donââ¬â¢t care about language interoperability, you can develop very rich types limited only by the capabilities of the language. Specifically, the CTS defines rules to which externally visible types and methods must adhere if they are to be accessible from any CLR-compliant programming language. Note that the CLS rules do not apply to code that is only accessible within the defining assembly. The figure below summarizes the way in which language features overlap with the CLS, within the wider context of the CLR/CTS. As this figure shows, the CLR/CTS offers a broadly inclusive set of features. Some languages expose a large subset of the CLR/CTS; in fact, A programmer willing to write in IL assembly language is able to use all the features offered by the CLR/CTS. Most other languagesââ¬âsuch as C#, VB, and Fortranââ¬âexpose a subset of the CLR/CTS features to the programmer. The CLS defines a minimum set of features that all languages must support. If you are designing a type in one language and you expect that type to be used by another language, then you should not take advantage of any features that are outside of the CLS. Doing so means that your type members might not be accessible by programmers writing code in other programming languages. In the code below, a CLS-compliant type is being defined in C#. However, the type has a few non-CLS-compliant constructs that cause the C# compiler to complain about the code: using System; // Tell compiler to check for CLS Compliance [assembly:CLSCompliant(true)] // Errors appear because the class is public public class App { // Error: Return type of App. Abc() is not CLS-compliant 18 Architecture of the . NET Framework public UInt32 Abc() { return 0; } / Error: Identifier App. abc() differing // only in case is not CLS-compliant public void abc() { } // No error: Method is private private UInt32 ABC() { return 0; } } In the code above, the [assembly:CLSCompliant(true)] attribute is applied to the assembly. This attribute tells the compiler to ensure that any publicly exposed type has no construct that would prevent the type from being accessed from any other pro gramming language. When the code above is compiled, the C# compiler emits two errors. The first error is reported because the method Abc returns an unsigned integer; Visual Basic. NET and some other languages cannot manipulate unsigned integer values. The second error arises because this type exposes two public methods which differ only by case: Abc and abc. Visual Basic. NET and some other languages cannot call both of these methods. Note that if you were to delete public from in front of class App and recompile, both errors would go away. The reason is that the App type would default to internal and would therefore no longer be exposed outside the assembly. For a complete list of CLS rules, refer to the Cross-Language Interoperability section in the . NET Framework SDK documentation. Let me distill the CLS rules to something very simple. In the CLR, every member of a type is either a field (data) or a method (behavior). This means that every programming language must be able to access fields and call methods. Certain fields and certain methods are used in special and common ways. To make coding these common programming patterns easier, languages typically offer additional abstractions. For example, languages expose concepts such as enums, arrays, properties, indexers, delegates, events, constructors, destructors, operator overloads, and conversion operators. When compilers come across any of these constructs in your source code, the compiler must translate them into fields and methods so that the CLR (and any other programming language) can access the construct. Consider the following type definition that contains a constructor, a destructor, some overloaded operators, a property, an indexer, and an event. Note that additional code is introduced to make the code compile; the code does not illustrate the correct way to implement a type. sing System; class Test { // Constructor public Test() {} // Destructor ~Test() {} // Operator overload public static Boolean operator == (Test t1, Test t2) { return true; } public static Boolean operator ! = (Test t1, Test t2) { return false; } 19 Applied . NET Framework Programming // An operator overload public static Test operator + (Test t1, Test t2) { return null; } // A Property public String AProperty { get { return null; } set { } } // An Indexer public String this[Int32 x] { get { return null; } set { } } // An Event event EventHandler AnEvent; } When the compiler compiles this code, the result is a type that has a number of fields and methods defined in it. You can easily see this using the IL disassembler tool (ILDasm. exe) provided with the . NET Framework SDK to examine the resulting managed module: The table on the next page shows how the programming language constructs got mapped to the equivalent CLR fields and methods: 20 Architecture of the . NET Framework Type Member AnEvent . ctor Finalize add_AnEvent get_AProperty get_Item op_Addition op_Equality op_Inequality remove_AnEvent set_AProperty set_Item Member Type Field Method Method Method Method Method Method Method Method Method Method Method Equivalent Programming Language Construct Event. The name of the field is AnEvent and its type is System. EventHandler Constructor Destructor Event add accessor method Property get accessor method Indexer get accessor method + operator == operator ! = operator Event remove accessor method Property set accessor method Indexer set accessor method The additional nodes under the Test type that are not mentioned in the table aboveââ¬â. lass, . custom, AnEvent, AProperty, and Itemââ¬âidentify additional metadata about the type. These nodes do not map to fields or methods; they just offer some additional information about the type that the CLR, programming languages, or tools can get access to. For example, a tool can see that the Test type offers an event, called AnEvent, which is exposed via the two methods (add_AnEvent and remove_AnEvent). Interoperability with Unmanaged Code The . NET Framework offers a ton of advantages over other development platforms. However, very few companies can afford to redesign and re-implement all their existing code. Microsoft realizes this and has built the CLR so that it offers mechanisms that allow an application to consist of both managed and unmanaged parts. Specifically, the CLR supports three interoperability scenarios: â⬠¢ Managed code can call an unmanaged function in a DLL. Managed code can easily call functions contained in DLLs using a mechanism called P/Invoke (for Platform Invoke). After all, many of the types defined in the FCL internally call functions exported from Kernel32. dll, User32. ll, and so on. Many programming languages will expose a mechanism that makes it easy for managed code to call out to unmanaged functions contained in DLLs. Example: A C# or VB application can call the CreateSemaphore function exported from Kernel32. dll. Managed code can use an existing COM component (server). Many companies have already implemented a number of unmanaged COM components. Using the type library from these components, a managed assembly can be created that describes the COM component. Managed code can access the type in the managed assembly just like any other managed type. See the TlbImp. exe tool that ships with the . NET Framework SDK for more information. If you do not have a type library or you want to have more control over what TlbImp. exe produces, you can manually build a type in source code that the CLR can use for doing the proper interop. Example: Using DirectX COM components from a C# or VB application. â⬠¢ 21 Applied . NET Framework Programming â⬠¢ Unmanaged code can use a managed type (server). A lot of existing unmanaged code requires that you supply a COM component for the code to work correctly. You can implement these components easily using managed code, avoiding all the code that has to do with reference counting and interfaces. See the TlbExp. exe and RegAsm. exe tools that ship with the . NET Framework SDK for more information. Example: Creating an ActiveX control or a shell extension in C# or VB. In addition to the above, the Microsoft Visual C++ compiler (version 13) supports a new /clr command-line switch. This switch tells the compiler to emit IL code instead of native x86 instructions. If you have a large amount of existing C++ code, you can recompile the code using this new compiler switch. The new code will require the CLR to execute, and you can modify the code over time to take advantage of the CLR-specific features. Note that the /clr switch cannot compile to IL any method that does one of the following: â⬠¢ â⬠¢ â⬠¢ â⬠¢ contains inline assembly language (via the __asm keyword), accepts a variable number of arguments, calls setjmp, contains intrinsic routines (such as __enable, __disable, _ReturnAddress, and _AddressOfReturnAddress). For a complete list of the constructs that the C++ compiler cannot compile into IL, see the documentation for the Visual C++ compiler. When the compiler canââ¬â¢t compile the method into IL, it compiles the method into x86 so that the application still runs. Note further that although the IL code produced is managed, the data is not managed. That is, data objects are not allocated from the managed heap, and they are not garbage collected. In fact, the data types do not have metadata produced for them and the type method names are mangled. The C code below calls the standard C runtime library printf function and also calls the WriteLine method in System. Console. Note that the System. Console type is defined in the Framework Class Library. Accordingly, C/C++ code can use libraries available to C/C++ as well as managed types. #include #using using namespace System; // For printf // For managed types defined in this assembly // Easily access System namespace types // Implement a normal C/C++ main function void main () { // Call the C-Runtime librarys printf function printf(Displayed by printf. ); // Call System. Consoles WriteLine method Console::WriteLine(Displayed by Console::WriteLine. ); } Compiling this code couldnt be easier. If the code above were placed in a Test. cpp file, youd compile it by executing the following line at the command prompt: cl /clr Test. cpp 22 Architecture of the . NET Framework The result is a Test. exe assembly file. If you run Test. exe, youll see the following output: C:;Test Displayed by printf. Displayed by Console::WriteLine. If you use ILDasm to examine this file, youââ¬â¢ll see the following: Here, ILDasm shows all the global functions and global fields defined within the assembly. Obviously, the compiler has generated a lot of stuff automatically. If you double-click the Main method, ILDasm will show you the IL code: . method public static int32 modopt([mscorlib]System. Runtime. CompilerServices. CallConvCdecl) main() cil managed { . vtentry 1 : 1 // Code size 28 (0x1c) . maxstack 1 IL_0000: ldsflda valuetype $ArrayType$0x0faed885 ? A0x44d29f64. unnamed-global-0 IL_0005: call vararg int32 modopt([mscorlib]System. Runtime. CompilerServices. CallConvCdecl) printf(int8 modopt([Microsoft. VisualC]Microsoft. VisualC. NoSignSpecifiedModifier) modopt([Microsoft. VisualC]Microsoft. VisualC. IsConstModifier)*) IL_000a: pop IL_000b: ldsflda valuetype $ArrayType$0x0e6cb2b2 ? A0x44d29f64. unnamed-global-1 IL_0010: newobj instance void [mscorlib]System. String::. ctor(int8*) IL_0015: call void [mscorlib]System. Console::WriteLine(string) IL_001a: ldc. i4. 0 23 Applied . NET Framework Programming IL_001b: ret } // end of method Global Functions::main What we see here isnââ¬â¢t pretty because the compiler generates a lot of special code to make all this work. You can see, however, that the IL above makes calls to both printf and the WriteLine method in Console. 24 Architecture of the . NET Framework 25
Thursday, May 14, 2020
Boxer Rebellion Timeline in China
At the turn of the 20th century, intense social pressure due to increasing foreign influence in Qing China led to an upsurge of participation in the Righteous Harmony Society Movement (Yihetuan), called the Boxers by foreign observers. From their base in drought-ravaged northern China, the Boxers spread across the country, attacking foreign missionaries, diplomats, and traders, as well as Chinese Christian converts. By the time it ended, the Boxer Rebellion had claimed almost 50,000 lives. Background to the Boxer Rebellion 1807: First Protestant Christian missionary arrives in China from the London Missionary Society.1835-36: Daoguang Emperor expels missionaries for distributing Christian books.1839-42: First Opium War, Britain imposes an unequal treaty on China and takes Hong Kong.1842: Treaty of Nanjing provides extraterritorial rights to all foreigners in China - they are no longer subject to Chinese law.The 1840s: Western Christian missionaries flood into China.1850-64: Christian convert Hong Xiuquan leads to bloody Taiping Rebellion against the Qing Dynasty.1856-60: Second Opium War; Britain and France defeat China and impose harsh Treaties of Tientsin.1894-95: First Sino-Japanese War, former tributary Japan defeats China and takes Korea.Nov. 1, 1897: Juye Incident, armed men kill two Germans at missionary home in Shandong Province, northern China.Nov. 14, 1897: German Kaiser Wilhelm II sends a fleet to Shandong, urges them to take no prisoners like Attila and the Huns.1897-98: Drought followed by flooding strikes Shandong, causing widespread misery. The Boxers Rebel 1898: Young men in Shandong form Righteous Fist groups, practicing martial arts and traditional spiritualism.June 11-Sept. 21, 1898: Hundred Days Reform, Emperor Guangxu tries to quickly modernize China.Sept. 21, 1898: On the verge of handing over sovereignty to Japan, Guangxu is stopped and goes into internal exile. Empress Dowager Cixi rules in his name.Oct. 1898: Boxers attack Liyuantun villages Catholic church, converted from a temple to the Jade Emperor.Jan. 1900: Empress Dowager Cixi rescinds condemnation of Boxers, issues letter of support.Jan-May, 1900: Boxers storm through the countryside, burning churches, killing missionaries and converts.May 30, 1900: British Minister Claude MacDonald requests defense force for Beijing foreign legations; Chinese allow 400 troops from eight nations into capital. The Rebellion Reaches Beijing Jun 5, 1900: Boxers cut railroad line at Tianjin, isolating Beijing.June 13, 1900: First Boxer appears in Beijings Legation (diplomatic) Quarter.June 13, 1900: Pro-Boxer General Dong Fuxians troops kill Japanese diplomat Sugiyama Akira.June 14, 1900: German Minister Clemens von Ketteler arrests and summarily executes a young boy he suspects of being a Boxer.June 14, 1900: Thousands of angry Boxers storm Beijing and burn Christian churches in response to boys murder.June 16, 1900: Empress Dowager Cixi and Emperor Guangxu hold council meeting, decide to fully support Boxers.June 19, 1900: Qing government sends messengers to offer foreign legation members safe passage out of Beijing; instead, the foreigners shoot the messengers dead.June 20, 1900: Manchu Bannerman Captain En Hai kills Minister von Ketteler in a melee to avenge the murdered Boxer boy. Siege of the Legations June 20-Aug. 14, 1900: Boxers and Chinese Imperial Army besiege legations sheltering 473 foreign civilians, 400 foreign soldiers, and approximately 3,000 Chinese Christians.June 21, 1900: Empress Dowager Cixi declares war against the foreign powers.June 22-23, 1900: Chinese set fire to parts of Legation district; priceless Hanlin Academy library burns.June 30, 1900: Chinese force Germans from a position atop Tartar Wall overlooking legations, but Americans hold the position.July 3, 1900: 56 US, British and Russian soldiers on Tartar Wall launch a 2 am a surprise attack, kill 20 Chinese soldiers, and drive survivors from the wall.July 9, 1900: Outside of Beijing; Shanxi Province governor executes 44 missionary families (men, women, and children) after offering them asylum at Taiyuan. Victims of Taiyuan Massacre become martyrs in eyes of Chinese Christians.July 13-14, 1900: Also 120 km (75 miles) outside Beijing, Battle of Tientsin (Tianjin); Eight-Nations relief force besieges Boxer-h eld city, 550 Boxers and 250 foreigners killed. Foreign troops (especially Germans and Russians) rampage through city afterward, looting, raping and killing civilians, while Japanese and Americans try to restrain them.July 13, 1900: In Beijing, Chinese set off a mine under French Legation, force French and Austrians to shelter in British compound.July 13, 1900: Advancing Chinese drive Japanese and Italian troops to precarious last defense line at Prince Sus palace.July 16, 1900: Australian journalist George Morrison injured and British Captain Strouts killed by Chinese snipers.July 16, 1900: London Daily Mail publishes aà report that all legation besieged had been massacred, including mercy killing of women and children, Russians boiled to death in oil, etc. The story was false, fabricated by a reporter in Shanghai.July 17, 1900: Eight-Nations relief force lands on the coast, begins the march to BeijingJuly 17, 1900: Qing government declares a cease-fire on legations.August 13, 19 00: Chinese end cease-fire, bombard legations as foreign rescue force approaches capital.August 14, 1900: Relief force lifts the siege on legations, forgets to relieve besieged Catholic North Cathedral until August 16.August 15, 1900: Empress Dowager Cixi and Emperor Guangxu escape Forbidden City dressed as peasants, go on inspection tour to ââ¬â¹theà ancient capital of Xian (formerly Changan) in Shaanxi Province. Aftermath Sept. 7, 1900: Qing officials sign Boxer Protocol, agree to pay huge war reparations over 40 years.Sept. 21, 1900: Russian troops seize Jilin and occupy Manchuria, moves that will spark 1904-05 Russo-Japanese Warââ¬â¹.Jan. 1902: Empress Dowager Cixi and Emperor Guangxu return to Beijing from Xian and resume control of the governmentââ¬â¹.1905: Empress Dowager Cixi abolishes imperial examination system for training bureaucrats in favor of western-style university system, part of an attempt at sweeping modernizationââ¬â¹.Nov. 14-15, 1908: Emperor Guangxu dies of arsenic poisoning, followed the next day by Empress Dowager Cixiââ¬â¹.Feb. 12, 1912: Qing Dynasty falls to Sun Yat-sen; formal abdication by Last Emperor Puyi.
Wednesday, May 6, 2020
Importance Of Books In Fahrenheit 451 By Ray Bradbury
Booksââ¬â¢ are a pillar of human civilization, they have cultivated our minds and expression. In most of human history, the powerful have tried to overwhelm the weak, and they have done this through the suppression information and knowledge. Fahrenheit 451 by Ray Bradbury discusses these ideas, by creating a dystopian society where the mere existence of books has been banned and eradicated. This fictional world in some facets of life has paralleled our own society, and for its time was inexplicably accurate in its predictions. The banning of books in society unnecessarily promotes the issue of suppression of knowledge and education. Reading banned books provides an intrinsic value, with its benefits heavily outweighing the drawbacks, it offersâ⬠¦show more contentâ⬠¦Whether it is for moral, political, or religious reasons, the banning of books is the suppression of knowledge and ideas. However, when a society decides to ban books, they are actively acknowledging the idea th at it is acceptable to restrict an individualââ¬â¢s freedom. Fahrenheit 451 depicts the vision of life where society allows a power, such as a government, to control free decision and thought. Although it was the most extreme version of banning, through the act of burning, it portrayed the destruction of the individualsââ¬â¢ choice to decide the idea of right and wrong. If someone does not want their child reading a book, they can prevent them, if someone does not agree with the contents of a book, they do not have to read it, nevertheless, that is their freedom to choose. Fahrenheit 451 discusses the desire for freedom, without the choice, no one will be able to fully understand the truth. This is the desire of Montag in the novel, is to read books, so that he can come to the truth on his own. It comes down to the rationality of who is allowed to justify morality, and the value it has in enhancing our lives and expression. Admittedly, banning books has shown benefits in protecting the innocence of the youth. In the U.S. most books are banned by schoolââ¬â¢s due to parents urging. With parents feeling uncomfortable with the contents of books, and the idea that it will be introduced to their children, they feel the necessity to ban itShow MoreRelatedRay Bradbury Compare And Contrast Essay903 Words à |à 4 PagesComparing and Contrasting Characteristics Ray Bradburyââ¬â¢s creation of character Montag in Fahrenheit 451 mirrors his own personal fears, social expectations, and importance of relations. Fahrenheit 451 is split up into 3 characteristics that the author, Ray Bradbury and the main character, Guy Montag share, bringing them to show their most common interestsâ⬠¦ their love for book. They are willing to go to the fullest extinct for their passion without letting anything get in their way and taking allRead MoreFahrenheit 451 - Power of Books1470 Words à |à 6 PagesTHE POWER OF BOOKS ESSAY Guy Montagââ¬â¢s ââ¬Å"crime against societyâ⬠, was that he understood the power of books. Fahrenheit 451 (1953), written by Ray Bradbury depicts a dystopian society which, due to the absence of books, discourages intellect and punishes free-will. As receptacles of knowledge, books give human beings a unique power, as they encourage and nurture intellect and understanding. The intellectual metamorphosis that Montag undergoes renders him aware of this fact, making him anRead MoreFahrenheit 451 And The Allegory Of The Cave By Ray Bradbury952 Words à |à 4 Pagespeople do not walk to a bookshelf and read a book in a one sitting anymore. Has the current world become similar to the society in Fahrenheit 451 written by Ray Bradbury? Fahrenheit 451 is set in a future idea of the world, where books are forbidden. Firefighters have a different type of job in this world; instead of putting out fires, they start them. One of the firefighters, Guy Montag, is not as interested in his job, he becomes interested in books. At a point in the story he is hunted down byRead MoreFahren heit 451 : The Burning Truth1149 Words à |à 5 PagesAlnagadi Doctor Clare Little Humanities 142 Aug/7/2014 ââ¬Å"Fahrenheit 451â⬠: The Burning Truth Introduction Fahrenheit 451 is the actual temperature at which paper catches fire. The story by Ray Bradbury represents a social criticism that alarms individuals against the risk of suppressing their feelings due to restrictions. The fascinating story of Bradbury, ââ¬ËFahrenheit 451ââ¬â¢ is interestingly well constructed. It can be clearly recognized that the book broadens the idea of a short story that the author wroteRead MoreRay Bradbury s Fahrenheit 4511721 Words à |à 7 Pagesliterature slowly disappear from the minds of the population? This is the question that Ray Bradburyââ¬â¢s novel, Fahrenheit 451, attempts to answer. In this book, he describes a hypothetical world in which the population not only avoids reading, but has made owning books an unthinkable crime, with all books discovered burned, along with the houses of those who hoarded them. In this dystopian future created by Bradbury, the beauty that is literature has been replaced in society by television programs andRe ad MoreRay Bradburys Fahrenheit 451: A World Without Books1095 Words à |à 5 Pagesââ¬Å"There is more than one way to burn a book. And the world is full of people running about with lit matchesâ⬠(Wikiquote, ââ¬Å"Ray Bradburyâ⬠). Author Ray Bradbury made this observation in 1979 and his thought has only become more true as time has gone on. Bradbury warns of the possibility of this happening in his novel, Fahrenheit 451. The message of Fahrenheit 451 is more important than ever because todayââ¬â¢s book editors, movie critics, and plays have intentionally and unintentionally removed Bradburyââ¬â¢sRead MoreAnalysis Of Ray Bradbury s Fahrenheit 451 1222 Words à |à 5 PagesSocietal Similarities Which of the three novels that were read this quarter related the most to modern American society? The first novel that was read this quarter was Fahrenheit 451 by Ray Bradbury, and this novel was about a dystopian society and the importance of reading. The next book that was read was Aldous Huxleyââ¬â¢s Brave New World and this novel was about a society where production is the first priority. Then the last novel read was 1984 by George Orwell, this novel was about a society whereRead MoreRay Bradbury s Fahrenheit 4511410 Words à |à 6 PagesRay Bradburyââ¬â¢s Fahrenheit 451, published in 1953 by Ballantine Books, rose to fame quickly and surely as a grandfather of the dystopian genre. A year after its release, Greg Conklin of Galaxy Science Fiction named the novel, ââ¬Å"among the great works of the imagination written in English in the last decade or moreâ⬠(Conklin). The Chicago Sunday Tribune s August Derleth called it a shockingly savage prophetic view of one poss ible future way of life, while honoring Bradbury in sight of his brilliantRead MoreFarenheit 451 : Author And Original Year Of Publication1705 Words à |à 7 PagesEnglish Novel Study Form Title: Fahrenheit 451 Author and Original Year of Publication: Bradbury, 1953 MLA citation: Bradbury, Ray. Fahrenheit 451. New York: Ballantine Publishing, 1978. Print. Pertinent biographical information on author (must include a citation that matches the Works Cited page): Ray Bradbury was born in Waukegan, Illinois on August 22, 1920. Bradbury chose the writer path at the age of twelve and thirteen where he later discovered the importance of writing and the library whichRead MoreAnalysis Of Ray Bradbury s Fahrenheit 451 1396 Words à |à 6 PagesAnalysis of Freedom of Information in Fahrenheit 451 by Ray Bradbury This study examines the issue of freedom of information in the story of literary oppression found in Fahrenheit 451 by Ray Bradbury. Bradbury presents the oppression of an authoritarian state that does not allow its citizens to reads books. Guy Montag is initially a servant of the state that requires him to locate and persecute members of the community that still collect books. In various cases, Bradbury defines the rights of certain
Tuesday, May 5, 2020
Cross Cultural Management for Global Leadership- myassignmenthelp
Question: Discuss about theCross Cultural Management for Global Leadership. Answer: Introduction: The essay aims at providing an insight into the article, From cross-cultural management to global leadership: Evolution and Adaptation. The mentioned article put forward a historical review on the evolution of global leadership. While doing this, the article has also discussed the origin of leadership in the presence of cross cultural management. The essay tries to identify whether the evolutionary trends within the domain of the cross cultural management in actuality leads to the formation of global leadership. The essay will also portray the evidence used for justification of the argument. There are also supporting links in the essay to show support or distraction from the overall hypothesis of the article. The essay will concludes on a note providing necessary justifications and reasons for agreeing or disagreeing with the point of view of the article. Discussion: According to Osland (2012), the concept of the global leadership took birth as result of the needs of the corporations in adapting to the global strategies, international expansion and competition in global marketplace. There realizations amongst corporations such capabilities were required for the development and implementation of the new strategic initiatives that necessitated the creation of various company specific models for development. Being a very young to the field, many training programmes and models offered by the consulting companies does not any empirical evidence. Global leadership is thus refers to the method of influencing the thought, attitude and behavioural process of the global community so that they can synergistically work towards a common goal or mission. Bird and Medenhall (2016), thus puts forward the concept of the cross cultural management as differences in the cultural practices while undertaking management activities outside the home country which often takes comparative perspective. They tried to addresses a broader field of international management and referred to it as the cross cultural management which acted as the source for the advent of the global leadership divided into four stages and tried to review the way in which the literature of cross cultural management dealt with concept of the leadership at each of the stages. Further they tried to put forward how the different streams from each of the stages gave rise to global leadership. Thus, according to the authors, the basis of global leadership remains multifaceted and is a reflection of composite contribution of intercultural communication, expatriate, global management and comparative leadership streams of research. Although the streams do not directly focus on the c hallenge of the global context but each of the streams put forward perspectives that remain useful for thinking about the attributes, roles and skills necessary for engaging in global leadership. The Stream one represents expatriation where the Employees from the home country are send to work for a period that ranges between six months to five years. Stream two on the other hand represents intercultural communication which refers to the ability of appropriately and effectively executing the communication behaviour that leads to the formation of a diverse environment culturally. Stream three portrays comparative leadership which represents the differences between the behaviour of leader and follower between different cultures. This helps in explaining why leaders in the higher power distance cultures remain more autocratic compared to the ones in the cultures with lower power distance. While the stream four refers to the global management since it ensures involvement of the responsibility across the cross border which sometimes requires the balancing the competing as well as contradictory demands across the multiple units in the different countries and the regions. The researc h on the global managers often remains couched in contrast to the domestic managers. Evidence Justifying the Authors Argument Bird and Medenhall (2016) also tried to point out that the empirical works on global leadership carried till date has focused completely on the understanding of the competencies, attributes, skills and traits. Yeung and Readys (2005) carried out a quantitative study that helped in analyzing the samples of close to 1200 managers who were working in 10 different corporation across 8 countries. The list was made based on the identification of the competencies that included articulating a vision which is tangible, possession of the orientation of results, possession of customer orientation ability and the ability of empowering the others. Black et al. (2013) undertook the interview process of close to 130 HR managers and the line executives for finding the criteria for the global executive. Goldsmith et al. (2006) interviewed close to 207 global and current leaders. The study included close to included 200 higher potential executives, questionnaire of the focus group consisting of 28 CEO s. With focus on the task analysis of the global leader and the necessary ability, knowledge and skill, Caligiuri and Tarique (2012) carried out the survey of close to 240 leaders operating globally. Evidence against the Authors Argument Bird and Medenhall (2016), through their analysis also found that there was huge number of competencies that conceptually overlapped while there were many that differed only in the semantic terms. There were even some that overlapped with the variables that directly influenced the selection of the expatriate, their effectiveness, adjustment and transformation along with the variables that remained crucial to the intercultural communication. However, Mendenhall and Osland (2002) ensured command over the chaotic nature by grouping the dimensions of competency into six broader categories that included expertise in global business, visioning, global organization savvy, cognitive orientation, values and traits and the skills for building cross cultural relationships. Thus, the competencies of global leadership span over range of qualitative characteristics. There are however various pre-dispositional characteristics of the personality that includes optimism and inquisitiveness while the a ttitudinal orientations includes results orientation or Cosmo politanism. The cognitive capabilities include intellectual intelligence or cognitive complexity whereas motivational inclinations include tenacity or the motivation of learning. The knowledge bases include the knowledge related to the global business or the technical skills which are value added the behavioural skill represents boundary spanning or cross cultural communication. This makes the global leadership a set of competencies which are multifaceted. Also, according to Jeong, Lim, and Park (2016), there appears to be a growing interest in the concept of global leadership amongst the practitioners and the scholars since the institution and the organizations increasingly recognizes its strategic importance for the expanding services, products and the resources. Then area of human resource development (HRD) have also emphasized on the core competencies of the global leadership. The core competencies of the global leadership primarily included expatriate and cross-cultural training, international business, management and Human Resource Development (HRD), organizational leadership and psychology. However, while reviewing the literature for the leadership there existed little consensus among researchers and the practitioners regarding the criteria of global leadership and the means for developing the global leaders. There were however suggestions from the scholars regarding the various approaches for not only developing the global lead ers but also the competency models for global leadership. The different perspectives were related by discipline that helped in easily explaining the global leadership. For instance, literature related to the expatriates emphasizes the experiences of the global leaders in carrying out the international assignments in the foreign country whereas the cross cultural studies focus on the identification of the similarities or the cultural differences for improving socialization, adaptation and communication across the different cultures. In spite of the differences, studies related to the global leadership have tried in capturing the influence of leaders as change agents across the borders in a multicultural, equivocal and complicated environment. As per, Jeong, Lim, and Park (2016), put forward the definition of global leadership as leadership of the individuals who influences and brings about major positive change within communities, organization and firm through the facilitation of the appropriate trust level, process and structures of the organization and involves varied stakeholders, culture and resources under the complexity of geographical, cultural and temporal conditions. Thus, based on the definition global leadership considered a process while the global leaders as the individuals. This definition is appropriately selected since it comprehensively explains the global leadership features aligned with the concept put forward by Bird and Mendenhall (2016) who also addressed the diverse contexts of the global leadership through highlighting the situational complexity and the multiple cultures whereas the other definitions emphasized on the particular aspects of global leadership related to traits, leadership roles and diversity. According to Jeong, Lim, and Park (2016), the global leaders included managers and leaders of both the groups across the levels since they not only influence their subordinates but also influence the colleagues, upper managers and div erse stakeholders under the global contexts particularly characterized as uncertain, dynamic and complex. Thus, the global leaders and the managers is regarded as the emerging group of professionals who are capable of adapting to the operations carried out in the multicultural and international context, a breed with the identifiable traits who works primarily in the organizations spanning the national borders. However, according to the views put forward by Hassanzadeh et al. (2015), global leaders needs a specific set of global competencies of leadership for effective fulfilment of their roles. They helped in identifying the seven competencies of the global leaders which includes Culture Sensitivity and awareness Global perspective and mindset Learning from the experiences Maintaining and developing relationships Communication Attitudes and traits Skills and knowledge They also put forward the importance for describing and identifying the global leadership competencies. There are various organizations who do not have defined global leadership competencies since their competencies are mostly related to the domestic leaders. But with globalization moving at a rapid speed there raises the need for more global leaders. According to Allon and Higgins (2018), global leaders need to be emotionally sensitive and culturally attuned. They also put forward the necessity of developing leaders who is capable of responding to specific foreign ambience of the different countries having varied interpersonal work conditions. Therefore, according to them, there two emerging constructs relevant for effective global leaders which includes emotional intelligence and culture. It is found that under the conventional view of the intelligence specifically measured by the IQ, emotional and cultural intelligences provides the necessary framework for effective understanding the cross cultural leadership and the clarification of the possible adaptations that requires implementation in the development programs related to leadership for the multinational firms. Therefore, the authors try to portray that analytical intelligence (IQ), emotional intelligence (EQ) and the leadership behaviours restrained by the cultural intellig ence (CQ) for the formation of a successful global leadership. Finn (2012) tries to put forward that the world keeps constantly changing around the organizations on a day to day basis. To deal with such changes leaders portrays an increasing need of the innovation in the technology, newer ways of doing the business, globalization and the emerging markets. Without added dimension of global context, changes within organizations are difficult. Issues such as the language, culture and the geographical context are some of the obstacles faced by the leaders while attempting to effect change on a global scale. Here the author mentions bout the contextual and the cultural factors involved in the global leadership that allows for in depth understanding of the differences and similarities that exists between the domestic and global change. Conclusion: To conclude, one can say that although the research made an attempt of incorporating various frameworks of global leadership however it was not without the limitations. The limitation helps in preventing the generalization of the more convergent behavioural characteristics of the leader. There was also discussion related to the relevant theories of the leadership or the perspectives for fulfilling the definition of the global leadership. The mention of the leadership theories like cross-cultural leadership, entrepreneurial leadership, authentic leadership, flexible leadership, strategic leadership and situational leadership would have merit additional development and integration of the global leadership. The behaviours or the competencies identified in numerous studies are not only redundant but also lack an effective and systematic framework thereby making it challenging for the practitioners and the researchers for extracting the suitable competency required for the global leaders. There was another problem which lay in the challenge of creation of the behaviour scale and the competencies that remains effective across the cultures. References: Alon, I. and Higgins, J.M., 2018. Global leadership success through emotional and cultural intelligences.Business horizons,48(6), pp.501-512. Bird, A., Mendenhall, M., Osland, J., Oddou, G. and Reiche, S., 2016. Global Leadership in Perspective.The Routledge Companion to Leadership, p.348. Black, J.S., Morrison, A.J. and Gregersen, H.B., 2013.Global explorers: The next generation of leaders. Routledge. Brownell, J. and Goldsmith, M., 2006. Commentary on meeting the competency needs of global leaders: A partnership approach: An executive coach's perspective.Human Resource Management,45(3), pp.309-336. Caligiuri, P. and Tarique, I., 2012. Dynamic cross-cultural competencies and global leadership effectiveness.Journal of World Business,47(4), pp.612-622. Finn III, E., 2012. Global leadership in a changing world. Hassanzadeh, M., Silong, A.D., Asmuni, A. and Wahat, N.W.A., 2015. Global Leadership Competencies.Journal of Educational and Social Research,5(2), p.137. Karin Andreassi, J., Lawter, L., Brockerhoff, M. and J. Rutigliano, P., 2014. Cultural impact of human resource practices on job satisfaction: A global study across 48 countries.Cross cultural management,21(1), pp.55-77. Mendenhall, M.E., Osland, J., Bird, A., Oddou, G.R., Stevens, M.J., Maznevski, M.L. and Stahl, G.K. eds., 2017.Global leadership: Research, practice, and development. Routledge. Park, S., Jeong, S., Jang, S., Yoon, S.W. and Lim, D.H., 2017. Critical Review of Global Leadership Literature: Toward an Integrative Global Leadership Framework.Human Resource Development Review, p.1534484317749030. Yeung, A.K. and Ready, D.A., 2005. Developing leadership capabilities of global corporations: A comparative study in eight nations.Human Resource Management,34(4), pp.529-547.
Subscribe to:
Posts (Atom)