Swift Standard Library: Documented and undocumented built-in functions in the Swift standard library – the complete list with all 74 functions

简介:

Swift has 74 built-in functions but only seven of them are documented in the Swift book (“The Swift Programming Language”). The rest remain undocumented. This article lists all built-in Swift functions – both documented and undocumented ones. The definition used for “built-in function” used in this article is a function available in Swift without importing any modules (such as Foundation, etc.) or referencing any classes. Let’s start with the seven documented built-in functions mentioned in the Swift book along with the page number on which the function was first mentioned:
Below is the full list of all 74 built-in functions in Swift. The functions covered above are the ones I think are useful on a day-to-day basis, but perhaps I’ve missed some functions from the list below that deserves coverage. If so, let me know in the comments section and please include a short code snippet to show how to use the function.

复制代码
 1 abs(...)
 2 advance(...)
 3 alignof(...)
 4 alignofValue(...)
 5 assert(...)
 6 bridgeFromObjectiveC(...)
 7 bridgeFromObjectiveCUnconditional(...)
 8 bridgeToObjectiveC(...)
 9 bridgeToObjectiveCUnconditional(...)
10 c_malloc_size(...)
11 c_memcpy(...)
12 c_putchar(...)
13 contains(...)
14 count(...)
15 countElements(...)
16 countLeadingZeros(...)
17 debugPrint(...)
18 debugPrintln(...)
19 distance(...)
20 dropFirst(...)
21 dropLast(...)
22 dump(...)
23 encodeBitsAsWords(...)
24 enumerate(...)
25 equal(...) 目前我知道equal可以判断两个数组是否相等
26 filter(...)
27 find(...)
28 getBridgedObjectiveCType(...)
29 getVaList(...)
30 indices(...)
31 insertionSort(...)
32 isBridgedToObjectiveC(...)
33 isBridgedVerbatimToObjectiveC(...)
34 isUniquelyReferenced(...)
35 join(...)
36 lexicographicalCompare(...)
37 map(...)
38 max(...)
39 maxElement(...)
40 min(...)
41 minElement(...)
42 numericCast(...)
43 partition(...)
44 posix_read(...)
45 posix_write(...)
46 print(...)
47 println(...)
48 quickSort(...)
49 reduce(...)
50 reflect(...)
51 reinterpretCast(...)
52 reverse(...)
53 roundUpToAlignment(...)
54 sizeof(...)
55 sizeofValue(...)
56 sort(...)
57 split(...)
58 startsWith(...)
59 strideof(...)
60 strideofValue(...)
61 swap(...)
62 swift_MagicMirrorData_summaryImpl(...)
63 swift_bufferAllocate(...)
64 swift_keepAlive(...)
65 toString(...)
66 transcode(...)
67 underestimateCount(...)
68 unsafeReflect(...)
69 withExtendedLifetime(...)
70 withObjectAtPlusZero(...)
71 withUnsafePointer(...)
72 withUnsafePointerToObject(...)
73 withUnsafePointers(...)
74 withVaList(...)
复制代码 复制代码
 1 // assert mentioned on page 55  2 assert(true)
 3 // countElements mentioned on page 79 原来是countElement现在是count  4 count("foo") == 3  5 // enumerate mentioned on page 94  6 for (i, j) in enumerate(["A", "B"]) {
 7 // "0:A", "1:B" will be printed  8 println("\(i):\(j)")
 9 }
10 // min mentioned on page 246 11 min(8, 2, 3) == 2 12 // print mentioned on page 85 13 print("Hello ")
14 // println mentioned on page 4 15 println("World")
16 // sort mentioned on page 14 17 var a = ["B","A"]
18 sort(&a)
19 for i in a {
20 // "A", "B" will be printed 21  println(i)
22 }
复制代码

abs(signedNumber): Returns the absolute value of a given signed number. Trivial but not documented.

1 abs(-1) == 1 2 abs(-42) == 42 3 abs(42) == 42

contains(sequence, element): Returns true if a given sequence (such as an array) contains the specified element.

1 var languages = ["Swift", "Objective-C"]
2 contains(languages, "Swift") == true 3 contains(languages, "Java") == false 4 contains([29, 85, 42, 96, 75], 42) == true

dropFirst(sequence): Returns a new sequence (such as an array) without the first element of the sequence.

1 languages = ["Swift", "Objective-C"]
2 var oldLanguages = dropFirst(languages)
3 equal(oldLanguages, ["Objective-C"]) == true

dropLast(sequence): Returns a new sequence (such as an array) without the last element of the sequence passed as argument to the function.

1 languages = ["Swift", "Objective-C"]
2 var newLanguages = dropLast(languages)
3 equal(newLanguages, ["Swift"]) == true

dump(object): Dumps the contents of an object to standard output.

1 languages = ["Swift", "Objective-C"]
2 dump(languages)
3 // Prints:
4 // ▿ 2 elements
5 // - [0]: Swift
6 // - [1]: Objective-C

equal(sequence1, sequence2): Returns true if sequence1 and sequence2 contain the same elements.

1 languages = ["Swift", "Objective-C"]
2 equal(languages, ["Swift", "Objective-C"]) == true 3 oldLanguages = dropFirst(languages)
4 equal(oldLanguages, ["Objective-C"]) == true

filter(sequence, includeElementClosure): Returns a the elements from sequence that evaluate to true by includeElementClosure.

1 for i in filter(1...100, { $0 % 10 == 0 }) {
2 // 10, 20, 30, ... 3  println(i)
4 assert(contains([10, 20, 30, 40, 50, 60, 70, 80, 90, 100], i))
5 }

find(sequence, element): Return the index of a specified element in the given sequence. Or nil if the element is not found in the sequence.

1 languages = ["Swift", "Objective-C"]
2 find(languages, "Objective-C") == 1 3 find(languages, "Java") == nil
4 find([29, 85, 42, 96, 75], 42) == 2

indices(sequence): Returns the indices (zero indexed) of the elements in the given sequence.

1 equal(indices([29, 85, 42]), [0, 1, 2])
2 for i in indices([29, 85, 42]) {
3 // 0, 1, 2 4  println(i)
5 }

join(separator, sequence): Returns the elements of the supplied sequence separated by the given separator.

1 join(":", ["A", "B", "C"]) == "A:B:C" 2 languages = ["Swift", "Objective-C"]
3 join("/", languages) == "Swift/Objective-C"

map(sequence, transformClosure): Returns a new sequence with the transformClosure applied to all elements in the supplied sequence.

1 equal(map(1...3, { $0 * 5 }), [5, 10, 15])
2 for i in map(1...10, { $0 * 10 }) {
3 // 10, 20, 30, ... 4  println(i)
5 assert(contains([10, 20, 30, 40, 50, 60, 70, 80, 90, 100], i))
6 }

max(comparable1, comparable2, etc.): Returns the largest of the arguments given to the function.

1 max(0, 1) == 1 2 max(8, 2, 3) == 8

maxElement(sequence): Returns the largest element in a supplied sequence of comparable elements.

1 maxElement(1...10) == 10 2 languages = ["Swift", "Objective-C"]
3 maxElement(languages) == "Swift"

minElements(sequence): Returns the smallest element in a supplied sequence of comparable elements.

1 minElement(1...10) == 1 2 languages = ["Swift", "Objective-C"]
3 minElement(languages) == "Objective-C"

reduce(sequence, initial, combineClosure): Recursively reduce the elements in sequence into one value by running the combineClosure on them with starting value of initial.这个玩意一点都不懂。

1 languages = ["Swift", "Objective-C"]
2 reduce(languages, "", { $0 + $1 }) == "SwiftObjective-C" 3 reduce([10, 20, 5], 1, { $0 * $1 }) == 1000

reverse(sequence): Returns the elements of the given sequence reversed.

1 equal(reverse([1, 2, 3]), [3, 2, 1])
2 for i in reverse([1, 2, 3]) {
3 // 3, 2, 1 4  println(i)
5 }

startsWith(sequence1, sequence2): Return true if the starting elements sequence1 are equal to the of sequence2.

1 startsWith("foobar", "foo") == true 2 startsWith(1...100, 1...15) == true 3 languages = ["Swift", "Objective-C"]
4 startsWith(languages, ["Swift"]) == true

相关文章
|
1月前
|
Kubernetes 容器 Perl
error: unable to retrieve the complete list of server APIs: metrics.k8s.io/v1beta1: the server is cu
error: unable to retrieve the complete list of server APIs: metrics.k8s.io/v1beta1: the server is cu
21 0
|
Web App开发
Reuse library debug in Chrome - phase3 exchange drop down list
Reuse library debug in Chrome - phase3 exchange drop down list
88 0
Reuse library debug in Chrome - phase3 exchange drop down list
|
安全 Java Maven
Pentesting Vulnerable Study Frameworks Complete List
It’s very difficult for the beginner security analyst, mainly the ones interested in the area ...
1175 0
|
2月前
|
存储 安全 Java
java集合框架及其特点(List、Set、Queue、Map)
java集合框架及其特点(List、Set、Queue、Map)
|
1月前
|
Java
Java使用List去重的四中方式
Java使用List去重的四中方式
19 6
|
2月前
|
Java
JAVA——List中剔除空元素(null)的三种方法汇总
JAVA——List中剔除空元素(null)的三种方法汇总
|
2月前
|
安全 Java API
Java并发 - J.U.C并发容器类 list、set、queue
Queue API 阻塞是通过 condition 来实现的,可参考 Java 并发 - Lock 接口 ArrayBlockingQueue 阻塞 LinkedBlockingQueue 阻塞 ArrayQueue 非阻塞 LinkedQueue 非阻塞
|
2月前
|
存储 安全 Java
【Java】集合(一)单列集合List
【Java】集合(一)单列集合List
22 0
|
2月前
|
Java API
java 对象list 使用stream进行过滤
在Java中,你可以使用Stream API对对象列表进行过滤。假设你有一个`List<MyObject>`,并且你想根据某些条件过滤出特定的对象。以下是一个示例: ```java import java.util.List; import java.util.stream.Collectors; public class Main { public static void main(String[] args) { List<MyObject> myObjects = ... // 初始化你的对象列表 List<MyObject> filter

相关课程

更多