zcw-shared 1.22.0 → 1.23.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,44 @@
1
+ export interface GCObject {
2
+ id: string;
3
+ name: string;
4
+ references: string[];
5
+ isRoot: boolean;
6
+ size: number;
7
+ age: number;
8
+ generation: 'young' | 'old';
9
+ space?: 'from' | 'to';
10
+ marked: boolean;
11
+ }
12
+ export interface GCStep {
13
+ stepNumber: number;
14
+ gcType: 'scavenge' | 'mark-sweep' | 'full';
15
+ action: 'init' | 'scan' | 'copy' | 'swap' | 'promote' | 'mark' | 'sweep' | 'compact' | 'complete';
16
+ currentObjectId?: string;
17
+ objects: GCObject[];
18
+ explanation: string;
19
+ collected: string[];
20
+ promoted: string[];
21
+ memoryStats: {
22
+ youngTotal: number;
23
+ youngUsed: number;
24
+ oldTotal: number;
25
+ oldUsed: number;
26
+ freed: number;
27
+ };
28
+ }
29
+ export interface GCResult {
30
+ steps: GCStep[];
31
+ survivors: string[];
32
+ collected: string[];
33
+ promoted: string[];
34
+ freedMemory: number;
35
+ }
36
+ export declare function visualizeGarbageCollection(initialObjects: Array<{
37
+ id: string;
38
+ name: string;
39
+ references: string[];
40
+ isRoot: boolean;
41
+ generation: 'young' | 'old';
42
+ age: number;
43
+ size: number;
44
+ }>, gcType?: 'scavenge' | 'full'): GCResult;
@@ -0,0 +1,263 @@
1
+ function scavengeGC(objects, steps, stepNum, collected, promoted) {
2
+ const allObjects = Array.from(objects.values());
3
+ const youngObjects = allObjects.filter(o => o.generation === 'young');
4
+ steps.push({
5
+ stepNumber: stepNum.value++,
6
+ gcType: 'scavenge',
7
+ action: 'init',
8
+ objects: allObjects.map(o => ({ ...o })),
9
+ explanation: `启动新生代 GC (Scavenge):检测到 ${youngObjects.length} 个年轻对象`,
10
+ collected: [...collected],
11
+ promoted: [...promoted],
12
+ memoryStats: calculateMemoryStats(allObjects, 0)
13
+ });
14
+ const reachableYoung = new Set();
15
+ for (const obj of allObjects) {
16
+ if (obj.isRoot && obj.generation === 'young' && obj.space === 'from') {
17
+ scanYoungObject(obj.id, objects, reachableYoung, steps, stepNum, collected, promoted, allObjects);
18
+ }
19
+ if (obj.generation === 'old') {
20
+ for (const refId of obj.references) {
21
+ const refObj = objects.get(refId);
22
+ if (refObj && refObj.generation === 'young' && refObj.space === 'from') {
23
+ scanYoungObject(refId, objects, reachableYoung, steps, stepNum, collected, promoted, allObjects);
24
+ }
25
+ }
26
+ }
27
+ }
28
+ for (const objId of reachableYoung) {
29
+ const obj = objects.get(objId);
30
+ if (!obj)
31
+ continue;
32
+ if (obj.age >= 2) {
33
+ obj.generation = 'old';
34
+ obj.space = undefined;
35
+ promoted.push(objId);
36
+ const currentObjects = Array.from(objects.values());
37
+ steps.push({
38
+ stepNumber: stepNum.value++,
39
+ gcType: 'scavenge',
40
+ action: 'promote',
41
+ currentObjectId: objId,
42
+ objects: currentObjects.map(o => ({ ...o })),
43
+ explanation: `对象 ${obj.name} 年龄达到 ${obj.age},晋升到老生代`,
44
+ collected: [...collected],
45
+ promoted: [...promoted],
46
+ memoryStats: calculateMemoryStats(currentObjects, 0)
47
+ });
48
+ }
49
+ else {
50
+ obj.space = 'to';
51
+ obj.age++;
52
+ const currentObjects = Array.from(objects.values());
53
+ steps.push({
54
+ stepNumber: stepNum.value++,
55
+ gcType: 'scavenge',
56
+ action: 'copy',
57
+ currentObjectId: objId,
58
+ objects: currentObjects.map(o => ({ ...o })),
59
+ explanation: `复制对象 ${obj.name} 到 To 空间,年龄 ${obj.age - 1} → ${obj.age}`,
60
+ collected: [...collected],
61
+ promoted: [...promoted],
62
+ memoryStats: calculateMemoryStats(currentObjects, 0)
63
+ });
64
+ }
65
+ }
66
+ let freedMemory = 0;
67
+ for (const obj of youngObjects) {
68
+ if (obj.space === 'from' && !reachableYoung.has(obj.id)) {
69
+ freedMemory += obj.size;
70
+ collected.push(obj.id);
71
+ objects.delete(obj.id);
72
+ const currentObjects = Array.from(objects.values());
73
+ steps.push({
74
+ stepNumber: stepNum.value++,
75
+ gcType: 'scavenge',
76
+ action: 'sweep',
77
+ currentObjectId: obj.id,
78
+ objects: currentObjects.map(o => ({ ...o })),
79
+ explanation: `回收 From 空间中的对象 ${obj.name} (${obj.size} KB)`,
80
+ collected: [...collected],
81
+ promoted: [...promoted],
82
+ memoryStats: calculateMemoryStats(currentObjects, freedMemory)
83
+ });
84
+ }
85
+ }
86
+ for (const obj of objects.values()) {
87
+ if (obj.generation === 'young' && obj.space === 'to') {
88
+ obj.space = 'from';
89
+ }
90
+ }
91
+ const finalObjects = Array.from(objects.values());
92
+ steps.push({
93
+ stepNumber: stepNum.value++,
94
+ gcType: 'scavenge',
95
+ action: 'swap',
96
+ objects: finalObjects.map(o => ({ ...o })),
97
+ explanation: `交换 From/To 空间:To 空间变为新的 From 空间`,
98
+ collected: [...collected],
99
+ promoted: [...promoted],
100
+ memoryStats: calculateMemoryStats(finalObjects, freedMemory)
101
+ });
102
+ }
103
+ function scanYoungObject(objId, objects, reachable, steps, stepNum, collected, promoted, allObjects) {
104
+ if (reachable.has(objId))
105
+ return;
106
+ const obj = objects.get(objId);
107
+ if (!obj || obj.generation !== 'young' || obj.space !== 'from')
108
+ return;
109
+ reachable.add(objId);
110
+ steps.push({
111
+ stepNumber: stepNum.value++,
112
+ gcType: 'scavenge',
113
+ action: 'scan',
114
+ currentObjectId: objId,
115
+ objects: allObjects.map(o => ({ ...o })),
116
+ explanation: `扫描年轻对象 ${obj.name},标记为可达`,
117
+ collected: [...collected],
118
+ promoted: [...promoted],
119
+ memoryStats: calculateMemoryStats(allObjects, 0)
120
+ });
121
+ for (const refId of obj.references) {
122
+ scanYoungObject(refId, objects, reachable, steps, stepNum, collected, promoted, allObjects);
123
+ }
124
+ }
125
+ function markSweepGC(objects, steps, stepNum, collected, promoted) {
126
+ const allObjects = Array.from(objects.values());
127
+ const oldObjects = allObjects.filter(o => o.generation === 'old');
128
+ steps.push({
129
+ stepNumber: stepNum.value++,
130
+ gcType: 'mark-sweep',
131
+ action: 'init',
132
+ objects: allObjects.map(o => ({ ...o })),
133
+ explanation: `启动老生代 GC (Mark-Sweep):检测到 ${oldObjects.length} 个老对象`,
134
+ collected: [...collected],
135
+ promoted: [...promoted],
136
+ memoryStats: calculateMemoryStats(allObjects, 0)
137
+ });
138
+ for (const obj of allObjects) {
139
+ if (obj.isRoot) {
140
+ markObject(obj.id, objects, steps, stepNum, collected, promoted, allObjects);
141
+ }
142
+ }
143
+ let freedMemory = 0;
144
+ for (const obj of oldObjects) {
145
+ if (!obj.marked) {
146
+ freedMemory += obj.size;
147
+ collected.push(obj.id);
148
+ objects.delete(obj.id);
149
+ const currentObjects = Array.from(objects.values());
150
+ steps.push({
151
+ stepNumber: stepNum.value++,
152
+ gcType: 'mark-sweep',
153
+ action: 'sweep',
154
+ currentObjectId: obj.id,
155
+ objects: currentObjects.map(o => ({ ...o })),
156
+ explanation: `清除未标记的老对象 ${obj.name} (${obj.size} KB)`,
157
+ collected: [...collected],
158
+ promoted: [...promoted],
159
+ memoryStats: calculateMemoryStats(currentObjects, freedMemory)
160
+ });
161
+ }
162
+ }
163
+ for (const obj of objects.values()) {
164
+ obj.marked = false;
165
+ }
166
+ }
167
+ function markObject(objId, objects, steps, stepNum, collected, promoted, allObjects) {
168
+ const obj = objects.get(objId);
169
+ if (!obj || obj.marked)
170
+ return;
171
+ obj.marked = true;
172
+ steps.push({
173
+ stepNumber: stepNum.value++,
174
+ gcType: 'mark-sweep',
175
+ action: 'mark',
176
+ currentObjectId: objId,
177
+ objects: allObjects.map(o => ({ ...o })),
178
+ explanation: `标记 ${obj.generation === 'old' ? '老' : '年轻'}对象 ${obj.name} 为可达`,
179
+ collected: [...collected],
180
+ promoted: [...promoted],
181
+ memoryStats: calculateMemoryStats(allObjects, 0)
182
+ });
183
+ for (const refId of obj.references) {
184
+ markObject(refId, objects, steps, stepNum, collected, promoted, allObjects);
185
+ }
186
+ }
187
+ function calculateMemoryStats(objects, freed) {
188
+ const youngObjs = objects.filter(o => o.generation === 'young');
189
+ const oldObjs = objects.filter(o => o.generation === 'old');
190
+ return {
191
+ youngTotal: 1024,
192
+ youngUsed: youngObjs.reduce((sum, o) => sum + o.size, 0),
193
+ oldTotal: 4096,
194
+ oldUsed: oldObjs.reduce((sum, o) => sum + o.size, 0),
195
+ freed
196
+ };
197
+ }
198
+ export function visualizeGarbageCollection(initialObjects, gcType = 'scavenge') {
199
+ const steps = [];
200
+ const stepNum = { value: 0 };
201
+ const collected = [];
202
+ const promoted = [];
203
+ const objects = new Map();
204
+ initialObjects.forEach(obj => {
205
+ objects.set(obj.id, {
206
+ ...obj,
207
+ space: obj.generation === 'young' ? 'from' : undefined,
208
+ marked: false
209
+ });
210
+ });
211
+ const allObjects = Array.from(objects.values());
212
+ steps.push({
213
+ stepNumber: stepNum.value++,
214
+ gcType,
215
+ action: 'init',
216
+ objects: allObjects.map(o => ({ ...o })),
217
+ explanation: `初始化 ${gcType === 'scavenge' ? '新生代' : '完整'} GC:${allObjects.filter(o => o.generation === 'young').length} 个年轻对象,${allObjects.filter(o => o.generation === 'old').length} 个老对象`,
218
+ collected: [],
219
+ promoted: [],
220
+ memoryStats: calculateMemoryStats(allObjects, 0)
221
+ });
222
+ if (gcType === 'scavenge') {
223
+ scavengeGC(objects, steps, stepNum, collected, promoted);
224
+ }
225
+ else {
226
+ scavengeGC(objects, steps, stepNum, collected, promoted);
227
+ const afterScavenge = Array.from(objects.values());
228
+ steps.push({
229
+ stepNumber: stepNum.value++,
230
+ gcType: 'mark-sweep',
231
+ action: 'init',
232
+ objects: afterScavenge.map(o => ({ ...o })),
233
+ explanation: `新生代 GC 完成,开始老生代 GC`,
234
+ collected: [...collected],
235
+ promoted: [...promoted],
236
+ memoryStats: calculateMemoryStats(afterScavenge, 0)
237
+ });
238
+ markSweepGC(objects, steps, stepNum, collected, promoted);
239
+ }
240
+ const finalObjects = Array.from(objects.values());
241
+ const totalFreed = collected.reduce((sum, id) => {
242
+ const obj = initialObjects.find(o => o.id === id);
243
+ return sum + (obj?.size || 0);
244
+ }, 0);
245
+ steps.push({
246
+ stepNumber: stepNum.value++,
247
+ gcType,
248
+ action: 'complete',
249
+ objects: finalObjects.map(o => ({ ...o })),
250
+ explanation: `GC 完成:回收 ${collected.length} 个对象,晋升 ${promoted.length} 个对象,释放 ${totalFreed} KB`,
251
+ collected: [...collected],
252
+ promoted: [...promoted],
253
+ memoryStats: calculateMemoryStats(finalObjects, totalFreed)
254
+ });
255
+ return {
256
+ steps,
257
+ survivors: Array.from(objects.keys()),
258
+ collected,
259
+ promoted,
260
+ freedMemory: totalFreed
261
+ };
262
+ }
263
+ //# sourceMappingURL=visualizeGarbageCollection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"visualizeGarbageCollection.js","sourceRoot":"","sources":["../../../src/functions/algorithm/visualizeGarbageCollection.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import type { Window } from '../../../references/browser.d';
2
+ import type { setTimeout, clearTimeout } from '../../../references/timer.d';
3
+ export type ThrottledEventType = 'resize' | 'scroll' | 'mousemove' | 'touchmove' | 'pointermove' | 'wheel';
4
+ export interface CreateThrottledEventListenerDeps {
5
+ addEventListener: Window['addEventListener'];
6
+ removeEventListener: Window['removeEventListener'];
7
+ setTimeout: typeof setTimeout;
8
+ clearTimeout: typeof clearTimeout;
9
+ now: () => number;
10
+ }
11
+ export declare function createThrottledEventListener(eventType: ThrottledEventType, callback: () => void, throttleMs: number, deps: CreateThrottledEventListenerDeps): () => void;
@@ -0,0 +1,51 @@
1
+ export function createThrottledEventListener(eventType, callback, throttleMs, deps) {
2
+ if (throttleMs === 0) {
3
+ const handleEvent = () => {
4
+ callback();
5
+ };
6
+ deps.addEventListener(eventType, handleEvent, { passive: true });
7
+ return () => {
8
+ deps.removeEventListener(eventType, handleEvent);
9
+ };
10
+ }
11
+ let timeoutId = undefined;
12
+ let lastExecuteTime = -1;
13
+ let hasPendingCall = false;
14
+ const executeCallback = () => {
15
+ lastExecuteTime = deps.now();
16
+ hasPendingCall = false;
17
+ callback();
18
+ };
19
+ const handleEvent = () => {
20
+ const now = deps.now();
21
+ const timeSinceLastExecute = now - lastExecuteTime;
22
+ if (lastExecuteTime < 0 || timeSinceLastExecute >= throttleMs) {
23
+ if (timeoutId !== undefined) {
24
+ deps.clearTimeout(timeoutId);
25
+ timeoutId = undefined;
26
+ }
27
+ executeCallback();
28
+ }
29
+ else {
30
+ hasPendingCall = true;
31
+ if (timeoutId === undefined) {
32
+ const remainingTime = throttleMs - timeSinceLastExecute;
33
+ timeoutId = deps.setTimeout(() => {
34
+ timeoutId = undefined;
35
+ if (hasPendingCall) {
36
+ executeCallback();
37
+ }
38
+ }, remainingTime);
39
+ }
40
+ }
41
+ };
42
+ deps.addEventListener(eventType, handleEvent, { passive: true });
43
+ return () => {
44
+ deps.removeEventListener(eventType, handleEvent);
45
+ if (timeoutId !== undefined) {
46
+ deps.clearTimeout(timeoutId);
47
+ timeoutId = undefined;
48
+ }
49
+ };
50
+ }
51
+ //# sourceMappingURL=createThrottledEventListener.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createThrottledEventListener.js","sourceRoot":"","sources":["../../../src/functions/dom/createThrottledEventListener.ts"],"names":[],"mappings":"AA+DA,MAAM,UAAU,4BAA4B,CAC1C,SAA6B,EAC7B,QAAoB,EACpB,UAAkB,EAClB,IAAsC;IAGtC,IAAI,UAAU,KAAK,CAAC,EAAE,CAAC;QACrB,MAAM,WAAW,GAAkB,GAAG,EAAE;YACtC,QAAQ,EAAE,CAAA;QACZ,CAAC,CAAA;QAED,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,WAAW,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QAEhE,OAAO,GAAG,EAAE;YACV,IAAI,CAAC,mBAAmB,CAAC,SAAS,EAAE,WAAW,CAAC,CAAA;QAClD,CAAC,CAAA;IACH,CAAC;IAGD,IAAI,SAAS,GAAQ,SAAS,CAAA;IAC9B,IAAI,eAAe,GAAG,CAAC,CAAC,CAAA;IACxB,IAAI,cAAc,GAAG,KAAK,CAAA;IAE1B,MAAM,eAAe,GAAG,GAAG,EAAE;QAC3B,eAAe,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;QAC5B,cAAc,GAAG,KAAK,CAAA;QACtB,QAAQ,EAAE,CAAA;IACZ,CAAC,CAAA;IAED,MAAM,WAAW,GAAkB,GAAG,EAAE;QACtC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;QACtB,MAAM,oBAAoB,GAAG,GAAG,GAAG,eAAe,CAAA;QAGlD,IAAI,eAAe,GAAG,CAAC,IAAI,oBAAoB,IAAI,UAAU,EAAE,CAAC;YAE9D,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;gBAC5B,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAA;gBAC5B,SAAS,GAAG,SAAS,CAAA;YACvB,CAAC;YACD,eAAe,EAAE,CAAA;QACnB,CAAC;aAAM,CAAC;YAEN,cAAc,GAAG,IAAI,CAAA;YAGrB,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;gBAC5B,MAAM,aAAa,GAAG,UAAU,GAAG,oBAAoB,CAAA;gBACvD,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,EAAE;oBAC/B,SAAS,GAAG,SAAS,CAAA;oBACrB,IAAI,cAAc,EAAE,CAAC;wBACnB,eAAe,EAAE,CAAA;oBACnB,CAAC;gBACH,CAAC,EAAE,aAAa,CAAC,CAAA;YACnB,CAAC;QAGH,CAAC;IACH,CAAC,CAAA;IAED,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,WAAW,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;IAGhE,OAAO,GAAG,EAAE;QACV,IAAI,CAAC,mBAAmB,CAAC,SAAS,EAAE,WAAW,CAAC,CAAA;QAChD,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;YAC5B,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAA;YAC5B,SAAS,GAAG,SAAS,CAAA;QACvB,CAAC;IACH,CAAC,CAAA;AACH,CAAC"}
@@ -0,0 +1,20 @@
1
+ export interface VisualizationStep {
2
+ stepNumber: number;
3
+ textPos: number;
4
+ patternPos: number;
5
+ action: string;
6
+ status: 'trying' | 'success' | 'fail' | 'backtrack';
7
+ matched: string;
8
+ explanation: string;
9
+ currentChar?: string;
10
+ currentPattern?: string;
11
+ }
12
+ export interface RegexMatchResult {
13
+ hasMatch: boolean;
14
+ matchedText: string;
15
+ matchIndex: number;
16
+ matchEndIndex: number;
17
+ steps: VisualizationStep[];
18
+ error?: string;
19
+ }
20
+ export declare function testRegex(pattern: string, text: string): RegexMatchResult;