Skip to content

Commit

Permalink
perf: ensure same hidden class for op subscribers
Browse files Browse the repository at this point in the history
  • Loading branch information
cartant committed Nov 22, 2020
1 parent 646d022 commit 807bde1
Showing 1 changed file with 38 additions and 30 deletions.
68 changes: 38 additions & 30 deletions src/internal/operators/OperatorSubscriber.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,40 +25,48 @@ export class OperatorSubscriber<T> extends Subscriber<T> {
onComplete?: () => void,
private onUnsubscribe?: () => void
) {
// It's important - for performance reasons - that all of this class's
// members are initialized and that they are always initialized in the same
// order. This will ensure that all OperatorSubscriber instances have the
// same hidden class in V8. This, in turn, will help keep the number of
// hidden classes involved in property accesses within the base class as
// low as possible. If the number of hidden classes involved exceeds four,
// the property accesses will become megamorphic and performance penalties
// will be incurred - i.e. inline caches won't be used.
super(destination);
if (onNext) {
this._next = function (value: T) {
try {
onNext(value);
} catch (err) {
this.destination.error(err);
this._next = onNext
? function (this: OperatorSubscriber<T>, value: T) {
try {
onNext(value);
} catch (err) {
this.destination.error(err);
}
}
};
}
if (onError) {
this._error = function (err) {
try {
onError(err);
} catch (err) {
// Send any errors that occur down stream.
this.destination.error(err);
: super._next;
this._error = onError
? function (this: OperatorSubscriber<T>, err: any) {
try {
onError(err);
} catch (err) {
// Send any errors that occur down stream.
this.destination.error(err);
}
// Ensure teardown.
this.unsubscribe();
}
// Ensure teardown.
this.unsubscribe();
};
}
if (onComplete) {
this._complete = function () {
try {
onComplete();
} catch (err) {
// Send any errors that occur down stream.
this.destination.error(err);
: super._error;
this._complete = onComplete
? function (this: OperatorSubscriber<T>) {
try {
onComplete();
} catch (err) {
// Send any errors that occur down stream.
this.destination.error(err);
}
// Ensure teardown.
this.unsubscribe();
}
// Ensure teardown.
this.unsubscribe();
};
}
: super._complete;
}

unsubscribe() {
Expand Down

0 comments on commit 807bde1

Please sign in to comment.