Briki: a Flexible Java Compiler
|
|
|
- Wendy Henry
- 10 years ago
- Views:
Transcription
1 Briki: a Flexible Java Compiler Michał Cierniak Wei Li Technical Report 621 Department of Computer Science University of Rochester Rochester, NY May 1996 Abstract We present a Java compiler architecture which uses a unique combination of front- and back-ends to deliver great flexibility. Our compiler is designed to use the same optimization passes no matter which pair of front- and back-end is used. The compiler can be configured as a traditional stand-alone compiler (which compiles Java source into Java bytecodes). Another configuration can be used as an on-the-fly optimizer (which optimizes applets as they are loaded from the network). We can also compile Java directly to native code, thus using Java as a replacement for one of the traditional programming languages. Other interesting setups are also possible. This flexibility is achieved by using a common intermediate representation, (Java Intermediate Representation). Multiple front-ends convert various input formats (Java source, bytecode) into. Once represented as an application can be transformed with any of the existing passes. The modified form of an application can be written out in one of the supported output formats. Although compilers with multiple front- and back-ends have already existed, our approach is unique in supporting high-level code transformations even on applications which are distributed without the source program. Since Briki is written in Java it can be easily integrated into any Java application (e.g. a WWW browser) which dynamically loads applets from the network to provide capabilities of on-the-fly optimization. This work was supported in part by an NSF Research Initiation Award (CCR ) and ARPA contract F C-0057.
2 1 Introduction One of the goals of the design of the Java programming language has been to enable the creation of portable applications which can be distributed over the network. One possible use of such applications (called applets) is by including them in HTML pages which can be accessed with World Wide Web browsers, such as Netscape Navigator, HotJava or Internet Explorer. The definition of Java includes both the definition of the programming language itself [6] and the definition of the virtual machine [7] which can run compiled Java applications distributed in the form of bytecodes [4]. An application in the bytecode form can run on any computer with an implementation of the Java virtual machine. As the technology matures, advanced compiler optimizations are being proposed to speed up execution of Java applications (unless explicitly stated otherwise, by a Java application we mean either a stand-alone application or an applet). Many techniques used to optimize programs written in other programming languages can be successfully applied to Java programs, other techniques are unique to Java. This paper does not describe any of those specific optimizations. Rather, we present a new way of applying arbitrary optimization techniques. We are developing an optimizing compiler with multiple front- and back-ends. The idea of re-using much of the compiler code for different programming languages (by having multiple front-ends) and for different target machines (by having multiple back-ends) is not new. There exist commercial compiler systems which use this approach to create multiple compilers which share the same code base. Java allows something else. It is possible to write a compiler which could apply the same optimizations to all Java applications whether they are distributed with the source code or as bytecode files (.class files). This can be accomplished by having two front-ends: one which would read Java source and another one which would read bytecode. Similarly, the same compiler could generate the target code as Java source, bytecode, or possibly native code for a given machine (either directly or by generating other high-level language, such as C, which can be compiled into efficient native programs). A diagram presenting the structure of our compiler is shown in Figure 1. (Java Intermediate Representation) is used by us to represent Java programs. Java is the first popular programming language which allows high-level optimizations on the applications distributed without the source code. Previously, all the optimizations had to applied before the binary distribution was produced. Once a user purchased an application without source, it would become immutable even if the progress in compiler technology brought new techniques which could significantly speed up this type of an application. Java bytecode made it possible to develop a compiler which could directly optimize applications distributed without source. Depending on the combination of front- and back-ends the compiler can be used in different ways. The most common combinations that we anticipate are: Java to bytecode A conventional compiler a replacement for javac [8]. bytecode to bytecode This can be used to optimize applications distributed without source. One could for instance integrate such a compiler with a web browser and perform optimizations on-the-fly. 1
3 Java source Code transformations Java source Java bytecode Java bytecode C etc. Figure 1: An overview of the compiler Java to Java Code-cleaning, pretty-printing. Also new optimizations which are just being developed can be debugged much easier if the output is human-readable. bytecode to Java This allows, for instance, profiling an application distributed without source, yet see the profiling information in a source format. This is an invaluable tool for researchers who want to understand the behavior of existing applications to design new optimization techniques. bytecode to native code On-the-fly (just-in-time) compilation. Java to native code Off-line compilation to native code. Off-line compilation to native code would let us use Java as a replacement for one of the traditional languages (C, C++, etc.) It is also possible to compile other programming languages [9] into. This approach has been proposed to allow for distribution of non-java programs in the bytecode form. It would be of course possible to write a front-end to our compiler for any of the languages which can be compiled into Java bytecode. All those combinations of front- and back-end can share the same code-transformation passes. One interesting application developed with our compiler uses the bytecode to Java set to instrument.class files. We have developed a profiling tool called NetProf [5] which instruments Java applications distributed as bytecode and interactively presents the profiling information in a visualization applet. That way we can profile applets over a network without explicit downloading. The rest of the paper describes our compiler and the status of its implementation. Section 2 describes the compiler at a high-level. Section 3 gives an overview of our universal intermediate representation for Java programs. Selected features of the compiler are demonstrated on examples in Section 4. Restrictions on current implementation are explained in Section 5. 2
4 2 Implementation Our main design goal was to build a compiler that can re-use the same transformation passes while working on different source and target representations of a Java program. There were also other requirements that we had on mind: The intermediate representation should be high-level enough that most of the information contained in the source program is easily accessible and reasoning about the program can be done in source-level terms. The compiler should be written in Java, so that it can be easily integrated into network applications to perform, for instance, on-the-fly (just-in-time) compilation/optimization or profiling over the network. The compiler should be light-weight so that the overhead of integrating it into other applications would be minimized. After considering the above requirements, we made the following design decisions. We chose to design our intermediate representation to be a syntax tree. Although other representations exist in contemporary compilers, a syntax tree structure is common in the advanced research compilers such as Polaris [1, 3], SUIF [10] or Sage++ [2]. As our intermediate representation for Java, we have designed (Java Intermediate Representation) which is a syntax tree whose structure follows the source code as close as possible. is discussed in more detail in Section 3. We have designed our front- and back-ends so that they can be used as parts of both applets or stand-alone applications. A compiler driver includes calls to the front-end(s) which read the input from a Java InputStream and back-end(s) which can write the output to an OutputStream. In addition to using stream as I/O, our compiler can use other data formats if they are more appropriate. For instance, our Java source back-end can generate the source in an array of strings, to make visualization simpler and more efficient. Note that the security models for Java applets in existing WWW browsers does not allow for dynamic bytecode transformations, but we anticipate that this situation will change as the technology matures. From a technical point of view, it is trivial to modify a browser so that every class is being passed to our compiler before it being loaded. 3 Intermediate Representation The intermediate representation is a syntax tree with a node for every Java class defined in the input. Every class node contains references to nodes for all interfaces, fields and methods defined for that class as well as some other information (access flags, a reference to the super class etc.). is our implementation of this intermediate representation. An overview of is presented in this section. Figure 2 shows a class hierarchy for a subset of the classes used in. For simplicity of the discussion assume that the compiler reads and stores only one class. The extension to handle multiple classes is straightforward. 3
5 JClass Jmethod JBlock JStatement JIfStmt JLoopStmt JReturnStmt JWhileStmt JThrowStmt JIntConstExpr JExpression JFieldExpr JNewExpr JBinOpExpr Figure 2: Class hierarchy of the nodes in the intermediate representation (only selected expression and statement types are shown) We will use the following, very simple example to illustrate how represents Java programs. class simple { int i; public simple() { i = 0; } } //simple A complete representation of class simple takes care of many details that are required to maintain the meaning of the program. The image gets even more complicated by the fact that some information is replicated so that it can be accessed quickly. We show a subset of the form of simple in Figure 3. Not all nodes are shown and not all fields are present. Each box represents a Java object which implements a node in. The name in the top left corner is the name of the class which is the type of a given node. All other lines represent fields with field name on the left side (in italics) and the value on the right side. Whenever a value is a reference, it is shown as an arrow pointing to an object. To keep the size of Figure 3 maintainable, we have omitted the symbol table for the constructor and the representation of the statement super() and the expression this. The representation is not exactly the same as the original source. Instead, corresponds exactly to the code generated by the compiler. In our example, the code for the constructor contains implicitly two additional statements: public simple() { super(); // implicit constructor call 4
6 JClass JField name: super: interfaces: fields: methods: simple java.lang.object name: sig: value: i I JMethod JBlock name: sig: num_args: block: <init> ()V 0 sym_tab constructor_call stmt_list "super()" JAssignStmt JFieldExpr JReturnStmt lhs: rhs: class_expr: field_name: sig: i I "this" result: JIntConstExpr value: 0 Figure 3: A simplified view of the representation of the class simple } i = 0; return; // implicit return statement All implicit methods, statements and expressions are represented explicitly in. Note that the constructor call is not inserted in the same list as all other statements. The reason is that the constructor call is sufficiently different in its properties that we decided to keep a reference to it in separate field All nodes in the syntax tree are objects of some class derived from the class (see Figure 2). The intermediate representation defines classes which are not derived from, but none of them can be used as a node in the tree. A class is represented with an object of a class JClass which contains lists of objects representing fields, methods and interfaces. Let us discuss the representation of methods (fields and interfaces follow the similar idea, but are much simpler). As can be seen in Figure 3, a method is represented with an object of the class JMethod. If the method is not native, this object contains a reference to an object of type JBlock which in turn contains a reference to the symbol table and a list of statements. A statement may contain other statements or expressions. 5
7 4 Code Transformations This section explains on some examples what kind of transformations are performed by our compiler. For lack of space, we do not include technical details about how the transformations are being performed. We mostly follow known techniques which we customized for the specific need of the Java language. 4.1 Recovering High-level Structure One of the important features of our compiler is the ability to recover high-level structure of the source Java program given its bytecode representation. Consider the following code fragment of a.class file as disassembled by javap [8]. It is not apparent what this sequence of bytecodes does. 0 iload_1 1 iconst_1 2 if_icmpeq 10 5 iload_1 6 iconst_3 7 if_icmpne aload_0 11 iconst_1 12 putfield #4 <Field cond1.i I> 15 goto aload_0 19 iconst_2 20 putfield #4 <Field cond1.i I> 23 aload_0 24 dup 25 getfield #4 <Field cond1.i I> 28 iconst_1 29 iadd 30 putfield #4 <Field cond1.i I> One can of course understand this code with some effort. Nevertheless, many compiler algorithms are best expressed in terms of high-level constructs like a loop or an assignment. Our compiler parses the above sequence of Java VM instructions and generates an equivalent representation which can be printed as the following Java source fragment (as described earlier the internal representation is not directly printable since it is a collection of Java objects with references to each other). if(((a1 == 1) (a1 == 3))) { this.i = 1; } else { 6
8 this.i = 2; } //if this.i = (this.i + 1); Note that a1 is used to represent the first argument to the method containing this sequence of bytecodes. The identifier used by the programmer in the source cannot be recovered. This makes a difference only if we intend to de-compile the source for human use. For the compiler the identifier is not relevant. What is important is the type of the parameter and this can be easily recovered from the bytecode representation of a class. 4.2 Instrumentation Instrumentation is an example of a compiler transformation which can be easily implemented with our compiler. To visualize the performance of a program, we would like to instrument source level constructs, so that we are able to say how many times a loop was executed, how often was the else-branch of an if-statement taken, etc. Instrumenting the code with method invocations at the beginning and end of all interesting control-flow blocks is trivial if we do it at the level. NetProf [5] is a set of tools which can visualize performance information over a network. NetProf first instruments a class that is to be profiled, then the application is executed, and after it terminates a visualization tool presents the performance in the terms of the recovered Java source. The instrumentation is done with our Java compiler configured as shown in Figure 4. Java bytecode NetProf instrumentation Java source Figure 4: NetProf instrumentation The dashed box in Figure 4 shows the instrumentation pass which had to be written for NetProf. All the other actions shown the diagram are handled by the compiler: bytecode is read from a Java stream (e.g. a file), it is converted to and after the instrumentation takes place the transformed is written out as Java source. The instrumentation pass was created with relatively little effort and all code needed to insert calls to the instrumentation library and adding new fields to the instrumented class is contained in a file less than 400 lines long. 4.3 Generating Java Source Given that the structure of follows closely the structure of a Java program, the Java source back-end is very simple. It walks the tree and recursively prints its subtrees. The Java source in Section 4.1 was generated automatically with the Java source back-end. 7
9 5 Status of Our Implementation Currently we have implemented only one front-end, bytecode and one back-end, Java source. Given finite resources the choice was made since it is both most interesting and most general. Figure 5(a) shows the current status of our implementation. Java source A javac bytecode bytecode B bc front-end bc front-end Java back-end Java back-end Java source Java source 1 javac bytecode 2 j2c C 3 (a) Current implementation (b) Constructing "virtual" front- and back-ends by using publicly available compilers Figure 5: Current status of our compiler. Of the two front-ends of interest: bytecode and Java source, we picked the bytecode front-end since it is more difficult to develop and we wanted to make sure that is designed so that it can be recovered from bytecode. Since the structure of follows closely the syntax of Java programs, developing a front-end for Java source will be relatively easy, especially that there exist grammars for Java in a form which can be used to automatically generate a parser for Java. It is even possible to obtain the source code for the Java compiler developed by Sun Microsystems. Choosing the bytecode front-end has an additional advantage that we can use any of the publicly available Java to bytecode compilers, such as javac which is distributed as part of the Java Developer s Kit [8] to create a virtual Java front-end. Furthermore, if compilers from other languages to the Java bytecode are developed, we can also create virtual front-ends for those languages. One such compiler that is available now is AppletMagic [9] developed by Intermetrics. AppletMagic compiles Ada 95 to Java bytecode. 8
10 Choosing Java source as the back-end has a similar advantage. We can use javac [8] to compile the output of our compiler to bytecode. The bytecode can be further compiled into C using j2c [11]. This gives us two additional virtual back-ends. Figure 5(b) shows those possibilities with the front-ends marked with capital letters and the back-ends marked with numbers. All possible letter number combinations give a valid compiler. There are six such compilers available now (nine if we include AppletMagic). We plan to implement some of the other front- and back-ends directly in our compiler. The highest priority is for the bytecode back-end which is necessary for on-the-fly optimizations. 6 Conclusion We have presented a Java compiler infrastructure which can be used to easily build optimizing compilers, code instrumentation tools, de-compilers, pretty-printers, code-verifiers and other programs which transform or analyze Java applications. Our compiler works on Java applications distributed in any form even if the source program is not available. Since the compiler itself is written in Java, it is easy to integrate it into most Java software (e.g. WWW browsers) which dynamically loads Java applets from the network. References [1] B. Blume, R. Eigenmann, K. Faigin, J. Grout, J. Hoeflinger, D. Padua, P. Petersen, B. Pottenger, L. Rauchwerger, P. Tu, and S. Weatherford. Polaris: The Next Generation in Parallelizing Compilers. In K. Pingali, U. Banerjee, D. Gelernter, A. Nicolau, and D. Padua, editors, Languages and Compilers for Parallel Computing: 7th International Workshop, volume 892 of Lecture Notes in Computer Science. Springer-Verlag, Berlin/Heidelberg, [2] F. Bodin. Sage++: An Object-oriented Toolkit and Class Library for Building Fortran and C++ Restructuring Tools. In Proceedings of the Second Annual Object-Oriented Numerics Conference, [3] K. A. Faigin, J. P. Hoeflinger, D. A. Padua, P. M. Petersen, and S. A. Weatherford. The Polaris Internal Representation. Technical Report 1317, Center for Supercomputing Research and Development, University of Illinois at Urbana-Champaign. [4] J. Gosling. Java Intermediate Bytecodes. In Proceedings of the ACM SIGPLAN Workshop on Intermediate Representations (IR 95), pages , San Francisco, CA, January In ACM SIGPLAN Notices 30:3 (March 1995). [5] S. Parthasarathy, M. Cierniak, and W. Li. NetProf: Network-based High-level Profiling of Java Bytecode. May submitted for publication. [6] Sun Microsystems. The Java Language Specification. October 30, Version 1.0 Beta. 9
11 [7] Sun Microsystems. The Java Virtual Machine Specification. August 21, Release 1.0 Beta. [8] Sun Microsystems. The Java(tm) Developer s Kit. May Version 1.0. Available at [9] S. T. Taft. Programming the Internet in Ada 95. March submitted for publication. [10] R. P. Wilson, R. S. French, C. S. Wilson, S. P. Amarasinghe, J. M. Anderson, S. W. K. Tjiang, S.-W. Liao, C.-W. Tseng, M. W. Hall, M. S. Lam, and J. L. Hennessy. SUIF: An Infrastructure for Research on Parallelizing and Optimizing Compilers. ACM SIGPLAN Notices, 29(12):31 37, December [11] J2c/CafeBabe java.class to C translator. January Available at info/andoh/java/j2c.html. 10
02 B The Java Virtual Machine
02 B The Java Virtual Machine CS1102S: Data Structures and Algorithms Martin Henz January 22, 2010 Generated on Friday 22 nd January, 2010, 09:46 CS1102S: Data Structures and Algorithms 02 B The Java Virtual
Advanced compiler construction. General course information. Teacher & assistant. Course goals. Evaluation. Grading scheme. Michel Schinz 2007 03 16
Advanced compiler construction Michel Schinz 2007 03 16 General course information Teacher & assistant Course goals Teacher: Michel Schinz [email protected] Assistant: Iulian Dragos INR 321, 368 64
Interpreters and virtual machines. Interpreters. Interpreters. Why interpreters? Tree-based interpreters. Text-based interpreters
Interpreters and virtual machines Michel Schinz 2007 03 23 Interpreters Interpreters Why interpreters? An interpreter is a program that executes another program, represented as some kind of data-structure.
Chapter 13 Computer Programs and Programming Languages. Discovering Computers 2012. Your Interactive Guide to the Digital World
Chapter 13 Computer Programs and Programming Languages Discovering Computers 2012 Your Interactive Guide to the Digital World Objectives Overview Differentiate between machine and assembly languages Identify
Topics. Introduction. Java History CS 146. Introduction to Programming and Algorithms Module 1. Module Objectives
Introduction to Programming and Algorithms Module 1 CS 146 Sam Houston State University Dr. Tim McGuire Module Objectives To understand: the necessity of programming, differences between hardware and software,
language 1 (source) compiler language 2 (target) Figure 1: Compiling a program
CS 2112 Lecture 27 Interpreters, compilers, and the Java Virtual Machine 1 May 2012 Lecturer: Andrew Myers 1 Interpreters vs. compilers There are two strategies for obtaining runnable code from a program
Programming Languages
Programming Languages In the beginning To use a computer, you needed to know how to program it. Today People no longer need to know how to program in order to use the computer. To see how this was accomplished,
CSE 452: Programming Languages. Acknowledgements. Contents. Java and its Evolution
CSE 452: Programming Languages Java and its Evolution Acknowledgements Rajkumar Buyya 2 Contents Java Introduction Java Features How Java Differs from other OO languages Java and the World Wide Web Java
Contents. Java - An Introduction. Java Milestones. Java and its Evolution
Contents Java and its Evolution Rajkumar Buyya Grid Computing and Distributed Systems Lab Dept. of Computer Science and Software Engineering The University of Melbourne http:// www.buyya.com Java Introduction
Chapter 13: Program Development and Programming Languages
Understanding Computers Today and Tomorrow 12 th Edition Chapter 13: Program Development and Programming Languages Learning Objectives Understand the differences between structured programming, object-oriented
Integrating TAU With Eclipse: A Performance Analysis System in an Integrated Development Environment
Integrating TAU With Eclipse: A Performance Analysis System in an Integrated Development Environment Wyatt Spear, Allen Malony, Alan Morris, Sameer Shende {wspear, malony, amorris, sameer}@cs.uoregon.edu
1. Overview of the Java Language
1. Overview of the Java Language What Is the Java Technology? Java technology is: A programming language A development environment An application environment A deployment environment It is similar in syntax
Computing Concepts with Java Essentials
2008 AGI-Information Management Consultants May be used for personal purporses only or by libraries associated to dandelon.com network. Computing Concepts with Java Essentials 3rd Edition Cay Horstmann
How to make the computer understand? Lecture 15: Putting it all together. Example (Output assembly code) Example (input program) Anatomy of a Computer
How to make the computer understand? Fall 2005 Lecture 15: Putting it all together From parsing to code generation Write a program using a programming language Microprocessors talk in assembly language
Java vs. Java Script
Java vs. Java Script Java and Java Script share two very similar names, but they are completely different languages that possess few commonalties. They differ both in their purpose and the applications
Chapter 13: Program Development and Programming Languages
15 th Edition Understanding Computers Today and Tomorrow Comprehensive Chapter 13: Program Development and Programming Languages Deborah Morley Charles S. Parker Copyright 2015 Cengage Learning Learning
Algorithm & Flowchart & Pseudo code. Staff Incharge: S.Sasirekha
Algorithm & Flowchart & Pseudo code Staff Incharge: S.Sasirekha Computer Programming and Languages Computers work on a set of instructions called computer program, which clearly specify the ways to carry
CSCI 3136 Principles of Programming Languages
CSCI 3136 Principles of Programming Languages Faculty of Computer Science Dalhousie University Winter 2013 CSCI 3136 Principles of Programming Languages Faculty of Computer Science Dalhousie University
The Java Series. Java Essentials I What is Java? Basic Language Constructs. Java Essentials I. What is Java?. Basic Language Constructs Slide 1
The Java Series Java Essentials I What is Java? Basic Language Constructs Slide 1 What is Java? A general purpose Object Oriented programming language. Created by Sun Microsystems. It s a general purpose
Characteristics of Java (Optional) Y. Daniel Liang Supplement for Introduction to Java Programming
Characteristics of Java (Optional) Y. Daniel Liang Supplement for Introduction to Java Programming Java has become enormously popular. Java s rapid rise and wide acceptance can be traced to its design
Syllabus for CS 134 Java Programming
- Java Programming Syllabus Page 1 Syllabus for CS 134 Java Programming Computer Science Course Catalog 2000-2001: This course is an introduction to objectoriented programming using the Java language.
CA4003 - Compiler Construction
CA4003 - Compiler Construction David Sinclair Overview This module will cover the compilation process, reading and parsing a structured language, storing it in an appropriate data structure, analysing
Compiler I: Syntax Analysis Human Thought
Course map Compiler I: Syntax Analysis Human Thought Abstract design Chapters 9, 12 H.L. Language & Operating Sys. Compiler Chapters 10-11 Virtual Machine Software hierarchy Translator Chapters 7-8 Assembly
How Programmers Use Internet Resources to Aid Programming
How Programmers Use Internet Resources to Aid Programming Jeffrey Stylos Brad A. Myers Computer Science Department and Human-Computer Interaction Institute Carnegie Mellon University 5000 Forbes Ave Pittsburgh,
Evolution of the Major Programming Languages
142 Evolution of the Major Programming Languages Object Oriented Programming: Smalltalk Object-Oriented: It s fundamental characteristics are: Data abstraction, Inheritance and Dynamic Binding. The essence
Towards a Framework for Generating Tests to Satisfy Complex Code Coverage in Java Pathfinder
Towards a Framework for Generating Tests to Satisfy Complex Code Coverage in Java Pathfinder Matt Department of Computer Science and Engineering University of Minnesota [email protected] Abstract We present
C# and Other Languages
C# and Other Languages Rob Miles Department of Computer Science Why do we have lots of Programming Languages? Different developer audiences Different application areas/target platforms Graphics, AI, List
University of Twente. A simulation of the Java Virtual Machine using graph grammars
University of Twente Department of Computer Science A simulation of the Java Virtual Machine using graph grammars Master of Science thesis M. R. Arends, November 2003 A simulation of the Java Virtual Machine
CS 209 Programming in Java #1
CS 209 Programming in Java #1 Introduction Spring, 2006 Instructor: J.G. Neal 1 Topics CS 209 Target Audience CS 209 Course Goals CS 209 Syllabus - See handout Java Features, History, Environment Java
Compilers. Introduction to Compilers. Lecture 1. Spring term. Mick O Donnell: [email protected] Alfonso Ortega: alfonso.ortega@uam.
Compilers Spring term Mick O Donnell: [email protected] Alfonso Ortega: [email protected] Lecture 1 to Compilers 1 Topic 1: What is a Compiler? 3 What is a Compiler? A compiler is a computer
COMP 356 Programming Language Structures Notes for Chapter 4 of Concepts of Programming Languages Scanning and Parsing
COMP 356 Programming Language Structures Notes for Chapter 4 of Concepts of Programming Languages Scanning and Parsing The scanner (or lexical analyzer) of a compiler processes the source program, recognizing
An Overview of Java. overview-1
An Overview of Java overview-1 Contents What is Java Major Java features Java virtual machine Java programming language Java class libraries (API) GUI Support in Java Networking and Threads in Java overview-2
Chapter 7D The Java Virtual Machine
This sub chapter discusses another architecture, that of the JVM (Java Virtual Machine). In general, a VM (Virtual Machine) is a hypothetical machine (implemented in either hardware or software) that directly
A Thread Monitoring System for Multithreaded Java Programs
A Thread Monitoring System for Multithreaded Java Programs Sewon Moon and Byeong-Mo Chang Department of Computer Science Sookmyung Women s University, Seoul 140-742, Korea [email protected], [email protected]
Checking Access to Protected Members in the Java Virtual Machine
Checking Access to Protected Members in the Java Virtual Machine Alessandro Coglio Kestrel Institute 3260 Hillview Avenue, Palo Alto, CA 94304, USA Ph. +1-650-493-6871 Fax +1-650-424-1807 http://www.kestrel.edu/
Online Recruitment System 1. INTRODUCTION
1. INTRODUCTION This project Online Recruitment System is an online website in which jobseekers can register themselves online and apply for job and attend the exam. Online Recruitment System provides
How To Understand Programming Languages And Programming Languages
Objectives Differentiate between machine and and assembly languages Describe Describe various various ways ways to to develop develop Web Web pages pages including including HTML, HTML, scripting scripting
2 Introduction to Java. Introduction to Programming 1 1
2 Introduction to Java Introduction to Programming 1 1 Objectives At the end of the lesson, the student should be able to: Describe the features of Java technology such as the Java virtual machine, garbage
GENERIC and GIMPLE: A New Tree Representation for Entire Functions
GENERIC and GIMPLE: A New Tree Representation for Entire Functions Jason Merrill Red Hat, Inc. [email protected] 1 Abstract The tree SSA project requires a tree representation of functions for the optimizers
1 The Java Virtual Machine
1 The Java Virtual Machine About the Spec Format This document describes the Java virtual machine and the instruction set. In this introduction, each component of the machine is briefly described. This
Chapter 6: Programming Languages
Chapter 6: Programming Languages Computer Science: An Overview Eleventh Edition by J. Glenn Brookshear Copyright 2012 Pearson Education, Inc. Chapter 6: Programming Languages 6.1 Historical Perspective
Programming Languages & Tools
4 Programming Languages & Tools Almost any programming language one is familiar with can be used for computational work (despite the fact that some people believe strongly that their own favorite programming
McGraw-Hill The McGraw-Hill Companies, Inc., 20 1. 01 0
1.1 McGraw-Hill The McGraw-Hill Companies, Inc., 2000 Objectives: To describe the evolution of programming languages from machine language to high-level languages. To understand how a program in a high-level
CSCI E 98: Managed Environments for the Execution of Programs
CSCI E 98: Managed Environments for the Execution of Programs Draft Syllabus Instructor Phil McGachey, PhD Class Time: Mondays beginning Sept. 8, 5:30-7:30 pm Location: 1 Story Street, Room 304. Office
Moving from CS 61A Scheme to CS 61B Java
Moving from CS 61A Scheme to CS 61B Java Introduction Java is an object-oriented language. This document describes some of the differences between object-oriented programming in Scheme (which we hope you
Chapter 12 Programming Concepts and Languages
Chapter 12 Programming Concepts and Languages Chapter 12 Programming Concepts and Languages Paradigm Publishing, Inc. 12-1 Presentation Overview Programming Concepts Problem-Solving Techniques The Evolution
Fundamentals of Java Programming
Fundamentals of Java Programming This document is exclusive property of Cisco Systems, Inc. Permission is granted to print and copy this document for non-commercial distribution and exclusive use by instructors
Android Application Development Course Program
Android Application Development Course Program Part I Introduction to Programming 1. Introduction to programming. Compilers, interpreters, virtual machines. Primitive data types, variables, basic operators,
Language Processing Systems
Language Processing Systems Evaluation Active sheets 10 % Exercise reports 30 % Midterm Exam 20 % Final Exam 40 % Contact Send e-mail to [email protected] Course materials at www.u-aizu.ac.jp/~hamada/education.html
- Applet java appaiono di frequente nelle pagine web - Come funziona l'interprete contenuto in ogni browser di un certo livello? - Per approfondire
- Applet java appaiono di frequente nelle pagine web - Come funziona l'interprete contenuto in ogni browser di un certo livello? - Per approfondire il funzionamento della Java Virtual Machine (JVM): -
The Mjølner BETA system
FakePart I FakePartTitle Software development environments CHAPTER 2 The Mjølner BETA system Peter Andersen, Lars Bak, Søren Brandt, Jørgen Lindskov Knudsen, Ole Lehrmann Madsen, Kim Jensen Møller, Claus
C Compiler Targeting the Java Virtual Machine
C Compiler Targeting the Java Virtual Machine Jack Pien Senior Honors Thesis (Advisor: Javed A. Aslam) Dartmouth College Computer Science Technical Report PCS-TR98-334 May 30, 1998 Abstract One of the
Course MS10975A Introduction to Programming. Length: 5 Days
3 Riverchase Office Plaza Hoover, Alabama 35244 Phone: 205.989.4944 Fax: 855.317.2187 E-Mail: [email protected] Web: www.discoveritt.com Course MS10975A Introduction to Programming Length: 5 Days
Lecture 9. Semantic Analysis Scoping and Symbol Table
Lecture 9. Semantic Analysis Scoping and Symbol Table Wei Le 2015.10 Outline Semantic analysis Scoping The Role of Symbol Table Implementing a Symbol Table Semantic Analysis Parser builds abstract syntax
Java CPD (I) Frans Coenen Department of Computer Science
Java CPD (I) Frans Coenen Department of Computer Science Content Session 1, 12:45-14:30 (First Java Programme, Inheritance, Arithmetic) Session 2, 14:45-16:45 (Input and Programme Constructs) Materials
ABSTRACT. Keywords Virtual Reality, Java, JavaBeans, C++, CORBA 1. INTRODUCTION
Tweek: Merging 2D and 3D Interaction in Immersive Environments Patrick L Hartling, Allen D Bierbaum, Carolina Cruz-Neira Virtual Reality Applications Center, 2274 Howe Hall Room 1620, Iowa State University
A TOOL FOR DATA STRUCTURE VISUALIZATION AND USER-DEFINED ALGORITHM ANIMATION
A TOOL FOR DATA STRUCTURE VISUALIZATION AND USER-DEFINED ALGORITHM ANIMATION Tao Chen 1, Tarek Sobh 2 Abstract -- In this paper, a software application that features the visualization of commonly used
Chapter 1 Java Program Design and Development
presentation slides for JAVA, JAVA, JAVA Object-Oriented Problem Solving Third Edition Ralph Morelli Ralph Walde Trinity College Hartford, CT published by Prentice Hall Java, Java, Java Object Oriented
A Java Based Tool for Testing Interoperable MPI Protocol Conformance
A Java Based Tool for Testing Interoperable MPI Protocol Conformance William George National Institute of Standards and Technology 100 Bureau Drive Stop 8951 Gaithersburg MD 20899 8951 1 301 975 4943 [email protected]
Lecture 1: Introduction
Programming Languages Lecture 1: Introduction Benjamin J. Keller Department of Computer Science, Virginia Tech Programming Languages Lecture 1 Introduction 2 Lecture Outline Preview History of Programming
Java Programming. Binnur Kurt [email protected]. Istanbul Technical University Computer Engineering Department. Java Programming. Version 0.0.
Java Programming Binnur Kurt [email protected] Istanbul Technical University Computer Engineering Department Java Programming 1 Version 0.0.4 About the Lecturer BSc İTÜ, Computer Engineering Department,
A Java Virtual Machine Architecture for Very Small Devices
A Java Virtual Machine Architecture for Very Small Devices Nik Shaylor Sun Microsystems Research Laboratories 2600 Casey Avenue Mountain View, CA 94043 USA [email protected] Douglas N. Simon Sun Microsystems
An Eclipse Plug-In for Visualizing Java Code Dependencies on Relational Databases
An Eclipse Plug-In for Visualizing Java Code Dependencies on Relational Databases Paul L. Bergstein, Priyanka Gariba, Vaibhavi Pisolkar, and Sheetal Subbanwad Dept. of Computer and Information Science,
03 - Lexical Analysis
03 - Lexical Analysis First, let s see a simplified overview of the compilation process: source code file (sequence of char) Step 2: parsing (syntax analysis) arse Tree Step 1: scanning (lexical analysis)
Programming Language Concepts for Software Developers
Programming Language Concepts for Software Developers Peter Sestoft IT University of Copenhagen, Denmark [email protected] Abstract This note describes and motivates our current plans for an undergraduate
picojava TM : A Hardware Implementation of the Java Virtual Machine
picojava TM : A Hardware Implementation of the Java Virtual Machine Marc Tremblay and Michael O Connor Sun Microelectronics Slide 1 The Java picojava Synergy Java s origins lie in improving the consumer
Habanero Extreme Scale Software Research Project
Habanero Extreme Scale Software Research Project Comp215: Java Method Dispatch Zoran Budimlić (Rice University) Always remember that you are absolutely unique. Just like everyone else. - Margaret Mead
Java applets. SwIG Jing He
Java applets SwIG Jing He Outline What is Java? Java Applications Java Applets Java Applets Securities Summary What is Java? Java was conceived by James Gosling at Sun Microsystems Inc. in 1991 Java is
What Perl Programmers Should Know About Java
Beth Linker, [email protected] Abstract The Java platform is by no means a replacement for Perl, but it can be a useful complement. Even if you do not need to or want to use Java, you should know a bit
In: Proceedings of RECPAD 2002-12th Portuguese Conference on Pattern Recognition June 27th- 28th, 2002 Aveiro, Portugal
Paper Title: Generic Framework for Video Analysis Authors: Luís Filipe Tavares INESC Porto [email protected] Luís Teixeira INESC Porto, Universidade Católica Portuguesa [email protected] Luís Corte-Real
Java 6 'th. Concepts INTERNATIONAL STUDENT VERSION. edition
Java 6 'th edition Concepts INTERNATIONAL STUDENT VERSION CONTENTS PREFACE vii SPECIAL FEATURES xxviii chapter i INTRODUCTION 1 1.1 What Is Programming? 2 J.2 The Anatomy of a Computer 3 1.3 Translating
Compiler Construction
Compiler Construction Lecture 1 - An Overview 2003 Robert M. Siegfried All rights reserved A few basic definitions Translate - v, a.to turn into one s own language or another. b. to transform or turn from
Java Language Tools COPYRIGHTED MATERIAL. Part 1. In this part...
Part 1 Java Language Tools This beginning, ground-level part presents reference information for setting up the Java development environment and for compiling and running Java programs. This includes downloading
Introduction to programming
Unit 1 Introduction to programming Summary Architecture of a computer Programming languages Program = objects + operations First Java program Writing, compiling, and executing a program Program errors
Introduction. Compiler Design CSE 504. Overview. Programming problems are easier to solve in high-level languages
Introduction Compiler esign CSE 504 1 Overview 2 3 Phases of Translation ast modifled: Mon Jan 28 2013 at 17:19:57 EST Version: 1.5 23:45:54 2013/01/28 Compiled at 11:48 on 2015/01/28 Compiler esign Introduction
Software Engineering
Software Engineering Lecture 06: Design an Overview Peter Thiemann University of Freiburg, Germany SS 2013 Peter Thiemann (Univ. Freiburg) Software Engineering SWT 1 / 35 The Design Phase Programming in
APPLETS AND NETWORK SECURITY: A MANAGEMENT OVERVIEW
84-10-25 DATA SECURITY MANAGEMENT APPLETS AND NETWORK SECURITY: A MANAGEMENT OVERVIEW Al Berg INSIDE Applets and the Web, The Security Issue, Java: Secure Applets, Java: Holes and Bugs, Denial-of-Service
ATSBA: Advanced Technologies Supporting Business Areas. Programming with Java. 1 Overview and Introduction
ATSBA: Advanced Technologies Supporting Business Areas Programming with Java 1 Overview and Introduction 1 1 Overview and Introduction 1 Overview and Introduction 1.1 Programming and Programming Languages
New Generation of Software Development
New Generation of Software Development Terry Hon University of British Columbia 201-2366 Main Mall Vancouver B.C. V6T 1Z4 [email protected] ABSTRACT In this paper, I present a picture of what software development
Integrated Open-Source Geophysical Processing and Visualization
Integrated Open-Source Geophysical Processing and Visualization Glenn Chubak* University of Saskatchewan, Saskatoon, Saskatchewan, Canada [email protected] and Igor Morozov University of Saskatchewan,
Java in Education. Choosing appropriate tool for creating multimedia is the first step in multimedia design
Java in Education Introduction Choosing appropriate tool for creating multimedia is the first step in multimedia design and production. Various tools that are used by educators, designers and programmers
CSC 8505 Handout : JVM & Jasmin
CSC 8505 Handout : JVM & Jasmin Note: This handout provides you with the basic information about JVM. Although we tried to be accurate about the description, there may be errors. Feel free to check your
Write Barrier Removal by Static Analysis
Write Barrier Removal by Static Analysis Karen Zee and Martin Rinard Laboratory for Computer Science Massachusetts Institute of Technology Cambridge, MA 02139 {kkz, [email protected] ABSTRACT We present
AP Computer Science A - Syllabus Overview of AP Computer Science A Computer Facilities
AP Computer Science A - Syllabus Overview of AP Computer Science A Computer Facilities The classroom is set up like a traditional classroom on the left side of the room. This is where I will conduct my
Design Patterns in Parsing
Abstract Axel T. Schreiner Department of Computer Science Rochester Institute of Technology 102 Lomb Memorial Drive Rochester NY 14623-5608 USA [email protected] Design Patterns in Parsing James E. Heliotis
CSC 551: Web Programming. Spring 2004
CSC 551: Web Programming Spring 2004 Java Overview Design goals & features platform independence, portable, secure, simple, object-oriented, Programming models applications vs. applets vs. servlets intro
Virtual Machines. Virtual Machines
Virtual Machines Virtual Machines What is a virtual machine? Examples? Benefits? 1 Virtualization Creation of an isomorphism that maps a virtual guest system to a real host: Maps guest state S to host
Manage Software Development in LabVIEW with Professional Tools
Manage Software Development in LabVIEW with Professional Tools Introduction For many years, National Instruments LabVIEW software has been known as an easy-to-use development tool for building data acquisition
CS 51 Intro to CS. Art Lee. September 2, 2014
CS 51 Intro to CS Art Lee September 2, 2014 Announcements Course web page at: http://www.cmc.edu/pages/faculty/alee/cs51/ Homework/Lab assignment submission on Sakai: https://sakai.claremont.edu/portal/site/cx_mtg_79055
Compiler and Language Processing Tools
Compiler and Language Processing Tools Summer Term 2011 Prof. Dr. Arnd Poetzsch-Heffter Software Technology Group TU Kaiserslautern Prof. Dr. Arnd Poetzsch-Heffter Compilers 1 Outline 1. Language Processing
General Introduction
Managed Runtime Technology: General Introduction Xiao-Feng Li ([email protected]) 2012-10-10 Agenda Virtual machines Managed runtime systems EE and MM (JIT and GC) Summary 10/10/2012 Managed Runtime
Instructor Özgür ZEYDAN BEU Dept. of Enve. Eng. http://cevre.beun.edu.tr/zeydan/ CIV 112 Computer Programming Lecture Notes (1)
Instructor Özgür ZEYDAN BEU Dept. of Enve. Eng. http://cevre.beun.edu.tr/zeydan/ CIV 112 Computer Programming Lecture Notes (1) Computer Programming A computer is a programmable machine. This means it
Virtual Credit Card Processing System
The ITB Journal Volume 3 Issue 2 Article 2 2002 Virtual Credit Card Processing System Geraldine Gray Karen Church Tony Ayres Follow this and additional works at: http://arrow.dit.ie/itbj Part of the E-Commerce
Jonathan Worthington Scarborough Linux User Group
Jonathan Worthington Scarborough Linux User Group Introduction What does a Virtual Machine do? Hides away the details of the hardware platform and operating system. Defines a common set of instructions.
n Introduction n Art of programming language design n Programming language spectrum n Why study programming languages? n Overview of compilation
Lecture Outline Programming Languages CSCI-4430 & CSCI-6430, Spring 2016 www.cs.rpi.edu/~milanova/csci4430/ Ana Milanova Lally Hall 314, 518 276-6887 [email protected] Office hours: Wednesdays Noon-2pm
Portable Profiling of Memory Allocation in Java
Portable Profiling of Memory Allocation in Java Walter Binder Ecole Polytechnique Fédérale de Lausanne (EPFL) Artificial Intelligence Laboratory CH-1015 Lausanne, Switzerland [email protected] Abstract.
