주어진 작업은 프로세스 내에서 생성할 수 있는 최대 스레드 수를 찾는 것입니다.
스레드는 경량 프로세스이며 스케줄러에서 독립적으로 관리할 수 있습니다. thread는 프로세스의 구성 요소이기 때문에 프로세스에 여러 개의 스레드가 연결될 수 있으며 프로세스보다 가볍기 때문에 컨텍스트 전환에 걸리는 시간도 적습니다.
스레드는 프로세스보다 적은 리소스를 필요로 하며 피어스레드와 메모리를 공유합니다. 모든 사용자 수준 피어 스레드는 운영 체제에서 단일 작업으로 처리됩니다. 생성 및 종료에 더 적은 시간이 필요합니다.
출력은 프로그램이 실행될 때마다 항상 다릅니다.
아래 프로그램에서 사용하는 접근 방식은 다음과 같습니다.
-
void* create(void *) 함수를 만들고 스레드의 작업만 보여주기 때문에 비워 둡니다.
-
main() 함수에서 최대 스레드 수와 반환 값을 각각 저장하기 위해 int 유형의 두 변수 max =0 및 ret =0을 초기화합니다.
-
pthread_t 유형의 변수 "th"를 선언합니다.
-
조건 ret ==0으로 while 루프를 실행하고 ret =pthread_create (&th,NULL, create, NULL);
를 입력합니다. -
루프 내에서 max++를 반복합니다.
-
루프 외부에서 최대값을 인쇄합니다.
예시
#include<pthread.h> #include<stdio.h> /*Leave the function empty as it only demonstrates work of thread*/ void *create ( void *){ } //main function int main(){ int max = 0, ret = 0; pthread_t th; //Iterate until 0 is returned while (ret == 0){ ret = pthread_create (&th, NULL, create, NULL); max++; } printf(" %d ", max); }
출력
5741