linux 下c 程序设计,Linux下C编程

按照书上的内容进行的,已经看到16页了,有点儿慢,想看仔细一点儿,另外自己还有其他的事情来忙,总结一下,以后回来可以看,也方便大家能给我一点儿指导。

’‘’第一个代码

#include

#include

#include

#include

int main(int argc,char* argv[])

{

DIR *dp;

struct dirent *dirp;

if(argc!=2)

printf("a single argument (the directionary name) is required");

if((dp=opendir(argv[1]))==NULL)

printf("cant open %s",argv[1]);

while((dirp=readdir(dp))!=NULL)

printf("%s\n",dirp->d_name);

closedir(dp);

exit(0);

}‘’‘

主要用到了打开目录,读取目录和关闭目录,不过在执行的时候总是出现没有这样的目录的错误,如果各位有知道的 ,能告诉我将不胜感谢。

‘’‘第二个代码

#include

#include

#include

#define BUFFSIZE 8192

int main()

{

int n;

char buf[BUFFSIZE];

while((n=read(STDIN_FILENO,buf,BUFFSIZE))>0)

if(write(STDOUT_FILENO,buf,n)!=n)

printf("write error");

if(n<0)

printf("read error");

exit(0);

}‘’‘

这是读取输入并将输入原样输出的程序

‘’‘第三个代码

#include

#include

#include

#include

int main()

{

printf("process id=%d\n",getpid());

exit(0);

}

’‘’

这是打印本进程的id号

‘’‘

第四个程序

#include

#include

#include

#include

#include

#include

#define MAXLINE 10

int main()

{

char buf[MAXLINE];

pid_t pid;

int status;

printf("%% ");

while(fgets(buf,MAXLINE,stdin)!=NULL){

buf[strlen(buf)-1]=0;

if((pid=fork())<0)// father id and child is 0 the string should be the process name that already exist

printf("fork error");

else if(pid==0){

(void)execlp(buf,buf,(char*)0);

printf("couldn't execute: %s",buf);

exit(127);

}

if(pid=waitpid(pid,&status,0)<0)

printf("waitpid error");

printf("%% ");

}

exit(0);

}

‘’‘

输入的字符串是已经存在的程序的名字。out,然后为他建立一个进程来执行,如果fork失败会返回-1,建立没有成功,我报这个错误时是我可以fork但是没有这个程序,即我给的字符串是随便写的,会返回的是0,成功,就会显示运行结果了。

‘’‘

第五个程序

#include

#include

#include

#include

int main(int argc,char *argv[])

{

fprintf(stderr,"EACCES:%s\n",strerror(EACCES));

errno=ENOENT;

perror(argv[0]);

exit(0);

}

‘’‘

这个直接输出错误信息

‘’‘第六个代码

#include "ourhdr.h"

int main()

{

printf("uid=%d,git=%d",getuid(),getgid());

exit(0);

}’‘’

输出用户id和组id

‘’‘第七个代码

#include

#include

#include

#include "ourhdr.h"

static void sig_int(int);

#define MAXLINE 20

int main()

{

char buf[MAXLINE];

pid_t pid;

int status;

if(signal(SIGINT,sig_int)==SIG_ERR)

printf("signal error");

printf("%%");

while(fgets(buf,MAXLINE,stdin)!=NULL)

{

buf[strlen(buf)-1]=0;

if((pid=fork())<0)

printf("fork error");

else if(pid==0){

execlp(buf,buf,(char*)0);

printf("Couldn't excute: %s",buf);

exit(127);

}

if((pid=waitpid(pid,&status,0))<0)

printf("waitpid error");

printf("%%");

}

exit(0);

}

void sig_int(int signo)

{

printf("interrupt\n%% ");

}’‘’

这个比较坑

功能和第四个差不过,不过这里多了一个错误信号处理程序,我按下crtl+c就会进入处理程序,然后又返回来,可是怎么停止程序呢,求助

附赠

ourhdr.h

#include

#include

#include

#include

#include

#include

自己写的不是原书的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值