Đang chuẩn bị nút TẢI XUỐNG, xin hãy chờ
Tải xuống
Các công đoàn của hai tập hợp A và B là một tập hợp có chứa tất cả các yếu tố có trong A cùng với tất cả các yếu tố có trong B. Giao điểm của A và B là tập hợp chứa các yếu tố có trong cả A và B. sự khác biệt của A và B là tập hợp chứa tất cả các yếu tố của A trừ những yếu tố cũng được B. | CHAPTER 12. THREADS AND MULTIPROCESSING 595 definition of an instance method is pretty much equivalent to putting the body of the method in a synchronized statement of the form synchronized this . . It is also possible to have synchronized static methods a synchronized static method is synchronized on the special class object that represents the class containing the static method. The real rule of synchronization in Java is this Two threads cannot be synchronized on the same object at the same time that is they cannot simultaneously be executing code segments that are synchronized on that object. If one thread is synchronized on an object and a second thread tries to synchronize on the same object the second thread is forced to wait until the first thread has finished with the object. This is implemented using something called a synchronization lock. Every object has a synchronization lock and that lock can be held by only one thread at a time. To enter a synchronized statement or synchronized method a thread must obtain the associated object s lock. If the lock is available then the thread obtains the lock and immediately begins executing the synchronized code. It releases the lock after it finishes executing the synchronized code. If Thread A tries to obtain a lock that is already held by Thread B then Thread A has to wait until Thread B releases the lock. In fact Thread A will go to sleep and will not be awoken until the lock becomes available. As a simple example of shared resources we return to the prime-counting problem. In this case instead of having every thread perform exactly the same task we ll so some real parallel processing. The program will count the prime numbers in a given range of integers and it will do so by dividing the work up among several threads. Each thread will be assigned a part of the full range of integers and it will count the primes in its assigned part. At the end of its computation the thread has to add its count to the overall .