1,临界区
临界区(Critical Section)是一段独占对某些共享资源访问的代码,在任意时刻只允许一个线程对共享资源进行访问。如果有多个线程试图同时访问临界区,那么在有一个线 程进入后其他所有试图访问此临界区的线程将被挂起,并一直持续到进入临界区的线程离开。临界区在被释放后,其他线程可以继续抢占,并以此达到用原子方式操 作共享资源的目的。
临界区在使用时以CRITICAL_SECTION结构对象保护共享资源,并分别用EnterCriticalSection()和 LeaveCriticalSection()函数去标识和释放一个临界区。所用到的CRITICAL_SECTION结构对象必须经过 InitializeCriticalSection()的初始化后才能使用,而且必须确保所有线程中的任何试图访问此共享资源的代码都处在此临界区的保 护之下。否则临界区将不会起到应有的作用,共享资源依然有被破坏的可能。
2,
联合:为了在单块存储区保存不同类型的数据。联合只能用第一个成员类型的值进行初始化。
3,stable的排序方法:
快速排序是不稳定的,冒泡排序是稳定的,shell排序
是不稳定的,归并排序是稳定的,插入排序是稳定的
临界区(Critical Section)是一段独占对某些共享资源访问的代码,在任意时刻只允许一个线程对共享资源进行访问。如果有多个线程试图同时访问临界区,那么在有一个线 程进入后其他所有试图访问此临界区的线程将被挂起,并一直持续到进入临界区的线程离开。临界区在被释放后,其他线程可以继续抢占,并以此达到用原子方式操 作共享资源的目的。
临界区在使用时以CRITICAL_SECTION结构对象保护共享资源,并分别用EnterCriticalSection()和 LeaveCriticalSection()函数去标识和释放一个临界区。所用到的CRITICAL_SECTION结构对象必须经过 InitializeCriticalSection()的初始化后才能使用,而且必须确保所有线程中的任何试图访问此共享资源的代码都处在此临界区的保 护之下。否则临界区将不会起到应有的作用,共享资源依然有被破坏的可能。
2,
联合:为了在单块存储区保存不同类型的数据。联合只能用第一个成员类型的值进行初始化。
3,stable的排序方法:
快速排序是不稳定的,冒泡排序是稳定的,shell排序
是不稳定的,归并排序是稳定的,插入排序是稳定的
本文介绍了临界区的概念及其实现方式,用于确保多线程环境下共享资源的安全访问。此外,还对比了多种排序算法的稳定性,帮助理解不同算法在实际应用中的表现。
37万+

被折叠的 条评论
为什么被折叠?



