Edit: Ignore this answer!
Here is a good answer: https://stackoverflow.com/a/50882183/5932590
See JMD’s comment below for more context!
Good question. In the source code for the tap
operator, this comment pretty much sums it up:
This operator is useful for debugging your Observables for the correct values
or performing other side effects.
Note: this is different to asubscribe
on the Observable. If the Observable returned bydo
is not subscribed, the side effects specified by the Observer will never happen.do
therefore simply spies on existing execution, it does not trigger an execution to happen likesubscribe
does.
Any side effect you can run in a tap
can probably also be put in the subscribe
block. The subscribe
indicates your intent to actively use the source value since it’s saying “when this observable emits, I want to save it’s value in the applicants
variable”. The tap
operator is mostly there for debugging, but it can be used to run side effects.
In general, favor the subscribe
block for running side effects, use tap
for debugging, but be aware that tap
can do more if you need it to.