Chapter 2 reviewed
This commit is contained in:
parent
fbd0f679b5
commit
566ed59a0e
2 changed files with 33 additions and 21 deletions
|
@ -199,10 +199,18 @@ dependencies are \added{represented with }black \added{arcs}, data dependencies
|
|||
\caption{A simple multiplication program, its CFG, PDG and SDG}
|
||||
\label{fig:basic-graphs}
|
||||
\end{figure}
|
||||
\sergio{nose si vale la pena poner la Figure~\ref{fig:basic-graphs} aqui, no hemos contado aun como se genera, sino que se genera y se supone que se cuenta mas adelante, tal vez sea mas util hacer referencia forward solo y no poner esta figura aqui, sino mas adelante. Plantearselo}
|
||||
|
||||
\subsection{Metrics}
|
||||
\sergio{Metrics o slicing indicators/features? }
|
||||
|
||||
There are four relevant metrics considered when evaluating a slicing algorithm:
|
||||
|
||||
There are four relevant metrics considered when evaluating a slicing algorithm:
|
||||
\sergio{Se me hace muy escueto esto, yo meteria algo de bullshit como dice Tama.}
|
||||
|
||||
\sergio{PROPOSAL:}
|
||||
|
||||
\sergio{In the area of program slicing, there are many different slicing techniques and tools implementing them. This fact has created the necessity to classify them by defining a set of different metrics. These metrics are commonly associated to some features of the generated slices. In the following, we list the most relevant metrics considered when evaluating a program slice:}
|
||||
|
||||
\begin{description}
|
||||
\item[Completeness.] The solution includes all the statements that affect
|
||||
|
@ -219,23 +227,25 @@ There are four relevant metrics considered when evaluating a slicing algorithm:
|
|||
commercially available) for most popular programming languages, from C++
|
||||
to Erlang. Some slicing techniques only cover a subset of the targeted
|
||||
language, and as such are less useful for commercial applications, but
|
||||
can be a stepping stone in the betterment of the field.
|
||||
can be a stepping stone in the betterment of the field.\sergio{Tambien estan las valen para todos los lenguajes, ORBS entraria en ese caso no Josep?}
|
||||
\item[Speed.] Speed of graph generation and slice creation. As previously
|
||||
stated, slicing is a two-step process: building a graph and traversing it.
|
||||
stated, slicing is a two-step process: building a graph and traversing it \sergio{esta frase hace parece que hacer slicing es dibujo libre... darle algo de importancia hablando de traducir el codigo a una representacion en forma de grafo con un estructura de datos compleja bla bla bla...}.
|
||||
The traversal is a linear two--pass analysis of a graph in most proposals, with small variations.
|
||||
Graph generation tends to be a longer process, but it is not as
|
||||
relevant, because it is only done once (per program being analyzed), making this the least important metric.
|
||||
relevant, because it is only done once (per program being analyzed), making this the least important metric. \sergio{Puedes anyadir que aunque la metrica del proceso de generacion no se suele tener muy en cuenta, esta existe porque es donde hay que hacer el analisis mas costoso sobre el programa y tal... relleno a saco! Que parece que no tiene ni merito generar el grafo :(}
|
||||
Only proposals that deviate from the aforementioned schema of building a graph and traversing it show a wider variation in speed.
|
||||
\end{description}
|
||||
|
||||
\subsection{Program slicing as a debugging technique}
|
||||
|
||||
Program slicing is first and foremost a debugging technique, having each
|
||||
variation a different purpose:
|
||||
\sergio{Soy pesado pero esto se me vuelve a hacer muy corto :/. Retoco esto un poco}
|
||||
|
||||
\added{As stated before, there are many uses for program slicing: program specialization, software maintenance, code obfuscation... but there is no doubt that p}\deleted{P}rogram slicing is first and foremost a debugging technique\added{.} \deleted{, having e}\added{E}ach\deleted{variation}\added{configuration of different dimensions serves} a different purpose:
|
||||
|
||||
|
||||
\begin{description}
|
||||
\item[Backward static.] Used to obtain the lines that affect a statement,
|
||||
normally used on a line which outputs an incorrect value, to narrow down
|
||||
normally used on a line which outputs an incorrect value, to narrow\sergio{track?} down
|
||||
the source of the bug.
|
||||
\item[Forward static.] Used to obtain the lines affected by a statement,
|
||||
used to identify dead code, to check the effects a line has on the rest
|
||||
|
@ -246,7 +256,7 @@ variation a different purpose:
|
|||
limits the slice to an execution log, only including statements that
|
||||
have run in a specific execution. The slice produced is much smaller and
|
||||
useful.
|
||||
\item[Quasi--static.] Some input values are given, and some are left
|
||||
\item[Quasi--static.] \added{In this slicing method s}\deleted{S}ome input values are given, and some are left
|
||||
unspecified: the result is a slice between the small dynamic slice and
|
||||
the general but bigger static slice. It can be specially useful when
|
||||
debugging a set of function calls which have a specific static input for
|
||||
|
@ -257,18 +267,19 @@ variation a different purpose:
|
|||
source of the bug.
|
||||
\item
|
||||
\carlos{añadir más quizá???}
|
||||
\sergio{a mi me parecen suficientes, puedes decir una frasecita de 2 o 3 lineas diciendo que hay mas y algun uso de alguno de los otros que queden asi a lo general, pero yo los veo suficientes.}
|
||||
\end{description}
|
||||
|
||||
\section{Exception handling in Java}
|
||||
\label{sec:intro-exception}
|
||||
|
||||
Exception handling is common in most modern programming languages. In Java, it
|
||||
consists of the following elements:
|
||||
Exception handling is common in most modern programming languages. \added{Exception handling generally consists in a set of statements that modify the normal execution flow noticing the existence of an abnormal program behaviour (controlled or not), and can be handled manually by the programmer or automatically by the system, depending on the programming language. In our work we focus on the Java programming language, so in the following, we describe the elements that Java uses to represent and handle exceptions:} \deleted{In Java, it
|
||||
consists of the following elements:}
|
||||
\begin{description}
|
||||
\item[Throwable.] An interface that encompasses all the exceptions or errors
|
||||
that may be thrown. Its child classes are \texttt{Error} for internal errors in the Java Virtual Machine and \texttt{Exception} for normal errors.
|
||||
Exceptions can be classified as \textsl{unchecked}
|
||||
(those that extend \texttt{RuntimeException} or \texttt{Error}) and
|
||||
(those that extend \texttt{RuntimeException}\sergio{se sale esto de la linea por el texttt} or \texttt{Error}) and
|
||||
\textsl{checked} (all others, may inherit from \texttt{Throwable}, but typically they do so from \texttt{Exception}). The first kind may be thrown anywhere without warning, whereas
|
||||
the second, if thrown, must be either caught in the same method or declared in the method header.
|
||||
\item[throws.] A statement that activates an exception, altering the normal
|
||||
|
@ -285,7 +296,7 @@ consists of the following elements:
|
|||
catches. Optionally, after the \textsl{catch} clauses a \textsl{finally}
|
||||
block may appear.
|
||||
\item[catch.] Contains two elements: a variable declaration (the type must
|
||||
be an exception) and a block of statements to be executed when an
|
||||
be an exception \sergio{exception o exception type?}) and a block of statements to be executed when an
|
||||
exception of the corresponding type (or a subtype) is thrown.
|
||||
\textsl{catch} clauses are processed sequentially, and if any matches
|
||||
the type of the thrown exception, its block is executed, and the rest
|
||||
|
@ -304,6 +315,7 @@ consists of the following elements:
|
|||
the program will end. Otherwise, the execution continues in the next
|
||||
statement after the \textsl{try-catch-finally} block.
|
||||
\end{description}
|
||||
\sergio{Me han molao las explicaciones, se entiende muy bien como funciona Java, parece que sea hasta facil de usar :D}
|
||||
|
||||
\footnotetext{Introduced in Java 7, see \url{https://docs.oracle.com/javase/7/docs/technotes/guides/language/catch-multiple.html} for more details.}
|
||||
|
||||
|
@ -320,7 +332,7 @@ Overflow\footnote{\url{https://stackoverflow.com}}. The survey contains a
|
|||
question about the technologies used by professional developers in their work,
|
||||
and from that list we have extracted those languages with more than $5\%$ usage
|
||||
in the industry. Table~\ref{tab:popular-languages} shows the list and its
|
||||
source. Except Bash, Assembly, VBA, C and G, the rest of the languages shown
|
||||
source. Except Bash, Assembly, VBA, C and G,\sergio{Bash y companyia no tienen mecanismo de exception handling? o no se parece al de Java? No queda claro en esta frase} the rest of the languages shown
|
||||
feature an exception system similar to the one appearing in Java.
|
||||
|
||||
\begin{table}
|
||||
|
@ -368,20 +380,19 @@ featuring a \texttt{throw} statement (\texttt{raise} in Python), try-catching
|
|||
structure and most include a finally block that may be appended to try blocks.
|
||||
The difference resides in the value passed by the exception, which in languages
|
||||
that feature inheritance it is a class descending from a generic error or
|
||||
exception, and in languages without it, it is an arbitrary value (e.g.
|
||||
exception, and in languages without it\sergio{este ``it" se refiere a inheritance? pon algun objeto y elimina algun it porque hay muchos y me lian xD}, it is an arbitrary value (e.g.
|
||||
JavaScript, TypeScript). In object--oriented programming, the filtering is
|
||||
performed by comparing if the exception is a subtype of the exception being
|
||||
caught (Java, C++, C\#, PowerShell\footnotemark, etc.); and in languages with
|
||||
arbitrary exception values, a boolean condition is specified, and the first
|
||||
catch block that fulfills its condition is activated, in following a pattern
|
||||
catch block that fulfills its condition is activated, in following\sergio{in following o following?} a pattern
|
||||
similar to that of \texttt{switch} statements (e.g. JavaScript). In both cases
|
||||
there exists a way to indicate that all exceptions should be caught, regardless
|
||||
of type and content.
|
||||
|
||||
\footnotetext{Only since version 2.0, released with Windows 7.}
|
||||
|
||||
On the other hand, in the other languages there exist a variety of systems that
|
||||
emulate or replace exception handling:
|
||||
On the other hand, in \deleted{the other languages } \sergio{``the other languages" es muy vago}\added{those languages that do not offer explicit exception handling mechanisms,} \deleted{there exist a variety of systems that emulate or replace exception handling:}\added{this feature is covered by a variety of systems that emulate or replace their behaviour:}
|
||||
|
||||
\begin{description} % bash, vba, C and Go exceptions explained
|
||||
\item[Bash.] The popular Bourne Again SHell features no exception system, apart
|
||||
|
@ -454,11 +465,11 @@ double safe_sqrt(double x, int ref) {
|
|||
function has ended or when a \texttt{panic} has been activated--- and
|
||||
\texttt{recover} ---stops the panic state and retrieves its value. The
|
||||
\texttt{defer} statement doubles as catch and finally, and multiple
|
||||
instances can be accumulated. When appropriate, they will run in LIFO order
|
||||
(Last In--First Out).
|
||||
\item[Assembly.] Assembly is a representation of machine code, and each computer architecture has its own instruction set, which makes an analysis impossible. In general, though, no unified exception handling is provided. \carlos{complete with more info on kinds of error handling at the processor level or is this out of scope???}
|
||||
instances can be accumulated. When appropriate, they will run in LIFO\deleted{order}
|
||||
(Last In--First Out) \added{order}.
|
||||
\item[Assembly.] Assembly is a representation of machine code, and each computer architecture has its own instruction set, which makes an analysis impossible. In general, though, no unified exception handling is provided. \carlos{complete with more info on kinds of error handling at the processor level or is this out of scope???}\sergio{Si metes una explicacion asi breve que se entienda bien, si va a ser muy tecnico yo pararia aqui. Diria que las excepciones se manejan a nivel de procesador o lo que sea asi por encima y matizao}
|
||||
\end{description}
|
||||
|
||||
\footnotetext{For more details on Go's design choices, see \url{https://golang.org/doc/faq\#exceptions}. \carlos{Possible transformation to citation???}}
|
||||
\footnotetext{For more details on Go's design choices, see \url{https://golang.org/doc/faq\#exceptions}. \carlos{Possible transformation to citation???}\sergio{No creo que nos vaya a hacer falta. Con el state of the art y la intro tendremos bastantes.}}
|
||||
|
||||
% vim: set noexpandtab:tabstop=2:shiftwidth=2:softtabstop=2:wrap
|
||||
|
|
|
@ -5,6 +5,7 @@
|
|||
\label{cha:incremental}
|
||||
|
||||
\carlos{Review if we want to call nodes ``Enter'' and ``Exit'' or ``Start'' and ``End'' (I'd prefer the first one).}
|
||||
\sergio{Enter o Entry?}
|
||||
|
||||
\section{First definition of the SDG}
|
||||
\label{sec:first-def-sdg}
|
||||
|
|
Loading…
Add table
Reference in a new issue