futex的使用_fuel开关

futex的使用_fuel开关futex_t::wake实际是一个计数器,防止在调用futex_wait函数前调用futex_wake而出现的死等现象,函数futex只在满足(*addr1==val)时等待。futex_wait函数与futex_wake函数配合使用,前者等待后者唤醒。futex_lock函数与futex_unlock函数配合使用,前者加锁后者解锁。应该是对数据加锁,而不应该对代码

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
futex_t::wake 实际是一个计数器,防止在调用futex_wait函数前调用futex_wake而出现的死等现象,

函数futex只在满足(*addr1 == val)时等待。

futex_wait函数与futex_wake函数配合使用,前者等待后者唤醒。

futex_lock函数与futex_unlock函数配合使用,前者加锁后者解锁。

应该是对数据加锁,而不应该对代码加锁。但这只是测试, 实际编程中不应如此使用。

编译使用如下命令:

g++ -g -W -Wall -Wextra -o mytest main.cpp -lpthread

执行:

./mytest

停止:

Ctrl-C

参考文献:

futex(2),futex(7),Linux内核文档,Linux内核源代码futex.c。

main.cpp:

// 2010年 07月 28日 星期三 13:01:43 CST

// author: 李小丹(Li Shao Dan) 字 殊恒(shuheng)

// K.I.S.S

// S.P.O.T

// linux-2.6.XX/Document/

// linux-2.6.xx/kernel/futex.c

#include <iostream>

#include <cstdlib>

#include <unistd.h>

#include <pthread.h>

#include <errno.h>

#include <linux/futex.h>

#include <sys/syscall.h>

using namespace std;

#define futex(addr1, op, val, rel, addr2, val3)    /

    syscall(SYS_futex, addr1, op, val, rel, addr2, val3)

struct futex_t {

    int wake;

    int lock;

    int wlock;

};

inline static void futex_init(futex_t *);

inline static int futex_wake(futex_t *);

inline static int futex_wait(futex_t *);

inline static int futex_lock(futex_t *);

inline static int futex_unlock(futex_t *);

static void *work_thread(void *);

static void *work_send(void *);

static int count = 0;

int main()

{

    struct futex_t ftx;

    pthread_t tid[6];

    futex_init(&ftx);

    pthread_create(&tid[3], 0, work_send, (void *)&ftx);

    pthread_create(&tid[1], 0, work_thread, (void *)&ftx);

    pthread_create(&tid[2], 0, work_thread, (void *)&ftx);

    pthread_create(&tid[5], 0, work_send, (void *)&ftx);

    pthread_create(&tid[0], 0, work_thread, (void *)&ftx);

    pthread_create(&tid[4], 0, work_send, (void *)&ftx);

    for(int i = 0; i < 6; ++i)

        pthread_join(tid[i], 0);

    return 0;

}

void *work_thread(void *p)

{

    struct futex_t *ftx = (struct futex_t *)p;

    //sleep(2);

    for(;;) {

        futex_wait(ftx);

        futex_lock(ftx);

        cout << pthread_self() << endl;

        cout << “Hello,world!/n”;

        cout << count++ << endl;

        cout << “******************************/n”;

        futex_unlock(ftx);

    }

    return (void *)0;

}

void *work_send(void *p)

{

    futex_t *ftx = (struct futex_t *)p;

    for(int i = 0; i < 3000; ++i)

        futex_wake(ftx);

    return (void *)0;

}

inline static void futex_init(futex_t *ftx)

{

    ftx->lock = 0;

    ftx->wake = 0;

    ftx->wlock = 0;

}

inline static int futex_wake(futex_t *ftx)

{

    __sync_fetch_and_add(&ftx->wake, 1);

    //__sync_lock_test_and_set(&ftx->wake, 1);

    return futex(&ftx->wake, FUTEX_WAKE, 1, 0, 0, 0);

}

inline static int futex_wait(futex_t *ftx)

{

    futex(&ftx->wlock, FUTEX_LOCK_PI, 0, 0, 0, 0);

    int ret = futex(&ftx->wake, FUTEX_WAIT, 0, 0, 0, 0);

    __sync_fetch_and_sub(&ftx->wake, 1);

    futex(&ftx->wlock, FUTEX_UNLOCK_PI, 0, 0, 0, 0);

    return (ret && errno == EWOULDBLOCK ? 1 : ret);

}

inline static int futex_lock(futex_t *ftx)

{

    return futex(&ftx->lock, FUTEX_LOCK_PI, 0, 0, 0, 0);

}

inline static int futex_unlock(futex_t *ftx)

{

    return futex(&ftx->lock, FUTEX_UNLOCK_PI, 0, 0, 0, 0);

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/191141.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • QueueUserWorkItem 初步学习

    QueueUserWorkItem 初步学习 DWORDWINAPITestThreadPool(PVOIDpContext);CRITICAL_SECTIONg_cs;int_tmain(intargc,_TCHAR*argv[]){ InitializeCriticalSection(&g_cs); SECURITY_ATTRIBUTESsa; sa.bInheritHandle=TRUE; sa.nLen

    2025年11月30日
    4
  • c语言大数求和_指数幂的加法

    c语言大数求和_指数幂的加法文章目录1.大数加法2.大数幂运算3.大数求余废话不多说,直接上代码了。1.大数加法stringgetCountAdd(stringa,stringb){ stringc=””; intbit=-1;//判断是否进位-1为否,其他为进位数 inti=a.length()-1;//获得a字符串长度 intj=b.length()-1;//获得b字符串长度 //第一种情况两者都处理完 while(i!=-1&&j!

    2022年10月6日
    2
  • 僵死进程及exec

    僵死进程及exec一.僵死进程僵死进程及处理方法(1)僵死进程概念:子进程先于父进程结束,父进程没有调用wait获取子进程退出码。(2)如何处理僵死进程:父进程通过调用wait()完成。(3)Init进

    2022年7月1日
    25
  • js也能写3D游戏?

    js也能写3D游戏?看完这本书《3DGameProgramingforKids》之后,发现3D游戏的学习,也可以使用javascript来写的。先要上这个网站https://threejs.org,然后下载它的three.js源码放到一个目录,比如js。然后放入这段代码: Myfirstthree.jsapp body{margin:0;} canvas{w

    2022年5月26日
    122
  • Dijkstra算法和Floyed算法「建议收藏」

    Dijkstra算法和Floyed算法「建议收藏」Dijkstra算法和Floyed算法最短路径:在非网图中,最短路径是指两顶点之间经历的边数最少的路径。在网图中,最短路径是指两顶点之间经历的边上权值之和最短的路径。最短路径问题:单源点到其他顶点的最短路径:Dijkstra方法,O(n2)按路径长度递增任意一对顶点之间的最短路径:Floyed方法,O(n3)Dijkstra算法:按路径长度递增1.设置一个集合S存放已经找到最短…

    2022年6月16日
    27
  • url转码 java_javaurlencode转码

    url转码 java_javaurlencode转码什么是URL转码不管是以何种方式传递url时,如果要传递的url中包含特殊字符,如想要传递一个+,但是这个+会被url会被编码成空格,想要传递&,被url处理成分隔符。尤其是当传递的url是经过Base64加密或者RSA加密后的,存在特殊字符时,这里的特殊字符一旦被url处理,就不是原先你加密的结果了。url特殊符号及对应的编码: 符号 url中的含义 编码 + URL中+号表示..

    2025年7月10日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号