vector-ref - access an element of a vector
LIBRARY
(import (rnrs)) ;R6RS
(import (rnrs base)) ;R6RS
(import (scheme r5rs)) ;R7RS
(import (scheme base)) ;R7RS
SYNOPSIS
(vector-ref vector k)
DESCRIPTION
Returns the contents of element
k
of
vector.
RETURN VALUES
Returns a single value; an object from the vector.
EXAMPLES
(vector-ref '#(1 1 2 3 5 8 13 21) 5)
=> 8
(vector-ref '#(1 1 2 3 5 8 13 21)
(exact
(round (* 2 (acos -1)))))
=> 13
APPLICATION USAGE
The specification of vectors does not actually require constant access
time, but in practice they are always implemented as flat arrays.
Therefore this procedure is used in algorithms that perform
random-access operations on arrays. Such algorithms would not have the
same time complexity if lists were used instead.
COMPATIBILITY
This procedure works the same everywhere.
ERRORS
This procedure can raise exceptions with the following condition types:
- &assertion (R6RS)
-
The wrong number of arguments was passed or an argument was outside its domain.
In particular,
k
must be an exact nonnegative integer less than the length of
vector.
- R7RS
-
The assertions described above are errors.
Implementations may signal an error, extend the procedure's
domain of definition to include such arguments,
or fail catastrophically.
SEE ALSO
make-vector(3scm),
define-record-type(7scm)
STANDARDS
R4RS,
IEEE Scheme,
R5RS,
R6RS,
R7RS
HISTORY
This procedure first appeared in R2RS, where the vector notation was optional.
AUTHORS
This page is part of the
scheme-manpages
project.
It includes materials from the RnRS documents.
More information can be found at
https://github.com/schemedoc/manpages/
.
Markup created by unroff 1.0sc, March 04, 2023.