zoukankan      html  css  js  c++  java
  • mq_unlink

    NAME

    mq_unlink - 销毁一个消息队列 (REALTIME)

    SYNOPSIS

    #include <mqueue.h>

    int mq_unlink(const char *name);

    DESCRIPTION

    函数 mq_unlink() 会从内核中删除名为name的消息队列.

    如果该函数被调用了,但是仍然有进程已经打开了这个消息队列,那么这个消息队列的销毁会被推迟到所有的引用都被关闭时执行.

    并且函数 mq_unlink() 不需要阻塞到所有的引用都被关闭为止,它会立即返回.

    函数 mq_unlink()调用成功后, 如果在随后调用 mq_open() 时重用这个消息队列名字,效果就像这个名字的消息队列不存在,

    如果没有设置O_CREAT标志,函数mq_open() 会返回失败,否则会创建一个新的消息队列.

    PARAMETERS

    name

    参数 name 是一个指向消息队列名字的指针.

    名字的形式是 "/somename",是一个以NULL结尾的字符串,字符串的最大长度为NAME_MAX。

    消息队列名字的第一个字符必须是"/",并且之后的字符中不允许出现"/"

      

    RETURN VALUE

    如果函数执行成功, 函数返回0

    如果函数执行失败,函数返回 -1 并且设置errno,errno的种别详见下面的ERRORS一节.

    ERRORS

    [EACCES]

    没有权限删除指定的消息队列.

    [ENOENT]

    指定的消息队列不存在.

    [ENAMETOOLONG]

    参数 name 的长度超过系统定义的最大长度.

    在不支持XSI系统中,name 的长度超过了 {_POSIX_PATH_MAX},在支持XSI系统中,name 的长度超过了 {_XOPEN_PATH_MAX};或者

    在不支持XSI系统中,某一级路径的长度超过了 {_POSIX_NAME_MAX},在支持XSI系统中,某一级路径的长度超过了 {_XOPEN_NAME_MAX};

    EXAMPLES

  • 相关阅读:
    golang 数据结构 优先队列(堆)
    leetcode刷题笔记5210题 球会落何处
    leetcode刷题笔记5638题 吃苹果的最大数目
    leetcode刷题笔记5637题 判断字符串的两半是否相似
    剑指 Offer 28. 对称的二叉树
    剑指 Offer 27. 二叉树的镜像
    剑指 Offer 26. 树的子结构
    剑指 Offer 25. 合并两个排序的链表
    剑指 Offer 24. 反转链表
    剑指 Offer 22. 链表中倒数第k个节点
  • 原文地址:https://www.cnblogs.com/LubinLew/p/POSIX-mq_unlink.html
Copyright © 2011-2022 走看看