Синхронизация


Основные сложности возникают тогда, когда потокам нужно совместно использовать одни и те же данные. Так как несколько потоков могут одновременно обращаться и записывать данные в одну область, то это может привести к нежелательным последствиям. Представьте себе такую ситуацию: один поток занимается вычислениями, используя значения какой-нибудь глобальной переменной, а в это время другой поток вдруг изменяет значение этой переменной, но поток, занимающийся вычислениями, продолжает свою работу, ничего не подозревая и используя уже измененное значение. Для предотвращения подобных ситуаций требуется механизм, позволяющий блокировать данные, когда один из потоков намеревается их изменить. Этот механизм получил название синхронизация.

Синхронизация позволяет задавать критические секции (critical sections), к которым в определенный момент имеет доступ только один из потоков. Это гарантирует то, что данные ресурса, контролируемые критической секцией, будут невидимы другими потоками и они не изменят их. И только после того, как поток выполнит всю необходимую работу, он освобождает ресурс, и, затем, доступ к этому ресурсу может получить любой другой поток. Например, если один поток записывает информацию в файл, то все другие не смогут использовать этот файл до тех пор, пока поток не освободит его.

Читать далее: QMutex - мьютексы в Qt