d的线安举例.
典型排序构造:
struct ThreadsafeQueue(T)
{
void QueueItem(T*) shared;
T* UnqueueItem() shared;
}//两个共享
struct SpecialWorkList
{
struct Job { ... }
void MakeJob(int x, float y, string z) shared // 可造工作线程
{
Job* job = new Job; // 线本
PopulateJob(job, x, y, z); // 准备工作可能复杂,值得实现`SpecialWorkList`
jobList.QueueItem(job); //包装项,不必丢弃共享
}
void Flush() // 非共享,线本消费者
{
Job* job;
while (job = jobList.UnqueueItem())
{//即使实现是线安,线本调用该函数也是线安的
// 线本分发,渲染,延时析构,延时创建资源,
// 等等.
}
}
void GetSpecialSystemState() //与SpecialWorkList的线安部分无关
{
return os.functionThatChecksSystemState();
}
...// 不同`jobList`打交道的工具函数
private:
void PopulateJob(ref Job job, ...)
{
// 贵函数,非线安,不与线程交流
}
ThreadsafeQueue!Job jobList;
}
该例不神奇,但是是典型线本,小部分为线安,Flush()线本函数内部处理线安.因为刷新为线安队列.
线安由工具对象组成,不需要加锁/神奇/转换等.
浙公网安备 33010602011771号