4.11 Vectors
A vector is a fixed-length array with constant-time access and update of the vector slots, which are numbered from 0 to one less than the number of slots in the vector.
Two vectors are equal? if they have the same length, and if the values in corresponding slots of the vectors are equal?.
A vector can be mutable or immutable. When an immutable vector is provided to a procedure like vector-set!, the exn:fail:contract exception is raised. Vectors generated by the default reader (see Reading Strings) are immutable.
A vector can be used as a single-valued sequence (see Sequences). The elements of the vector serve as elements of the sequence. See also in-vector.
A literal or printed vector starts with #(, optionally with a number between the # and (. See Reading Vectors for information on reading vectors and Printing Vectors for information on printing vectors.
函数
(make-vector size [v]) → vector?
size : exact-nonnegative-integer? v : any/c = 0
函数
(vector-immutable v ...) →
(and/c vector? immutable?) v : any/c
函数
vec : vector?
函数
(vector-ref vec pos) → any/c
vec : vector? pos : exact-nonnegative-integer?
函数
(vector-set! vec pos v) → void?
vec : (and/c vector? (not/c immutable?)) pos : exact-nonnegative-integer? v : any/c
函数
vec : (and/c vector? (not/c impersonator?))
函数
(vector*-ref vec pos) → any/c
vec : (and/c vector? (not/c impersonator?)) pos : exact-nonnegative-integer?
函数
(vector*-set! vec pos v) → void?
vec : (and/c vector? (not/c immutable?) (not/c impersonator?)) pos : exact-nonnegative-integer? v : any/c
添加于package base的6.90.0.15版本。
函数
(vector-cas! vec pos old-v new-v) → boolean?
vec : (and/c vector? (not/c immutable?) (not/c impersonator?)) pos : exact-nonnegative-integer? old-v : any/c new-v : any/c
添加于package base的6.11.0.2版本。
函数
(vector->list vec) → list?
vec : vector?
函数
(list->vector lst) → vector?
lst : list?
函数
(vector->immutable-vector vec) → (and/c vector? immutable?)
vec : vector?
函数
(vector-fill! vec v) → void?
vec : (and/c vector? (not/c immutable?)) v : any/c
函数
(vector-copy! dest dest-start src [ src-start src-end]) → void? dest : (and/c vector? (not/c immutable?)) dest-start : exact-nonnegative-integer? src : vector? src-start : exact-nonnegative-integer? = 0 src-end : exact-nonnegative-integer? = (vector-length src)
> (define v (vector 'A 'p 'p 'l 'e)) > (vector-copy! v 4 #(y)) > (vector-copy! v 0 v 3 4) > v '#(l p p l y)
函数
(vector->values vec [start-pos end-pos]) → any
vec : vector? start-pos : exact-nonnegative-integer? = 0 end-pos : exact-nonnegative-integer? = (vector-length vec)
函数
(build-vector n proc) → vector?
n : exact-nonnegative-integer? proc : (exact-nonnegative-integer? . -> . any/c)
> (build-vector 5 add1) '#(1 2 3 4 5)
4.11.1 Additional Vector Functions
(require racket/vector) | package: base |
函数
(vector-set*! vec pos v ... ...) → void?
vec : (and/c vector? (not/c immutable?)) pos : exact-nonnegative-integer? v : any/c
函数
(vector-map proc vec ...+) → vector?
proc : procedure? vec : vector?
> (vector-map + #(1 2) #(3 4)) '#(4 6)
函数
(vector-map! proc vec ...+) → vector?
proc : procedure? vec : (and/c vector? (not/c immutable?))
> (define v (vector 1 2 3 4)) > (vector-map! add1 v) '#(2 3 4 5)
> v '#(2 3 4 5)
函数
(vector-append vec ...) → vector?
vec : vector?
> (vector-append #(1 2) #(3 4)) '#(1 2 3 4)
函数
(vector-take vec pos) → vector?
vec : vector? pos : exact-nonnegative-integer?
> (vector-take #(1 2 3 4) 2) '#(1 2)
函数
(vector-take-right vec pos) → vector?
vec : vector? pos : exact-nonnegative-integer?
> (vector-take-right #(1 2 3 4) 2) '#(3 4)
函数
(vector-drop vec pos) → vector?
vec : vector? pos : exact-nonnegative-integer?
> (vector-drop #(1 2 3 4) 2) '#(3 4)
函数
(vector-drop-right vec pos) → vector?
vec : vector? pos : exact-nonnegative-integer?
> (vector-drop-right #(1 2 3 4) 1) '#(1 2 3)
> (vector-drop-right #(1 2 3 4) 3) '#(1)
函数
(vector-split-at vec pos) →
vector? vector? vec : vector? pos : exact-nonnegative-integer?
(values (vector-take vec pos) (vector-drop vec pos))
except that it can be faster.
> (vector-split-at #(1 2 3 4 5) 2)
'#(1 2)
'#(3 4 5)
函数
(vector-split-at-right vec pos) →
vector? vector? vec : vector? pos : exact-nonnegative-integer?
(values (vector-take-right vec pos) (vector-drop-right vec pos))
except that it can be faster.
> (vector-split-at-right #(1 2 3 4 5) 2)
'#(1 2 3)
'#(4 5)
函数
(vector-copy vec [start end]) → vector?
vec : vector? start : exact-nonnegative-integer? = 0 end : exact-nonnegative-integer? = (vector-length v)
> (vector-copy #(1 2 3 4)) '#(1 2 3 4)
> (vector-copy #(1 2 3 4) 3) '#(4)
> (vector-copy #(1 2 3 4) 2 3) '#(3)
函数
(vector-filter pred vec) → vector?
pred : procedure? vec : vector?
> (vector-filter even? #(1 2 3 4 5 6)) '#(2 4 6)
函数
(vector-filter-not pred vec) → vector?
pred : procedure? vec : vector?
> (vector-filter-not even? #(1 2 3 4 5 6)) '#(1 3 5)
函数
(vector-count proc vec ...+) → exact-nonnegative-integer?
proc : procedure? vec : vector?
> (vector-count even? #(1 2 3 4 5)) 2
> (vector-count = #(1 2 3 4 5) #(5 4 3 2 1)) 1
> (vector-argmin car #((3 pears) (1 banana) (2 apples))) '(1 banana)
> (vector-argmin car #((1 banana) (1 orange))) '(1 banana)
> (vector-argmax car #((3 pears) (1 banana) (2 apples))) '(3 pears)
> (vector-argmax car #((3 pears) (3 oranges))) '(3 pears)
函数
(vector-member v vec) → (or/c natural-number/c #f)
v : any/c vec : vector?
> (vector-member 2 (vector 1 2 3 4)) 1
> (vector-member 9 (vector 1 2 3 4)) #f
函数
(vector-memv v vec) → (or/c natural-number/c #f)
v : any/c vec : vector?
> (vector-memv 2 (vector 1 2 3 4)) 1
> (vector-memv 9 (vector 1 2 3 4)) #f
函数
(vector-memq v vec) → (or/c natural-number/c #f)
v : any/c vec : vector?
> (vector-memq 2 (vector 1 2 3 4)) 1
> (vector-memq 9 (vector 1 2 3 4)) #f
函数
(vector-sort vec less-than? [ start end #:key key #:cache-keys? cache-keys?]) → vector? vec : vector? less-than? : (any/c any/c . -> . any/c) start : exact-nonnegative-integer? = 0 end : exact-nonnegative-integer? = (vector-length vec) key : (any/c . -> . any/c) = (λ (x) x) cache-keys? : boolean? = #f
> (define v1 (vector 4 3 2 1)) > (vector-sort v1 <) '#(1 2 3 4)
> v1 '#(4 3 2 1)
> (define v2 (vector '(4) '(3) '(2) '(1))) > (vector-sort v2 < 1 3 #:key car) '#((2) (3))
> v2 '#((4) (3) (2) (1))
添加于package base的6.6.0.5版本。
函数
(vector-sort! vec less-than? [ start end #:key key #:cache-keys? cache-keys?]) → void? vec : (and/c vector? (not/c immutable?)) less-than? : (any/c any/c . -> . any/c) start : exact-nonnegative-integer? = 0 end : exact-nonnegative-integer? = (vector-length vec) key : (any/c . -> . any/c) = (λ (x) x) cache-keys? : boolean? = #f
> (define v1 (vector 4 3 2 1)) > (vector-sort! v1 <) > v1 '#(1 2 3 4)
> (define v2 (vector '(4) '(3) '(2) '(1))) > (vector-sort! v2 < 1 3 #:key car) > v2 '#((4) (2) (3) (1))
添加于package base的6.6.0.5版本。