发布时间:2015-04-16 20:44:32
一、什么是线程在一个程序中的多个执行路线就叫做线程(thread)。更准确的定义是:线程是一个进程内部的一个控制序列。事实上,所有的进程都至少有一个执行线程。创建新进程的fork系统调用与创建新线程的区别:当进程执行fork调用时, 将创建出该进程的一份新副本。 这个新进程拥有自己的变量和自己的PID, 它的时间调度也是独立的, 它的执行(通常)几乎是完全独立于父进程。当在进程中创建一个新线程时, 新的线程拥有自己的栈, 因此也有自己的局部......【阅读全文】
发布时间:2015-04-16 20:44:24
一、线程同步线程同步的两种基本方法:A. 信号量 它的作用如同看守一段代码的看门人。 控制一组相同对象的访问时, 比如从5条可用的电话线中分配一条给某个线程的情况, 就更适合计算信号量。 最简单的信号量--二进制信号量,它只有0和1两种取值; 更通用的信号量--计数信号量,它有更大的取值范围。B. 互斥量 它的作用如同保护代码段的一个互斥设备。 如果想控制任一时刻只能有一个线程可......【阅读全文】
发布时间:2015-04-16 20:44:13
用互斥量实现的线程安全循环队列。只是一个示例实现,不大能用于实际编程。因为当真正多线程时,会因为资源竞争而等待,导致队列的效率极低。更有效的方式是使用信号量。更多的不说了,直接看代码吧。cir_queue.h/* * \File * cir_queue.h * \Brief * circular queue */#ifndef __CIR_QUEUE_H__#define __CIR_QUEUE_H__#define QUE_SIZE 8typedef int DataType;typedef struct cir_queue_t{&n......【阅读全文】
发布时间:2015-04-16 20:44:04
用信号量实现的线程安全队列。简单有用的示例程序,比起互斥量的实现在多线程时效率更好。cir_queue.h/* * \File * cir_queue.h * \Brief * circular queue */#ifndef __CIR_QUEUE_H__#define __CIR_QUEUE_H__#define QUE_SIZE 8typedef int DataType;typedef struct cir_queue_t{ DataType data[QUE_SIZE]; int f......【阅读全文】