Skip to content

Commit

Permalink
GH-44811: [C++] minor optimize cancel and thread pool (#44812)
Browse files Browse the repository at this point in the history
### Rationale for this change

Minor code optimization for ThreadPool and cancel

### What changes are included in this PR?

Minor code optimization for ThreadPool and cancel

### Are these changes tested?

Covered by existing

### Are there any user-facing changes?

no

* GitHub Issue: #44811

Authored-by: mwish <[email protected]>
Signed-off-by: mwish <[email protected]>
  • Loading branch information
mapleFU authored Nov 27, 2024
1 parent 1c0c13a commit 26b08a3
Show file tree
Hide file tree
Showing 3 changed files with 6 additions and 3 deletions.
2 changes: 1 addition & 1 deletion cpp/src/arrow/util/cancel.cc
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ struct StopSourceImpl {
Status cancel_error_;
};

StopSource::StopSource() : impl_(new StopSourceImpl) {}
StopSource::StopSource() : impl_(std::make_shared<StopSourceImpl>()) {}

StopSource::~StopSource() = default;

Expand Down
2 changes: 1 addition & 1 deletion cpp/src/arrow/util/cancel.h
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ class ARROW_EXPORT StopSource {
class ARROW_EXPORT StopToken {
public:
// Public for Cython
StopToken() {}
StopToken() = default;

explicit StopToken(std::shared_ptr<StopSourceImpl> impl) : impl_(std::move(impl)) {}

Expand Down
5 changes: 4 additions & 1 deletion cpp/src/arrow/util/thread_pool.cc
Original file line number Diff line number Diff line change
Expand Up @@ -460,7 +460,10 @@ static void WorkerLoop(std::shared_ptr<ThreadPool::State> state,
std::move(task.stop_callback)(stop_token->Poll());
}
}
ARROW_UNUSED(std::move(task)); // release resources before waiting for lock
{
auto tmp_task = std::move(task); // release resources before waiting for lock
ARROW_UNUSED(tmp_task);
}
lock.lock();
}
if (ARROW_PREDICT_FALSE(--state->tasks_queued_or_running_ == 0)) {
Expand Down

0 comments on commit 26b08a3

Please sign in to comment.