【elfboard linux开发板】4. 文件点灯与创建多进程

ps:提升效率的小tips:

灵活运用vim操作命令,gg快速跳转到文件开头,G跳转到结尾

多行操作

ctrl + V

shift + i

插入修改内容

esc退出编辑

sudo vi /etc/vim/vimrc

在文件中添加如下内容省略重复工作:

bash 复制代码
autocmd BufNewFile *.c,*.cpp,*.h,*.sh,*.java exec ":call SetTitle()"
func SetTitle()
	if &filetype == 'c'
		call setline(1,"#include <unistd.h>")
		call append(line("."),"    ")
		call append(line(".")+1,"int main(int args,char*argv[])")
		call append(line(".")+2,"{")
		call append(line(".")+3,"    ")
		call append(line(".")+4,"}")
	endif
endfunction

1.文件

以下命令都可以在vim编辑器里,通过在命令模式下2K跳转查询;也可以在终端中man 2 命令查询

a. int open( const char *pathname, int flags,[mode_t mode])
返回值 :成功返回文件描述符,失败返回-1
flags参数 可以填写: O_RDONLY, O_WRONLY, O_RDWR分别表示只读、只写、可读可写, O_CREAT 没有就创建该文件
mode参数 与flags参数有关,如果flags参数为O_CREAT, 该参数为新建文件的权限值,一般用8进制位传入,方便阅读;且与外部umask掩码有关,权限为mode-umask

需要包含下面头文件

#include <fcntl.h>

#include <sys/stat.h>

b. ssize_t read(int fd, void *buf, size_t count)
返回值:成功返回读取的字符长度,0说明读到了文件的结尾,失败返回-1,并且设置errno

errno 函数头文件 #include <errno.h>

输出错误信息:perror("error is ")

fd : 文件描述符

读取count个字符放到buf中

c. int close(int fd)

返回值:成功返回0,失败返回-1,并设置errno

关闭文件

c 复制代码
/*
读文件 输出到终端
*/
#include<stdio.h>
#include <errno.h>
#include <sys/stat.h>
#include <unistd.h>
#include <fcntl.h>

int main(int args,char* argv[]){
	int fd = open(argv[1], O_RDONLR);
	if(fd==-1){
		perror("open error");
		exit(1);
	}
	int len;
	char buf[1024];
	while((len=read(fd,buf,sizeof(buf)))!=0){
		if(len==-1){
			perror("read error");
			exit(1);
		}
		for(int i=0;i<len;i++){
			printf("%c",buf[i]);
		}
		printf("\n");
	}
	close(fd);
	return 0;
}

d. ssize_t write(int fd, const void *buf, size_t count)

作用:向文件描述符fd指向的文件,写入count个buf其实地址开始的字符;
返回值:成功返回写入成功的字节数,错误返回-1,且设置errno

e. off_t lseek(int fd, off_t offset, int whence)

作用:将光标移到whence位置

offset: 偏移位置

whence常用参数:

SEEK_SET: 移动到设置的offset位置

SEEK_CUR: 移动到现在光标+offset位置

SEEK_END:移到到文件末尾+offset位置

f. dup2(int oldfd, int newfd)

作用:用newfd指向oldfd文件描述符

c 复制代码
/*
文件名:file_write_arm.c
作用:写文件与显示写入内容
author: LiuGuoyong
date:2023/12/27
*/
#include<stdio.h>
#include <errno.h>
#include <sys/stat.h>
#include <unistd.h>
#include <fcntl.h>

int main(int args,char* argv[]){
	int fd = open(argv[1], O_WRONLY|O_CREAT,0777);
	int fd2 = open(argv[2], O_WRONLY|O_CREAT,0777);
	char buf[2] = {'1','0'}; 
	dup2(STDOUT_FILENO,fd); //将fd指向了标准输出,向fd中写入会直接显示到终端中
	if(fd==-1){
		perror("open fd error");
		exit(1);
	}
	if(fd2==-1){
		perror("open fd2 error");
		exit(1);
	}
	while(1){
		lseek(fd,0,SEEK_SET);
		lseek(fd2,0,SEEK_SET);
		write(fd,buf,1);
		write(fd2,&buf[1],1);
		sleep(2);
		lseek(fd,0,SEEK_SET);
		lseek(fd2,0,SEEK_SET);
		write(fd,&buf[1],1);
		write(fd2,buf,1);
		sleep(2);
	}
	close(fd);
	close(fd2);
	return 0;
}


2. 进程

  1. pid_t fork()创建子进程
    返回值:0:子进程,-1:失败,并且生成errno,>0: 子进程pid号
  2. waitpid(pid_t pid,int *wstatus, int options)回收子进程
    pid: -1 任意子进程

    < < <-1 回收进程组id等于 pid的绝对值

    0 子进程创建过程
    > > > 0 子进程pid号

  3. pid_t getpid() 获取进程id
c 复制代码
/*
名称:pid_arm.c
*/

#include <unistd.h>
#include <stdio.h>
#include <sys/wait.h>


int main(void){
	pid_t pid;
	int i = 0;
	for(;i<5;i++){
		if((pid = fork())==0)
			break;
	}	
	if(i == 5){
		sleep(5);
		waitpid(-1,NULL,0);
		printf("pid is %d\n",getpid());
	}
	else{
		sleep(i);
		printf("pid is %d\n",getpid());
	}
	return 0;
}

编译发送同前;

效果:

相关推荐
和舒貌1 小时前
Linux系统编程基础详解
linux·运维·服务器·基础
Jack魏2 小时前
Linux MySQL 8.0.29 忽略表名大小写配置
linux·mysql·mysql8·mysql常见问题
ctrigger2 小时前
AI回答:Linux C/C++编程学习路线
linux·c语言·c++
蛊明4 小时前
下载CentOS 10
linux·运维·centos
北京-宏哥4 小时前
Linux系统安装MySQL5.7(其他版本类似)避坑指南
linux·运维·服务器
Aphelios3804 小时前
Linux 下 VIM 编辑器学习记录:从基础到进阶(下)
java·linux·学习·编辑器·vim
qw9494 小时前
Linux 高级篇 日志管理、定制自己的Linux系统、备份与恢复
linux·运维·服务器
丶只有影子4 小时前
【Nacos】从零开始启动Nacos服务(windows/linux)
linux·运维·windows·微服务·springcloud
-SGlow-5 小时前
Linux相关概念和易错知识点(30)(线程互斥、线程同步)
linux·运维·服务器
茂茂在长安6 小时前
Linux 命令大全完整版(11)
java·linux·运维·服务器·前端·centos