再来一道多线程的题目网传的GOOGLE面试题,看了一些其他人的实现,有的因为编程语言原因看不懂有的貌似不能完成任务,下面给出我的在linux下的C实现。
题目:有四个线程1、2、3、4。线程1的功能就是输出1,线程2的功能就是输出2,以此类推.........现在有四个文件ABCD。初始都为空。现要让四个文件呈如下格式:
题目:有四个线程1、2、3、4。线程1的功能就是输出1,线程2的功能就是输出2,以此类推.........现在有四个文件ABCD。初始都为空。现要让四个文件呈如下格式:
A:1 2 3 4 1 2....
B:2 3 4 1 2 3....
C:3 4 1 2 3 4....D:4 1 2 3 4 1....
太习惯从0开始,所以线程的编号也从0开始编。不过在输出的时候做了+1操作。线程启动之后,线程0首先写文件0,然后线程1写文件0,1,接着线程2写文件0,1,2,线程3写文件0,1,2,3。之后就顺畅的运行起来了,线程0依次写这4个文件。
文件状态大致变化,每一横排为一个文件:
1 => 12 => 123 => 1234 => 12341
2 23 234 2341
3 34 341
4 41
这个图注意是记录下思路,其实线程1写文件1的时候,线程2已经在写文件0了。太紧密不好表示。
/*
* ==============