`

记录锁

 
阅读更多
#include <errno.h>
#include <fcntl.h>
#include <unistd.h>
#include <iostream>
#include <sys/wait.h>
#include <stdlib.h>
using namespace std;

/*
    lockType:F_RDLCK,F_WRLCK,F_UNLCK
*/
int controlFile(int fd,int lockType)
{
    struct flock fileLock;
    fileLock.l_type = lockType;
    fileLock.l_start = 0;
    fileLock.l_whence = SEEK_SET;
    fileLock.l_len = 0;
    return fcntl(fd,F_SETLK,&fileLock);
}

int main()
{
    pid_t pid;

    if((pid=fork())<0)
    {
        return -1;
    }else if(pid==0){
        sleep(3);
        int fd = open("test.txt",O_RDWR | O_CREAT  | O_APPEND);
        int ret = controlFile(fd,F_WRLCK);
        //加锁失败也是可以写的,所以这里需要程序员在加锁的时候去判定是否有别的进程在锁定文件
        if(ret<0){
            cout << "child lock file fail" << endl;
        }else{
            write(fd,"test0",5);
            controlFile(fd,F_UNLCK);
        }
        close(fd);
        exit(0);
    }else
    {
        int fd = open("test.txt",O_RDWR | O_CREAT  | O_APPEND);
        int ret = controlFile(fd,F_WRLCK);
        if(ret<0){
            cout << "parent lock file fail" << endl;
        }else{
            write(fd,"test1",5);
            sleep(10);
            controlFile(fd,F_UNLCK);
        }
        close(fd);
    }
    return 0;
}


child lock file fail
分享到:
评论

相关推荐

    linux文件和记录锁[借鉴].pdf

    在Linux系统中,文件和记录锁是用于管理多个进程对同一文件访问的重要机制,确保数据的一致性和完整性。这两种锁定方式允许程序控制对文件的并发访问,防止数据冲突。 首先,我们要理解文件锁(File Locks)和记录...

    公平锁&非公平锁.pdf

    AQS 中有一个 state 变量,用于记录锁的状态,state 的初值为 0,表示锁未被占用。当某个线程请求锁时,如果锁未被占用,则将 state 设置为 1,表示锁被占用。如果锁已经被占用,则线程将被加入等待队列中。 在 ...

    InnoDB的七种锁

    在这个案例中,**事务A**执行插入操作时,会获取到针对ID为11的**记录锁**(Record Lock),这是一个**排他锁**。因为事务A尚未提交,**事务B**尝试插入ID为12的行时,不会与事务A发生冲突,因此不会被阻塞。这体现...

    MYSQL锁机制全揭秘

    InnoDB的行级锁类型包括记录锁、间隙锁和临键锁等,主要用来减少锁争用,提高并发性。InnoDB支持多版本并发控制(MVCC),可以实现非阻塞的读操作。 在解决MySQL锁问题时,需要注意选择合适的事务隔离级别,因为...

    网维大师挂机锁网维大师挂机锁网维大师挂机锁

    6. **日志记录**:挂机锁还会记录解锁和锁定的时间以及解锁者的信息,便于监控和审计,有助于追踪潜在的安全风险。 挂机锁的应用不仅限于个人工作环境,也广泛适用于公共工作区和数据中心。在这些环境中,网络设备...

    MySQL锁的详细介绍

    * Next-key Lock 锁:记录锁和间隙锁组合,同时锁住数据,并且锁住数据前后范围。 三、悲观锁 悲观锁(Pessimistic Locking)是指在数据处理过程,将数据处于锁定状态,一般使用数据库的锁机制实现。 在 MySQL 中...

    广联达仿真锁写锁工具(深思4).rar

    5. 日志记录:记录锁的操作历史,便于追踪和排查问题。 6. 用户权限管理:根据角色和任务分配不同的访问和操作权限。 总的来说,广联达仿真锁写锁工具(深思4)是为了解决建筑行业项目中的协同工作难题,通过高效的...

    使用家庭挂机锁

    5. **日志记录**:一些高级的挂机锁软件会记录解锁尝试,包括成功和失败的记录,以便用户追踪可能的侵入尝试。 6. **远程控制**:部分挂机锁还支持远程解锁功能,用户可以通过手机等移动设备远程解除电脑锁定,方便...

    锁机源码123

    7. **安全日志**:记录锁机、解锁事件,便于审计和追踪。 8. **多平台兼容性**:如果源码适用于不同操作系统,需要考虑跨平台的实现,如使用C++或Java等跨平台语言。 【标签】"锁机"进一步强调了该源码的核心功能...

    MySQL的锁机制解析

    - **记录锁(Record Locks)**:只锁定特定的行。 - **间隙锁(Gap Locks)**:不锁定具体记录,而是锁定索引之间的间隙,防止其他事务插入记录。 3. **锁定模式与事务隔离级别**: - **读未提交(READ ...

    结锁加锁工具收集大家试试

    5. **日志记录**:记录锁的获取和释放过程,便于事后分析问题。 在使用这些工具时,开发者应根据实际需求选择合适的锁类型和工具,并遵循最佳实践,如尽量减少锁的粒度,避免全局锁,以及使用短生命周期的锁等。...

    安卓锁机软件

    8. **日志记录**:为了帮助用户追踪和分析安全事件,可以实现日志记录功能,记录解锁尝试和成功解锁的时间戳。 9. **测试和优化**:在开发过程中,对软件进行全面的测试,包括兼容性测试(在不同设备和Android版本...

    MySQL十种锁,一篇文章带你全解析.doc

    按照锁定的粒度,锁可以分为表锁、页面锁、行锁、记录锁、间隙锁和临键锁。根据锁的属性,可以分为共享锁(读锁,S锁)和排他锁(写锁,X锁)。此外,还有根据加锁机制划分的乐观锁和悲观锁。 1. 表锁:在MyISAM和...

    如何正确选择适合酒店使用的电子门锁

    此外,考虑门锁的酒店管理功能,如记录开锁信息,有助于提升管理效率和安全保障。 总的来说,酒店在选择电子门锁时,要从多个维度进行深入分析,确保所选门锁能够适应酒店的特定需求,既能保障安全,又能提升服务...

    Redis高可用的分布式锁

    同时,为了监控和调试,还可以记录锁的获取和释放日志,以便分析锁的使用情况。 总结来说,通过SpringBoot的AOP和Redis的特性,我们可以构建出高可用的分布式锁,实现并发控制,保证分布式环境下的数据一致性。同时...

    电脑屏幕锁

    9. **日志记录**:有些高级的屏幕锁程序会记录解锁尝试,以便用户了解是否有未授权的解锁尝试。 10. **更新与支持**:软件开发者应定期更新程序,修复可能的安全漏洞,并提供技术支持,以确保用户始终享有最新的...

    物联网智慧锁服务系统商业计划书.doc

    物联网智慧锁服务系统商业计划书是智慧锁科技有限公司制定的商业计划书,旨在推广物联网智慧锁服务系统,提供智慧锁服务、记录锁服务、RFID 锁、蓝牙锁、ZigBee 锁服务等四大类服务。该计划书详细介绍了物联网智慧锁...

Global site tag (gtag.js) - Google Analytics