当前位置: 首页 > news >正文

企业形象设计学什么seo网站推广方案

企业形象设计学什么,seo网站推广方案,贵阳软件制作,网站建设需要学习什么为了解决多个进程同时操作一个文件,产生一些情况,通常对文件进行上锁,已解决对共享文件的竞争 对打开文件进行各种操作: int fcentl(int fd, int cmd, .../*arg*/如果cmd与锁操作有关,那么fcentl函数的第三个参数就要…

为了解决多个进程同时操作一个文件,产生一些情况,通常对文件进行上锁,已解决对共享文件的竞争

对打开文件进行各种操作:

int fcentl(int fd, int cmd, .../*arg*/

如果cmd与锁操作有关,那么fcentl函数的第三个参数就要传入一个结构体

在这里插入图片描述
在这里插入图片描述
其中结构体如下:

 struct flock {...short l_type;    /* Type of lock: F_RDLCK,F_WRLCK, F_UNLCK */short l_whence;  /* How to interpret l_start:SEEK_SET, SEEK_CUR, SEEK_END */off_t l_start;   /* Starting offset for lock */off_t l_len;     /* Number of bytes to lock */pid_t l_pid;     /* PID of process blocking our lock(F_GETLK only) */...};

在这里插入图片描述
在这里插入图片描述

利用fcntl函数解决两个终端同时写访问一个文件产生的竞争问题:

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/file.h> int lock_set(int fd, int type){struct flock old_lock, lock;lock.l_whence = SEEK_SET; //加锁区域为文件开始处 lock.l_start = 0;//加锁区域在文件位置的相对偏移量 lock.l_len = 0;//加锁区域长度 lock.l_type = type;//锁的类型 lock.l_pid = -1;fcntl(fd, F_GETLK, &lock);//写入if(lock.l_type != F_UNLCK){//若未解锁 if(lock.l_type == F_RDLCK){//读取锁 printf("Read lock already set by %d\n", lock.l_pid);}else if(lock.l_type == F_WRLCK){printf("Write lock already set by %d\n", lock.l_pid);} } /*上述可能由于不是解锁状态l_type被设置成了相应的锁值下方进行上锁操作时要再次调用type*/ lock.l_type = type;if((fcntl(fd, F_SETLKW, &lock)) < 0){//上锁失败 printf("Lock failed:type  = %d\n", lock.l_type);return -1;}switch(lock.l_type){case F_RELCK:printf("Read lock set by %d\n", getpid());//获取当前进程的IDbreak;case F_WRLCK:printf("Write lock set by %d\n", getpid());break;case F_UNLCK:printf("Release lock by %d\n", getpid());//解锁返回1 return 1;break; }return 0;//上锁返回0 
}int main(int argc, const char * argv[]){int fd;if((fd = open("test.txt", O_RDWR)) < 0){printf("open error\n");return -1;}lock_set(fd, F_WRLCK);//设置写入锁getchar();//等待响应 lock_set(fd, F_UNLCK);//解锁getchar();close(fd);return 0; 
}

为了更好演示,将写访问改成读访问,读访问可以多进程同时进行:

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/file.h> int lock_set(int fd, int type){struct flock old_lock, lock;lock.l_whence = SEEK_SET; //加锁区域为文件开始处 lock.l_start = 0;//加锁区域在文件位置的相对偏移量 lock.l_len = 0;//加锁区域长度 lock.l_type = type;//锁的类型 lock.l_pid = -1;fcntl(fd, F_GETLK, &lock);//写入if(lock.l_type != F_UNLCK){//若未解锁 if(lock.l_type == F_RDLCK){//读取锁 printf("Read lock already set by %d\n", lock.l_pid);}else if(lock.l_type == F_WRLCK){printf("Write lock already set by %d\n", lock.l_pid);} } /*上述可能由于不是解锁状态l_type被设置成了相应的锁值下方进行上锁操作时要再次调用type*/ lock.l_type = type;if((fcntl(fd, F_SETLKW, &lock)) < 0){//上锁失败 printf("Lock failed:type  = %d\n", lock.l_type);return -1;}switch(lock.l_type){case F_RELCK:printf("Read lock set by %d\n", getpid());//获取当前进程的IDbreak;case F_WRLCK:printf("Write lock set by %d\n", getpid());break;case F_UNLCK:printf("Release lock by %d\n", getpid());//解锁返回1 return 1;break; }return 0;//上锁返回0 
}int main(int argc, const char * argv[]){int fd;if((fd = open("test.txt", O_RDWR)) < 0){printf("open error\n");return -1;}lock_set(fd, F_WRLCK);//设置写入锁getchar();//等待响应 lock_set(fd, F_RDLCK);//解锁getchar();close(fd);return 0; 
}

效果:两进程一起访问
在这里插入图片描述

c语言strlen与sizeof函数的区别:

char a[32]
a[32] = "abcd";
strlen(a) = 4;
sizeof(a) = 32;
http://www.dinnco.com/news/56973.html

相关文章:

  • 商城网站设计需要哪些技术新手运营从哪开始学
  • 黄金做空网站天津关键词排名推广
  • 网站建设项目设计表线上营销推广的公司
  • 手机网站优化seo系统优化
  • 做酒的网站名字大全爱站网长尾关键词
  • wordpress做视频播放网站com天堂网
  • 莱芜网站优化招聘网地推扫码平台
  • 搭建网站有什么用全自动引流推广软件app
  • 临朐网站制作网站软件下载
  • 做的非常好的网站案例自己怎么做网站优化
  • 分类目录网站有哪些天津seo排名费用
  • 网站建设启示福州短视频seo网红
  • 东莞网站建设怎么样免费网络推广公司
  • 深圳网站制作必推祥奔科技百度电脑网页版入口
  • 石家庄城乡建设网站设计公司排名
  • 做外贸网站要注意什么开发网站用什么软件
  • google网站郑州seo网站有优化
  • 做国际贸易做什么网站商业软文代写
  • 昆明市城建设档案馆网站免费大数据平台
  • 做家电维修网站能接到单吗制作网站公司
  • 免费二级域名大全推广排名seo
  • wordpress密码进入网站做抖音seo排名软件是否合法
  • wordpress 多站点 固定链接国外网站
  • 遵义市营商环境建设局网站成都关键词快速排名
  • 网站开发商业机密推广下载
  • 上海网站建设公司怎么分辨好坏seo优化师培训
  • 大赛网站开发需求自媒体seo是什么意思
  • 赚钱网站入口河南seo网站多少钱
  • wordpress表情评论插件seo经典案例分析
  • 山东省网站备案太原做网络推广的公司