! 43
!= (not equal to) 42
56
&& 43
2’s complement representation 39
< (less than) 42
<= (less than or equal to) 42
== (equal to) 42
> (greater than) 42
>= (greater than or equal to) 42
abstract 185
Abstraction 18 166
Acceptance testing 147
Account class 19
Account name (Unix) 284
acroread command (Unix) 301
actual parameter 19
Adaptability 168
AddExpression class 265
Addition of elements from a collection 112
Address 5
Analysis 65
Ancestor (of node in tree) 259
Appending to an existing file 203
args parameter of main method 77
Ariadne 5 disaster 69
ArithmeticException class 72
Array 93
ArrayList class 96
ASCII encoding 5 46
Assad, Mark viii
Assembly language 3
assertion 133
ASSIGNMENT 7
Associativity 126
Asymptotic notation 228
ATM class 25
ATMCard class 25
Automation of testing 151
Average-case cost 228
Big-Oh notation 228
Binary encoding 4
Binary tree 262
Bit 4
black-box testing 149
BNF 270
Boole, George 43
Boolean algebra 125
Boolean type 41
BorderLayout GUI class 80
Bounded cost 227
BufferedReader class 200
Buffering files 205
Building a collection 112
Built-in class 37
Button GUI class 80
BYTE 5
C (programming language) 3 33
C++ 3
Cast 98
cat command (Unix) 288
catch keyword 71
CD example class 220
CD example class, cd command (Unix) 292
CHARACTER 5
Checkbox GUI class 80
Checked exception 74
Child (of node in tree) 259
Chip, silicon 2
chmod command (Unix) 301
class 19
class invariant 136 198
clear-box testing 149
close method 201
Cohesion 168
Collection 92
Collection class 92
Command (Unix) 285
Command Line Arguments 77
comment 15
Commutativity 126
composite design pattern 263
Computer science 2
Condition 42
Constant cost 227 229
Constants 75
constructor 22
Context-free grammar 270
Contract class 137
Control characters 46
Conversion of int to double 40
Copying a file (Unix) 289
Correctness of programs 141
Counting elements in a collection 112
Coupling 169
cp command (Unix) 289
create 35
creation 22
Current directory (Unix) 290
Data compression 238
date command (Unix) 301
Debug print statements 165
declaration 6
Decoration of parser 279
Defect testing 148
Deleting a file (Unix) 289
Descendant (of node in tree) 259
Design 14
Design by contract 135 175
Design of methods 65
Design pattern 263
diff command (Unix) 214 301
Directories (Unix) 289
Disk 199
Dividing a parser 283
DOUBLE PRECISION 41
Double type 40
Dynamic type 189
EBNF 270
Eiffel 3 33 198
else keyword 48
emacs command (Unix) 301
Empty sequence 97
Empty string 44
Encapsulated PostScript files 302
Enumeration class 60
EPS files 302
Equality (of variables) 35
Equivalence partitions 151
Error class 72
escape character 45
Ethics 236
ExampleToken class 273
Exception class 72
Exceptions 69
Exclusive OR 124
EXECUTE permission 300
EXPONENT 40
Expression class 264 279
Extensible markup language (XML) files 303
Factorial method 50 251
Factory 101
FALSE 41
Fekete, Alan viii
fib method 243
Fibonacci numbers 243
FIFO 99
File class 209
File name matching 296
File name suffix es(Unix) 302
| File permissions (Unix) 299
File separator 215
FileNotFoundException 207
Files 199
final 59
final, keyword 76
Finally keyword 72
find command (Unix) 301
Finite automaton 272
First-in-first-out 99
Floating point 40
FlowLayout GUI class 80
flush method 205
Folders 289
Form of a program 162
Formal parameter 18
FORTRAN 3 33
Frame GUI class 80
Frank, Ed viii
Full path name (Unix) 295
Function 19
function call 19
Function, of a program 161
Functional prototype 162
Generate and test 67
ghostview command (Unix) 301
Glass-box testing 150
Grammar 270
graphical user interfaces 80
Greening, Tony viii
grep command (Unix) 301
GridBagLayout GUI class 80
GridLayout GUI class 80
Group management 176
Group projects vii
Group work 174
GUIs 80
gunzip command (Unix) 301
gzip command (Unix) 301
hanoi method 254
Hard coded input 75
Hash table 106
HashMap class 106
Hierarchy 258
High level languages 3
Home directory (Unix) 290
HTML files 302
Hypertext markup language files 302
Icon 284
if 47
if, statement 48
Implication 128
Income tax problem 146
Increment 55
Index in array 93
Index variable 55
Induction, mathematical 249
inheritance 184
Inheritance of class invariants 198
Inheritance of preconditions and postconditions 197
Initial value of variable 7
Input 75
Input/output redirection (Unix) 298
Instance variable 22
Instruction 7
INTERFACE 101
Invariant 136
Invariant, class 136 198
Invariant, loop 138
IOException 207
IOException class 72
isPrime method 66
Iterator 103
Iterator-based traversal 103
Java 3
java.awt package 80
java.awt.event package 80
JavaToken class 274
Joy, Bill viii
Kay, Judy viii
Kummerfeld, Sarahif viii
Left subtree 262
Leonardo Pisano 242
Lesley, Nicoleifif viii
Lexical analyser 272
Lexical analysis 272
Lifetime (of variable) 32
Lindholm, Tim viii
Linear cost 228 229
Linear search (of a collection) 115
LinkedList class 96 99
List GUI class 80
List GUI class, list 96
Listiterator interface 103
Literal 37
LiteralExpression class 264
loadDatabase example method 221
LoanLItem example class 219
Local variable 18
Log file 165
Logarithmic cost 229
logging in 284
Logging out 285
Login name (Unix) 284
Loop 50 230
Loop invariant 138
lpq command (Unix) 288
lpr command (Unix) 288
ls command (UNIX) 287 292 300
magic numbers 75
Mantissa 40
Mathematical induction 249
Maximum-finding 113
MAX_VALUE 40
Memory, computer 3
Menu GUI class 80
method 13
method call 18
method overloading 97
Meyer, Bertrand 197
minimum-finding 113
MIN_VALUE 40
mkdir command (Unix) 290
more command (Unix) 288
Moving a file (Unix) 288
MulExpression class 266
multiplicationTable method 63
mv command (Unix) 288 291
mysqrt method 14
Name (of variable) 6
Natural language 124
Naughton, Patrick viii
nested loops 231
nested statements 60
netscape command (Unix) 302
new expression 23
Node (of tree) 258
Non-existent variable 31
Non-null 31
Non-strictness 43
NULL 25 31
NullPointerException class 72
Numerical analysis 41
Object 22
object identity 33
object-oriented languages 3
OLD 135
Open-box testing 149
Ordered tree 259
Output 75
|