>백엔드 개발 >C++ >Mutex를 이동 가능하고 스레드로부터 안전한 C 클래스로 만들려면 어떻게 해야 합니까?

Mutex를 이동 가능하고 스레드로부터 안전한 C 클래스로 만들려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-29 06:05:14673검색

How Can I Make My C   Class with a Mutex Movable and Thread-Safe?

C에서 이동 가능한 유형의 뮤텍스 처리

문제:

std::mutex의 복사 가능 및 이동 불가능 특성, 뮤텍스를 보유하는 클래스 기본 이동 생성자가 부족하여 이동 가능한 스레드로부터 안전한 유형을 생성하기가 어렵습니다.

해결책:

뮤텍스를 보유하는 클래스 A에 대한 스레드로부터 안전한 이동 의미 체계를 달성하려면, 다음 전략을 채택하십시오:

이동 생성자:

A(A&& a) {
    WriteLock rhs_lk(a.mut_); // Lock the rhs mutex
    field1_ = std::move(a.field1_); // Move the data
    field2_ = std::move(a.field2_);
}

이동 할당 연산자:

A& operator=(A&& a) {
    if (this != &a) {
        WriteLock lhs_lk(mut_, std::defer_lock);
        WriteLock rhs_lk(a.mut_, std::defer_lock);
        std::lock(lhs_lk, rhs_lk);
        field1_ = std::move(a.field1_);
        field2_ = std::move(a.field2_);
    }
    return *this;
}

복사 생성자:

A(const A& a) {
    ReadLock rhs_lk(a.mut_); // Lock the rhs mutex for reading
    field1_ = a.field1_; // Copy the data
    field2_ = a.field2_;
}

과제 복사 연산자:

A& operator=(const A& a) {
    if (this != &a) {
        WriteLock lhs_lk(mut_, std::defer_lock);
        ReadLock rhs_lk(a.mut_, std::defer_lock);
        std::lock(lhs_lk, rhs_lk);
        field1_ = a.field1_;
        field2_ = a.field2_;
    }
    return *this;
}

기타 고려 사항:

  • 편의를 위해 ReadLock 및 WriteLock 유형 별칭을 정의합니다.
  • 다음을 기억하세요. 이동 할당 연산자가 방지되도록 std::lock을 사용하여 두 뮤텍스를 모두 잠급니다. 교착 상태.
  • 동시 읽기를 허용하려면 C 14에서 std::shared_timed_mutex를 사용하는 것을 고려하세요.
  • 적절한 뮤텍스 잠금을 사용하여 클래스 A의 내부 상태에 액세스하는 모든 멤버 함수나 자유 함수를 보호하세요.
  • 필요한 경우 데이터 멤버 잠금을 추가하여 ReadLock 및 WriteLock 개체를 저장하여 기본 구성 멤버를 방지합니다. 복사 중입니다.

위 내용은 Mutex를 이동 가능하고 스레드로부터 안전한 C 클래스로 만들려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.