백엔드 개발 PHP 튜토리얼 Linux--스레드 동기화 및 상호 배제

Linux--스레드 동기화 및 상호 배제

Jan 18, 2017 am 10:32 AM

1. 뮤텍스 뮤텍스
동기화: 순서대로 리소스에 액세스합니다. 상호 배제: 언제든지 하나만 실행되지만 다중 스레드 프로그램의 경우 액세스 충돌 문제가 매우 일반적입니다. 해결 방법은 뮤텍스(Mutex, MutualExclusive Lock)를 도입하고 스레드를 완료하는 것입니다. 잠금을 획득하지 못한 스레드는 대기만 할 수 있고 공유 데이터에 액세스할 수 없습니다. 이러한 방식으로 "읽기-수정-쓰기"의 3단계 작업이 수행됩니다. write"는 원자적 작업을 형성합니다. 모두 실행하거나 모두 실행하지 않으면 실행 중에 중단되지 않으며 이 작업은 다른 프로세서에서 병렬로 수행되지 않습니다.
뮤텍스 잠금은 pthread_mutex_t 유형의 변수로 표시됩니다. pthread_mutex_init로 초기화되고 hread_destroy()로 소멸됩니다. 성공하면 0을 반환하고 실패하면 오류 번호를 반환합니다. . Mutex 변수가 정적으로 할당된 경우(전역 변수 또는 정적 변수) 매크로 정의 PTHREAD_MUTEX_INITIALIZER를 사용하여 초기화할 수도 있습니다. 이는 pthread_mutex_init로 초기화하는 것과 동일하며 attr 매개변수는 NULL입니다.
스레드는 pthread_mutex_lock을 호출하여 Mutex. 이때 다른 스레드가 Mutex를 획득하기 위해 스레드가 pthread_mutex_lock을 호출한 경우 현재 스레드는 다른 스레드가 Mutex를 해제하기 위해 pthread_mutex_unlock을 호출할 때까지 기다려야 하며, 현재 스레드는 Mutex를 획득하고 실행을 계속하기 전에 깨어나야 합니다. . 즉, 스레드가 뮤텍스를 잠그고 잠금을 해제하지 않고 다른 스레드가 뮤텍스를 얻으려면 전화를 끊고 잠긴 스레드가 뮤텍스를 잠금 해제하고 뮤텍스를 해제할 때까지 기다려야 합니다. 그런 다음 스레드가 깨어나서 뮤텍스를 해제할 수 있습니다.
스레드가 잠금을 획득하고 싶지만 정지 및 대기를 원하지 않는 경우 pthread_mutex_trylock을 호출할 수 있습니다. 다른 스레드가 뮤텍스를 획득한 경우 이 함수는 실패하고 스레드를 유발하지 않고 EBUSY를 반환합니다. 매달리고 기다리기.

1 #include<stdio.h>  
  2 #include<stdlib.h>  
  3 #include<pthread.h>  
  4 static int g_count=0;  
  5 void * addWrite(void * arg)  
  6 {  
  7     int count=0;  
  8     int value=0;  
  9     while(count++ <5000)  
 10     {  
 11         value=g_count;  
 12         printf("g_count is %d\n",g_count);  
 13         g_count=value+1;  
 14     }  
 15 }  
 16 int main()  
 17 {  
 18     pthread_t id1;  
 19     pthread_t id2;  
 20     int ret=pthread_create(&id1,NULL,addWrite,NULL);  
 21     int res=pthread_create(&id2,NULL,addWrite,NULL);  
 22     pthread_join(id1,NULL);  
 23     pthread_join(id2,NULL);
로그인 후 복사

우리는 각각 g_count를 5000배로 증가시키는 두 개의 스레드를 생성합니다. 일반적으로 최종 카운터는 10000과 같아야 하지만 실제로는 프로그램이 실행될 때마다 결과가 5000을 초과하는 경우도 있습니다. 카운트가 6000을 넘는 경우도 있지만 잠금을 추가한 후 아래 그림과 같이 다섯 번째 줄에 pthread_mutex_init(in)을 추가하세요.

Linux--스레드 동기화 및 상호 배제

결과:

Linux--스레드 동기화 및 상호 배제

잠금을 추가하면 10000이 출력됩니다
2. 잠금 및 잠금 해제의 구현 원리

뮤텍스 잠금 동작을 구현하기 위해 대부분의 아키텍처에서는 스왑 또는 교환 명령을 제공합니다. 명령어는 레지스터와 메모리 유닛 사이에서 데이터를 교환하는 기능이다. 명령어가 하나만 있기 때문에 다중 프로세서 플랫폼에서도 메모리에 접근하는 버스 사이클은 순차적이다. 한 프로세서는 다른 프로세서에서 실행됩니다. 스왑 명령은 버스 사이클 동안만 기다릴 수 있습니다. 이는 아래 의사코드에 나와 있습니다. 잠금 해제 시 잠금 해제 작업도 원자성을 보장하기 위해 하나의 명령으로만 구현됩니다.

Linux--스레드 동기화 및 상호 배제

3. 교착 상태
・일반적으로 동일한 스레드가 잠금을 두 번 호출하면 두 번째 호출 중에 잠금이 이미 사용 중이므로 스레드가 중단됩니다. 그리고 다른 스레드가 잠금을 해제할 때까지 기다립니다. 그러나 잠금은 자체적으로 사용되며 스레드는 잠금을 해제할 기회 없이 일시 중지되므로 이를 교착 상태라고 합니다. 또 다른 일반적인 교착 상태 상황은 다음과 같습니다. 스레드 A는 잠금 1을 획득하고 스레드 B는 잠금 2를 획득합니다. 이때 스레드 A는 잠금 2를 획득하려고 시도합니다. 결과적으로 스레드 B가 해제될 때까지 기다려야 합니다. 스레드 B도 잠금 1을 얻기 위해 잠금을 호출하면 스레드 A가 잠금 1을 해제할 때까지 기다려야 하므로 스레드 A와 B 모두 영원히 일시 중지 상태에 있습니다.
교착 상태 발생 조건
①. 상호 배제 조건: 리소스는 한 번에 하나의 스레드에서만 사용할 수 있습니다.
②. 요청 및 보유 조건: 리소스 요청으로 인해 프로세스가 차단되면 획득한 리소스를 보유합니다.

3. 비박탈 조건: 프로세스를 통해 획득한 자원은 모두 사용되기 전에 강제로 박탈될 수 없습니다.

④순환 대기 조건: 여러 프로세스 간에 헤드-투-테일 순환 대기 자원 관계가 형성됩니다.

더 많은 스레드와 더 많은 잠금이 관련되면 교착 상태 문제가 발생할 가능성이 높습니다. 프로그램을 작성할 때 동시에 여러 잠금을 획득하지 않도록 노력해야 합니다. 필요한 경우 원칙이 있습니다. 모든 스레드에 여러 잠금이 필요한 경우 동일한 순서를 따라야 합니다(가장 일반적인 순서는 다음과 같습니다). Mutex 변수의 주소 순서대로) Lock을 획득하면 교착 상태가 발생하지 않습니다. 예를 들어, 잠금 1, 잠금 2 및 잠금 3이 프로그램에서 사용되고 해당 Mutex 변수의 주소가 잠금 1

위 내용은 Linux-thread 동기화 및 상호 배제 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!


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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Centos와 Ubuntu의 차이 Centos와 Ubuntu의 차이 Apr 14, 2025 pm 09:09 PM

Centos와 Ubuntu의 주요 차이점은 다음과 같습니다. Origin (Centos는 Red Hat, Enterprise의 경우, Ubuntu는 Debian에서 시작하여 개인의 경우), 패키지 관리 (Centos는 안정성에 중점을 둡니다. Ubuntu는 APT를 사용하여 APT를 사용합니다), 지원주기 (Ubuntu는 5 년 동안 LTS 지원을 제공합니다), 커뮤니티에 중점을 둔다 (Centos Conciors on ubuntu). 튜토리얼 및 문서), 사용 (Centos는 서버에 편향되어 있으며 Ubuntu는 서버 및 데스크탑에 적합), 다른 차이점에는 설치 단순성 (Centos는 얇음)이 포함됩니다.

Centos를 설치하는 방법 Centos를 설치하는 방법 Apr 14, 2025 pm 09:03 PM

CentOS 설치 단계 : ISO 이미지를 다운로드하고 부팅 가능한 미디어를 실행하십시오. 부팅하고 설치 소스를 선택하십시오. 언어 및 키보드 레이아웃을 선택하십시오. 네트워크 구성; 하드 디스크를 분할; 시스템 시계를 설정하십시오. 루트 사용자를 만듭니다. 소프트웨어 패키지를 선택하십시오. 설치를 시작하십시오. 설치가 완료된 후 하드 디스크에서 다시 시작하고 부팅하십시오.

유지 보수를 중단 한 후 Centos의 선택 유지 보수를 중단 한 후 Centos의 선택 Apr 14, 2025 pm 08:51 PM

Centos는 중단되었으며 대안은 다음과 같습니다. 1. Rocky Linux (Best Compatibility); 2. Almalinux (Centos와 호환); 3. Ubuntu 서버 (구성 필수); 4. Red Hat Enterprise Linux (상업용 버전, 유료 라이센스); 5. Oracle Linux (Centos 및 Rhel과 호환). 마이그레이션시 고려 사항은 호환성, 가용성, 지원, 비용 및 커뮤니티 지원입니다.

Docker 원리에 대한 자세한 설명 Docker 원리에 대한 자세한 설명 Apr 14, 2025 pm 11:57 PM

Docker는 Linux 커널 기능을 사용하여 효율적이고 고립 된 응용 프로그램 실행 환경을 제공합니다. 작동 원리는 다음과 같습니다. 1. 거울은 읽기 전용 템플릿으로 사용되며, 여기에는 응용 프로그램을 실행하는 데 필요한 모든 것을 포함합니다. 2. Union 파일 시스템 (Unionfs)은 여러 파일 시스템을 스택하고 차이점 만 저장하고 공간을 절약하고 속도를 높입니다. 3. 데몬은 거울과 컨테이너를 관리하고 클라이언트는 상호 작용을 위해 사용합니다. 4. 네임 스페이스 및 CGroup은 컨테이너 격리 및 자원 제한을 구현합니다. 5. 다중 네트워크 모드는 컨테이너 상호 연결을 지원합니다. 이러한 핵심 개념을 이해 함으로써만 Docker를 더 잘 활용할 수 있습니다.

Docker Desktop을 사용하는 방법 Docker Desktop을 사용하는 방법 Apr 15, 2025 am 11:45 AM

Docker Desktop을 사용하는 방법? Docker Desktop은 로컬 머신에서 Docker 컨테이너를 실행하는 도구입니다. 사용 단계는 다음과 같습니다. 1. Docker Desktop 설치; 2. Docker Desktop을 시작하십시오. 3. Docker 이미지를 만듭니다 (Dockerfile 사용); 4. Docker Image 빌드 (Docker 빌드 사용); 5. 도커 컨테이너를 실행하십시오 (Docker Run 사용).

Centos 후해야 할 일은 유지 보수를 중단합니다 Centos 후해야 할 일은 유지 보수를 중단합니다 Apr 14, 2025 pm 08:48 PM

Centos가 중단 된 후 사용자는 다음과 같은 조치를 취할 수 있습니다. Almalinux, Rocky Linux 및 Centos 스트림과 같은 호환되는 분포를 선택하십시오. Red Hat Enterprise Linux, Oracle Linux와 같은 상업 분포로 마이그레이션합니다. Centos 9 Stream : 롤링 분포로 업그레이드하여 최신 기술을 제공합니다. Ubuntu, Debian과 같은 다른 Linux 배포판을 선택하십시오. 컨테이너, 가상 머신 또는 클라우드 플랫폼과 같은 다른 옵션을 평가하십시오.

Docker 이미지가 실패하면해야 할 일 Docker 이미지가 실패하면해야 할 일 Apr 15, 2025 am 11:21 AM

실패한 Docker 이미지 빌드에 대한 문제 해결 단계 : Dockerfile 구문 및 종속성 버전을 확인하십시오. 빌드 컨텍스트에 필요한 소스 코드 및 종속성이 포함되어 있는지 확인하십시오. 오류 세부 사항에 대한 빌드 로그를보십시오. -표적 옵션을 사용하여 계층 적 단계를 구축하여 실패 지점을 식별하십시오. 최신 버전의 Docker Engine을 사용하십시오. -t [image-name] : 디버그 모드로 이미지를 빌드하여 문제를 디버깅하십시오. 디스크 공간을 확인하고 충분한 지 확인하십시오. 빌드 프로세스에 대한 간섭을 방지하기 위해 Selinux를 비활성화하십시오. 커뮤니티 플랫폼에 도움을 요청하고 Dockerfiles를 제공하며보다 구체적인 제안을 위해 로그 설명을 구축하십시오.

VSCODE에 필요한 컴퓨터 구성 VSCODE에 필요한 컴퓨터 구성 Apr 15, 2025 pm 09:48 PM

대 코드 시스템 요구 사항 : 운영 체제 : Windows 10 이상, MacOS 10.12 이상, Linux 배포 프로세서 : 최소 1.6GHz, 권장 2.0GHz 이상의 메모리 : 최소 512MB, 권장 4GB 이상의 저장 공간 : 최소 250MB, 권장 1GB 및 기타 요구 사항 : 안정 네트워크 연결, Xorg/Wayland (LINUX)

See all articles