Calculi with control operators have been studied to reason about control in programming languages and to interpret the computational content of classical proofs. To make these calculi into a real programming language, one should also include data types.As a step into that direction, this paper defines a simply typed call-by-value λ -calculus with the control operators catch and throw, a data type of lists, and an operator for primitive recursion (à la Gödel's T). We prove that our system satisfies subject reduction, progress, confluence for untyped terms, and strong normalization for well-typed terms.