Professional Documents
Culture Documents
Program:-
read num
iter=1
do
iter=`expr $iter + 1`
done
Program:-
iter=1
read nn
mkdir $nn
read na
while [ $iter –le $na ]
do
read fn
cp $fn $nn
iter=`expr $iter + 1`
done
Program:-
a given file.
read fn
wc –l $fn
wc –w $fn
wc –c $fn
program:-
echo Menu
read ch
case ch in
1) ls $a;;
2) ls –l $a;;
3) ls –la $a;;
esac
program:-
There are two division options: one returns the quotient and the other
returns reminder. The script requires 3 arguments: The operation to be used and two integer numbers.
read x
do
read s
case $s in
;;
;;
;;
;;
;;
program:-
read r
read c
i=0
do
read a[$i]
i= `expr $i + 1`
done
i=0 ; k=0
until [ $i –eq $c ]
do
j=0;
until [ $j –eq $r ]
do
n= `expr $j \* $c`
m= `expr $n + $i
b[$k] = ${a[$m]}
k= `expr $k + 1`
j= `expr $j + 1`
done
i = `expr $i + 1`
echo "\n"
done
Program 7
Program:-
#include <fcntl.h>
#include <stdio.h>
FILE *fd1;
int n,count=0;
char buf;
fd1=fopen(argv[1],"r");
while(!feof(fd1))
buf=fgetc(fd1);
if(buf==' ')
count=count+1;
return (0);
Unix commands
Cat:-
#include<fcntl.h>
#include<sys/stat.h>
#define BUFSIZE 1
int fd1;
int n;
char buf;
fd1=open(argv[1],O_RDONLY);
while((n=read(fd1,&buf,1))>0)
printf("%c",buf);
/* or
write(1,&buf,1); */
return (0);
LS command
#include <sys/types.h>
#include <sys/dir.h>
#include <sys/param.h>
#include <stdio.h>
#define FALSE 0
#define TRUE 1
char pathname[MAXPATHLEN];
main() {
int count,i;
int file_select();
if (getwd(pathname) == NULL )
exit(0);
if (count <= 0)
exit(0);
for (i=1;i<count+1;++i)
printf("%s \n",files[i-1]->d_name);
}
return (FALSE);
else
return (TRUE);
Mv command
Program:-
#include<fcntl.h>
#include<stdio.h>
#include<unistd.h>
#include<sys/stat.h>
int fd1,fd2;
int n,count=0;
fd1=open(argv[1],O_RDONLY);
fd2=creat(argv[2],S_IWUSR);
rename(fd1,fd2);
unlink(argv[1]);
return (0);
program 8:-
Program:-
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main()
int fd[2];
if(pipe(fd)<0)
exit(1);
if(fork())
close(fd[0]);
else
char buf[100];
close(fd[1]);
read(fd[0],buf,100);
fflush(stdout);
exit(0);
Program 9
program:-
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <fcntl.h>
int main()
int i,n,sum=0;
pid_t pid;
system(“clear”);
printf(“Enter n value:”);
scanf(“%d”,&n)
pid=fork();
if(pid==0)
for(i=1;i<n;i+=2)
printf(“%d\”,i);
sum+=i;
printf(“Odd sum:%d\n”,sum);
else
printf(“From process\n”);
for(i=0;i<n;i+=2)
printf(“%d\”,i);
sum+=i;
printf(“Even sum:%d\n”,sum);
program 10
Displays the real time
Program:-
#include <stdio.h>
#include <sys/time.h>
#include <sys/signal.h>
/* Declarations */
void main();
int times_up();
void main()
for (; ;)
times_up(1);
sleep(60);
int times_up(sig)
int sig;
{
long now;
char *ctime();
time (&now);
return (sig);
program 11
Program:-
#include <stdio.h>
#include <sys/file.h>
#include <error.h>
#include <sys/sem.h>
int semid,fd;
void my_lock(int);
void my_unlock(int);
union semnum
int val;
short *array;
}arg;
int main(])
char buff[MAXBUF+1];
pid=getpid();
perror(“semget”);
exit(1);
arg.val=1;
if(semctl(semid,0,SETVAL,arg)<0)
perror(“semctl”);
if((fd=open(SEQFILE,2))<0)
perror(“open”);
exit(1);
pid=getpid();
for(i=0;i<2;i++)
my_lock(fd);
lseek(fd,01,0);
if((n=read(fd,buff,MAXBUF))<0)
perror(“read”);
exit(1);
seqno++;
sprintf(buff,”%d\n”, seqno);
n=strlen(buff);
lseek(fd,01,0);
if(write(fd,buff,n)!=n)
perror(“write”);
exit(1);
sleep(1);
my_unlock(fd);
{
struct sembuff sbuf=(0, -1, 0);
printf(“Locking: Resource…\n”);
else
printf(“Error in Lock\n”);
printf(“UnLocking: Resource…\n”);
else
printf(“Error in Unlock\n”);
program 12
Program:-
processes.(using semaphores)
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <time.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
#define NUM_LOOPS 20
int sem_set_id;
int child_pid;
int i;
int rc;
if (sem_set_id == -1) {
perror("main: semget");
exit(1);
sem_val.val = 0;
switch (child_pid) {
case -1:
perror("fork");
exit(1);
case 0:
sem_op.sem_num = 0;
sem_op.sem_op = -1;
sem_op.sem_flg = 0;
fflush(stdout);
sleep(3);
break;
default:
fflush(stdout);
sem_op.sem_num = 0;
sem_op.sem_op = 1;
sem_op.sem_flg = 0;
delay.tv_sec = 0;
delay.tv_nsec = 10;
nanosleep(&delay, NULL);
break;
return 0;
program 13
Program:-
#include <stdio.h>
#include<sys/ipc.h>
#include<sys/shm.h>
#include<sys/types.h>
#define SEGSIZE 100
int shmid,cntr;
key_t key;
char *segptr;
key=ftok(“.”,’s’);
if((shmid=shmget(key,SEGSIZE,0))= = -1)
perror(“shmget”);
exit(1);
else
printf(“SHMID:%d”, shmid);
system(“ipcs –m”);
if((segptr=shmat(shmid,0,0))= =(char*)-1)
{
perror(“shmat”);
exit(1);
strcpy(segptr,buff);
printf(“DONE\n”);
printf(“DATA:-%s\n”segptr);
printf(“DONE\n”);
if(shmctl(shmid,IPC_RMID,0)= = -1)
else
printf(“Removed Successfully”);
program 14
Program:-
the following.
#include <stdio.h>
#include <sys/ipc.h>
#include <fcntl.h>
struct mesg
long type;
char mtext[MAX];
} *mesg;
char buff[MAX];
main()
int mid,fd,n,count=0;;
if((mid=msgget(1006,IPC_CREAT | 0666))<0)
exit(1);
mesg ->type=6;
fd=open(“fact”,O_RDONLY);
while(read(fd,buff,25)>0)
strcpy(mesg ->mtext,buff);
if((mid=msgget(1006,0))<0)
exit(1);
while((n=msgrcv(mid,&mesg,MAX,6,IPC_NOWAIT))>0)
write(1,mesg.mtext,n);
count++;