-
Notifications
You must be signed in to change notification settings - Fork 11
Expand file tree
/
Copy path9-exclusive.js
More file actions
64 lines (56 loc) · 1.41 KB
/
9-exclusive.js
File metadata and controls
64 lines (56 loc) · 1.41 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
'use strict';
class Pool {
constructor() {
this.instances = [];
this.free = [];
this.current = 0;
this.size = 0;
this.available = 0;
}
acquire() {
if (this.available === 0) return null;
let instance = null;
let free = false;
do {
instance = this.instances[this.current];
free = this.free[this.current];
this.current++;
if (this.current === this.size) this.current = 0;
} while (!instance || !free);
return instance;
}
add(instance) {
if (this.instances.includes(instance)) {
throw new Error('Pool: add duplicates');
}
this.size++;
this.available++;
this.instances.push(instance);
this.free.push(true);
}
capture() {
const instance = this.acquire();
if (!instance) return null;
const index = this.instances.indexOf(instance);
this.free[index] = false;
this.available--;
return instance;
}
release(instance) {
const index = this.instances.indexOf(instance);
if (index < 0) throw new Error('Pool: release unexpected instance');
if (this.free[index]) throw new Error('Pool: release not captured');
this.free[index] = true;
this.available++;
}
}
// Usage
const pool = new Pool();
pool.add({ instance: 1 });
pool.add({ instance: 2 });
const last = { instance: 3 };
pool.add(last);
for (let i = 0; i < 10; i++) {
console.log(pool.capture());
if (i === 5) pool.release(last);
}