我的任务是用 C 语言编写一个加密程序。
有一个源文件和一个目标文件。我的程序 需要从源文件中读取内容,对其进行加密并 将加密内容写入目标文件。
我的程序中有 7 个线程。
三个线程一行一行读取源文件并放入文件内容 进入共享缓冲区 1,线程从共享缓冲区 1 读取内容,对其进行加密 并放入共享缓冲区2,另外三个线程读取加密内容 从共享缓冲区2中将其写入目标文件。
我的想法是创建两个 mutices 以确保只有一个线程可以读取 源文件或同时写入目标文件。我的问题是如何控制多个线程对共享缓冲区 1、共享缓冲区 2 的访问。我知道它像生产者/消费者问题一样退出,但更复杂。有人可以给我建议吗?提前致谢。
最佳答案
在 boost 示例中,您有一个关于互斥锁、共享内存和多线程通信的非常好的示例,here 。
此示例使用共享内存来存储来自一个线程的消息,而另一个线程读取这些消息,从而阻止共享内存进行并发访问。您可以申请您的主题。
关于c - 线程同步,谁能给我算法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7749637/