免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: baohuaihuai
打印 上一主题 下一主题

新鲜出炉Google面试题一道(多线程) [复制链接]

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
41 [报告]
发表于 2007-10-26 21:27 |只看该作者
原帖由 wuxiangzhi 于 2007-10-26 21:23 发表


就是因为什么都没干哈,线程1,2,3,4有机会打架了。

我这里很多人用一台服务器,跑这个程序的时候,基本没有竞争


可否让每个线程执行一点任务,避免竞争?

论坛徽章:
0
42 [报告]
发表于 2007-10-26 21:53 |只看该作者
原帖由 wuxiangzhi 于 2007-10-26 20:30 发表

貌似不能往lseek形成的空洞里写东西的吧~~

你确定?

论坛徽章:
0
43 [报告]
发表于 2007-10-27 00:49 |只看该作者
lseek以后可以写~

论坛徽章:
0
44 [报告]
发表于 2007-10-27 10:49 |只看该作者
lseek形成的空洞是可以写的~~~~~

论坛徽章:
0
45 [报告]
发表于 2007-10-27 10:54 |只看该作者
验证了一下,还是那个仁兄的方法高明啊~~哈哈
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <pthread.h>
#include <errno.h>
#include <unistd.h>
#include <stdio.h>

char *file[] = {"./a","./b","./c","./d"};


void*thread_func(void*arg)
{
        int     num, fd[4], i;
        char    buf[4];

        num = *(int*)arg;
        free(arg);

        memset(buf, 0, sizeof(buf));
        sprintf(buf, "%d", num+1);

        for (i=0; i<4; i++) {
                fd[i] = open(file[i],O_WRONLY);
                lseek(fd, (num+(4-i))%4, SEEK_CUR);
                write(fd[i], (void*)buf, strlen(buf));
        }

        while (1) {
                for (i=0; i<4; i++) {
                        lseek(fd[i], 3, SEEK_CUR);
                        write(fd[i], (void*)buf, strlen(buf));
                }
        }

        pthread_exit(0);
}

int main()
{
        int i, *num, fd;

        for (i=0; i<4; i++) {
                fd = open(file[i], O_CREAT | O_WRONLY, S_IRUSR|S_IWUSR);
                close(fd);
        }

        for (i=0; i<4; i++) {
                num =(int*)malloc(sizeof(int));
                *num = i;
                pthread_create(NULL, NULL, thread_func, num);
        }

        pause();
}


[ 本帖最后由 wuxiangzhi 于 2007-10-27 11:05 编辑 ]

论坛徽章:
0
46 [报告]
发表于 2007-10-27 10:56 |只看该作者
用四个Buffer对应四个文件,然后四个线程按序写就行了,好像必须同步才行

论坛徽章:
0
47 [报告]
发表于 2007-10-27 11:25 |只看该作者
原帖由 wuxiangzhi 于 2007-10-27 10:54 发表
验证了一下,还是那个仁兄的方法高明啊~~哈哈
#include
#include
#include
#include
#include
#include
#include

char *file[] = {"./a","./b","./c","./d"};


void*thread_func(v ...


如wuxiangzhi 【18楼】所说一样,你可以view a 查看文件尾部,就会发现很多空洞未写

论坛徽章:
0
48 [报告]
发表于 2007-10-27 11:27 |只看该作者
原帖由 fertiland 于 2007-10-27 11:25 发表


如wuxiangzhi 【18楼】所说一样,你可以view a 查看文件尾部,就会发现很多空洞未写


虽然会有空洞,基本可以满足这个题目的需求了,至少前面大部分都是满足的。
要想没有空洞,只能加同步了,不管是同步写,还是同步计数

[ 本帖最后由 wuxiangzhi 于 2007-10-27 11:29 编辑 ]

论坛徽章:
0
49 [报告]
发表于 2007-10-27 11:33 |只看该作者
都是牛人啊。。小弟我这辈子是进还了google了。

论坛徽章:
0
50 [报告]
发表于 2007-10-27 11:51 |只看该作者

不用锁!最快速的办法。

每个文件的每个位置的字母都是可以计算的。
不过到可以安排每个线程各自先写一个文件。

线程1,
文件1,第1个字节写1;跳3字节,写1;跳3字节写1;……
文件2,第4个字节写1;跳3字节,写1;跳3字节写1;……
文件3,第3个字节写1;跳3字节,写1;跳3字节写1;……
文件4,第2个字节写1;跳3字节,写1;跳3字节写1;……

线程2,线程3,线程4,
略。

[ 本帖最后由 yuanchengjun 于 2007-10-27 11:55 编辑 ]

评分

参与人数 1可用积分 +1 收起 理由
shang2010 + 1

查看全部评分

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP