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号
浙公网安备 33010602011771号