mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
62 lines
1.7 KiB
Swift
62 lines
1.7 KiB
Swift
//===--- PopFront.swift ---------------------------------------------------===//
|
|
//
|
|
// This source file is part of the Swift.org open source project
|
|
//
|
|
// Copyright (c) 2014 - 2021 Apple Inc. and the Swift project authors
|
|
// Licensed under Apache License v2.0 with Runtime Library Exception
|
|
//
|
|
// See https://swift.org/LICENSE.txt for license information
|
|
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
import TestsUtils
|
|
|
|
public let benchmarks = [
|
|
BenchmarkInfo(name: "PopFrontArray",
|
|
runFunction: run_PopFrontArray,
|
|
tags: [.validation, .api, .Array],
|
|
legacyFactor: 20),
|
|
BenchmarkInfo(name: "PopFrontUnsafePointer",
|
|
runFunction: run_PopFrontUnsafePointer,
|
|
tags: [.validation, .api],
|
|
legacyFactor: 100),
|
|
]
|
|
|
|
let arrayCount = 1024
|
|
|
|
@inline(never)
|
|
public func run_PopFrontArray(_ n: Int) {
|
|
let orig = Array(repeating: 1, count: arrayCount)
|
|
var a = [Int]()
|
|
for _ in 1...n {
|
|
var result = 0
|
|
a.append(contentsOf: orig)
|
|
while a.count != 0 {
|
|
result += a[0]
|
|
a.remove(at: 0)
|
|
}
|
|
check(result == arrayCount)
|
|
}
|
|
}
|
|
|
|
@inline(never)
|
|
public func run_PopFrontUnsafePointer(_ n: Int) {
|
|
let orig = Array(repeating: 1, count: arrayCount)
|
|
let a = UnsafeMutablePointer<Int>.allocate(capacity: arrayCount)
|
|
for _ in 1...n {
|
|
for i in 0..<arrayCount {
|
|
a[i] = orig[i]
|
|
}
|
|
var result = 0
|
|
var count = arrayCount
|
|
while count != 0 {
|
|
result += a[0]
|
|
a.update(from: a + 1, count: count - 1)
|
|
count -= 1
|
|
}
|
|
check(result == arrayCount)
|
|
}
|
|
a.deallocate()
|
|
}
|