Advanced Linux Programming: 4-Threads
Số trang: 34
Loại file: pdf
Dung lượng: 285.57 KB
Lượt xem: 10
Lượt tải: 0
Xem trước 4 trang đầu tiên của tài liệu này:
Thông tin tài liệu:
Tham khảo tài liệu advanced linux programming: 4-threads, công nghệ thông tin, hệ điều hành phục vụ nhu cầu học tập, nghiên cứu và làm việc hiệu quả
Nội dung trích xuất từ tài liệu:
Advanced Linux Programming: 4-Threads 4 ThreadsT HREADS, LIKE PROCESSES, ARE A MECHANISM TO ALLOW A PROGRAM to do more thanone thing at a time. As with processes, threads appear to run concurrently; the Linuxkernel schedules them asynchronously, interrupting each thread from time to time togive others a chance to execute. Conceptually, a thread exists within a process.Threads are a finer-grained unit ofexecution than processes.When you invoke a program, Linux creates a new processand in that process creates a single thread, which runs the program sequentially.Thatthread can create additional threads; all these threads run the same program in thesame process, but each thread may be executing a different part of the program at anygiven time. We’ve seen how a program can fork a child process.The child process is initiallyrunning its parent’s program, with its parent’s virtual memory, file descriptors, and soon copied.The child process can modify its memory, close file descriptors, and the likewithout affecting its parent, and vice versa.When a program creates another thread,though, nothing is copied.The creating and the created thread share the same memoryspace, file descriptors, and other system resources as the original. If one thread changesthe value of a variable, for instance, the other thread subsequently will see the modi-fied value. Similarly, if one thread closes a file descriptor, other threads may not read62 Chapter 4 Threads from or write to that file descriptor. Because a process and all its threads can be exe- cuting only one program at a time, if any thread inside a process calls one of the exec functions, all the other threads are ended (the new program may, of course, create new threads). GNU/Linux implements the POSIX standard thread API (known as pthreads). All thread functions and data types are declared in the header file .The pthread functions are not included in the standard C library. Instead, they are in libpthread, so you should add -lpthread to the command line when you link your program. 4.1 Thread Creation Each thread in a process is identified by a thread ID.When referring to thread IDs in C or C++ programs, use the type pthread_t. Upon creation, each thread executes a thread function.This is just an ordinary func- tion and contains the code that the thread should run.When the function returns, the thread exits. On GNU/Linux, thread functions take a single parameter, of type void*, and have a void* return type.The parameter is the thread argument: GNU/Linux passes the value along to the thread without looking at it.Your program can use this parame- ter to pass data to a new thread. Similarly, your program can use the return value to pass data from an exiting thread back to its creator. The pthread_create function creates a new thread.You provide it with the following: 1. A pointer to a pthread_t variable, in which the thread ID of the new thread is stored. 2. A pointer to a thread attribute object.This object controls details of how the thread interacts with the rest of the program. If you pass NULL as the thread attribute, a thread will be created with the default thread attributes.Thread attributes are discussed in Section 4.1.5, “Thread Attributes.” 3. A pointer to the thread function.This is an ordinary function pointer, of this type: void* (*) (void*) 4. A thread argument value of type void*. Whatever you pass is simply passed as the argument to the thread function when the thread begins executing. A call to pthread_create returns immediately, and the original thread continues exe- cuting the instructions following the call. Meanwhile, the new thread begins executing the thread function. Linux schedules both threads asynchronously, and your program must not rely on the relative order in which instructions are executed in the two threads. 4.1 Thread Creation 63 The program in Listing 4.1 creates a thread that prints x’s continuously to standarderror. After calling pthread_create, the main thread prints o’s continuously to standarderror. Listing 4.1 (thread-create.c) Create a Thread #include #include /* Prints x’s to stderr. The parameter is unused. Does not return. */ void* print_xs (void* unused) { while (1) fputc (‘x’, stderr); retu ...
Nội dung trích xuất từ tài liệu:
Advanced Linux Programming: 4-Threads 4 ThreadsT HREADS, LIKE PROCESSES, ARE A MECHANISM TO ALLOW A PROGRAM to do more thanone thing at a time. As with processes, threads appear to run concurrently; the Linuxkernel schedules them asynchronously, interrupting each thread from time to time togive others a chance to execute. Conceptually, a thread exists within a process.Threads are a finer-grained unit ofexecution than processes.When you invoke a program, Linux creates a new processand in that process creates a single thread, which runs the program sequentially.Thatthread can create additional threads; all these threads run the same program in thesame process, but each thread may be executing a different part of the program at anygiven time. We’ve seen how a program can fork a child process.The child process is initiallyrunning its parent’s program, with its parent’s virtual memory, file descriptors, and soon copied.The child process can modify its memory, close file descriptors, and the likewithout affecting its parent, and vice versa.When a program creates another thread,though, nothing is copied.The creating and the created thread share the same memoryspace, file descriptors, and other system resources as the original. If one thread changesthe value of a variable, for instance, the other thread subsequently will see the modi-fied value. Similarly, if one thread closes a file descriptor, other threads may not read62 Chapter 4 Threads from or write to that file descriptor. Because a process and all its threads can be exe- cuting only one program at a time, if any thread inside a process calls one of the exec functions, all the other threads are ended (the new program may, of course, create new threads). GNU/Linux implements the POSIX standard thread API (known as pthreads). All thread functions and data types are declared in the header file .The pthread functions are not included in the standard C library. Instead, they are in libpthread, so you should add -lpthread to the command line when you link your program. 4.1 Thread Creation Each thread in a process is identified by a thread ID.When referring to thread IDs in C or C++ programs, use the type pthread_t. Upon creation, each thread executes a thread function.This is just an ordinary func- tion and contains the code that the thread should run.When the function returns, the thread exits. On GNU/Linux, thread functions take a single parameter, of type void*, and have a void* return type.The parameter is the thread argument: GNU/Linux passes the value along to the thread without looking at it.Your program can use this parame- ter to pass data to a new thread. Similarly, your program can use the return value to pass data from an exiting thread back to its creator. The pthread_create function creates a new thread.You provide it with the following: 1. A pointer to a pthread_t variable, in which the thread ID of the new thread is stored. 2. A pointer to a thread attribute object.This object controls details of how the thread interacts with the rest of the program. If you pass NULL as the thread attribute, a thread will be created with the default thread attributes.Thread attributes are discussed in Section 4.1.5, “Thread Attributes.” 3. A pointer to the thread function.This is an ordinary function pointer, of this type: void* (*) (void*) 4. A thread argument value of type void*. Whatever you pass is simply passed as the argument to the thread function when the thread begins executing. A call to pthread_create returns immediately, and the original thread continues exe- cuting the instructions following the call. Meanwhile, the new thread begins executing the thread function. Linux schedules both threads asynchronously, and your program must not rely on the relative order in which instructions are executed in the two threads. 4.1 Thread Creation 63 The program in Listing 4.1 creates a thread that prints x’s continuously to standarderror. After calling pthread_create, the main thread prints o’s continuously to standarderror. Listing 4.1 (thread-create.c) Create a Thread #include #include /* Prints x’s to stderr. The parameter is unused. Does not return. */ void* print_xs (void* unused) { while (1) fputc (‘x’, stderr); retu ...
Tìm kiếm theo từ khóa liên quan:
công nghệ thông tin thủ thuật máy tính tin học quản trị mạng computer networkGợi ý tài liệu liên quan:
-
52 trang 429 1 0
-
24 trang 354 1 0
-
Top 10 mẹo 'đơn giản nhưng hữu ích' trong nhiếp ảnh
11 trang 312 0 0 -
Làm việc với Read Only Domain Controllers
20 trang 299 0 0 -
74 trang 295 0 0
-
96 trang 291 0 0
-
Báo cáo thực tập thực tế: Nghiên cứu và xây dựng website bằng Wordpress
24 trang 289 0 0 -
Đồ án tốt nghiệp: Xây dựng ứng dụng di động android quản lý khách hàng cắt tóc
81 trang 279 0 0 -
EBay - Internet và câu chuyện thần kỳ: Phần 1
143 trang 274 0 0 -
Tài liệu dạy học môn Tin học trong chương trình đào tạo trình độ cao đẳng
348 trang 269 1 0