#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <fcntl.h>
//윈도우에 cygwin 설치후
//Notepad++ 를 사용해서 편집.
//컴파일 방법은
//.c 파일은 gcc -o read read.c
//.cpp 파일은 g++ -o read read.cpp
//실행 방법은
//./read
//vi read.c 로 파일 사용가능
//i 누르면 키보드 입력
//esc 누르면 키보드 입력 중지
//esc 누르고 shift + zz 누르면 저장하고 나가기
//esc 누르고 :q! 엔터치면 저장 않고 나가기
//ls 로 목록 보기
//cd 로 경로 이동하기
//cd .. 상위 경로로 이동하기
int main(int argc, char* argv)
{
int r = 0;
int fd = 0;
char buf[1024];
char * pbuf = (char*) malloc (10);
size_t size;
fd = open("txt.txt", O_RDONLY);
if(fd == 0)
{
perror("open() 에러\n");
exit(1);
}
//fd 0은 표준 입력
//fd 1은 표준 출력
//fd 2은 화면 출력
size = read(fd, pbuf, 10);
if(size == -1) //실패
{
perror("read() 에러\n");
exit(1);
}
printf("%s\n", pbuf);
r = close(fd);
if(r == -1)
{
//실패
perror("close() 에러\n");
exit(1);
}
free(pbuf);
pbuf = NULL;
system("pause");
return 0;
}
/*
//---------------------------------------------------------------------------------------
int open(const char path, int oflag, / * mode_t mode * /);
path = 파일경로를 포함하는 문자열
oflag = 열린 파일의 제어 방법을 지정
O_RDONLY | O_WRONLY | O_RDWR | O_APPEND | O_CREAT | O_EXCL | O_NDELAY | O_NONBLOCK | O_NOCTTY | O_DSYNC
| O_RSYNC | O_SYNC | O_TRUNC
성공 = 파일 디스크립터
실패 = -1
errno() 로 에러코드 확인. errno()는 perror()를 사용.
//---------------------------------------------------------------------------------------
int create(const char *path, mode_t mode);
path = 파일 생성 경로에 파일이름
mode = 프로세스가 가지고 있는 umask값이 mode로 지정한 퍼미션 비트값을 변경하고, 변경된 퍼미션값을 갖는
파일을 만든다. 그런데. path경로에 파일이 이미 있고 쓸 수 있는 파일이라면 파일 크기는 0으로 바뀌고
모든 데이터는 지워진다. 파일을 성공적으로 만들면 creat 함수는 오직 쓰기 전용 파일로
파일 디스크립터를 리턴한다. 그러나 파일을 만들 수 없다면 creat함수는 -1을 리턴하고 실패한 이유를
설명하는 에러코드를 외부 변수 errno에 넣는다.
//---------------------------------------------------------------------------------------
#include <unistd.>
int close(int fd);
파일에는 썼지만. 운영체제에서 디스크에 쓰지 못한 데이터를 마저 쓰고., 이 파일이 사용했던
자원(버퍼, 파일 테이블 엔트리(file table entry)등을 반납할 수 있다. 파일을 닫는 함수는 close이다.
성공 = 0
실패 = -1 (errno)
//---------------------------------------------------------------------------------------
#include <unistd.h>
ssize_t read(int fd, void *buf, size_t nbytes);
ssize_t write(int fd, const void *buf, size_t nbytes);
read 함수는 fd가 가리키는 파일에서 최대 n 바이트만큼 데이터를 읽어와 buf가 가리키는 메모리 영역에 저장한다.
그리고. 실제 읽은 바이트 수를 read함수의 결과로 리턴한다. 만약 결과로 0을 리턴하면 파일에 끝에 도달해서
더 이상 읽을 데이터가 없다는 뜻이다. write 함수는 buf가 가리키는 메모리 영역에서 최대 n 바이트만큼
데이터를 읽어와 fd가 가리키는 파일에 저장한다. 실제로 저장한 바이트 수를 이 함수의 결과로 리탄한다.
두 함수 모두 에러가 발생하면 -1을 리턴하고 외부 변수 errno에 에러 코드는 넣는다.
다른 프로그래밍 언어에 내장되어 있는 입출력 명령과 달리 read와 write함수는 데이터를 변환하거나
데이터 형식을 지정하지 않는다. 이 두 함수에 어떤 종류의 C데이터형식을 넣어도 실행할 수는 있다.
하지만 이것은 사람이 읽을 수 있는 형태의 데이터가 아니라 실제 메모리 안에 있는 데이터 그대로
실행하는 것이다.
유닉스 시스템 프로그래밍 SVR4' 내용 (무단전제...)참조... ㅡ_ㅡ;;
*/
----------------------------------------------------------------------------
젊음'은 모든것을 가능하게 만든다.
매일 1억명이 사용하는 프로그램을 함께 만들어보고 싶습니다.
정규 근로 시간을 지키는. 야근 없는 회사와 거래합니다.
read 와는 별 관계 없고, 쉘에서 * 를 wildcard 로 확장해 주기 때문입니다.
set -f 명령으로 glob 을 끄고 해보세요.
스크립트에서 #!/bin/sh -f 와 같이 -f 옵션을 줘도 됩니다.
$ touch a b c
$ cat a.sh
#!/bin/sh -f
echo $1 $2 $3
exit 0;
$ ./a.sh *
*
$ sh a.sh *
a a.sh b c
$ sh -f a.sh *
*
$ echo *
a a.sh b c
$ set -f
$ echo *
*
되면 한다! / feel no sorrow, feel no pain, feel no hurt, there's nothing gained.. only love will then remain.. 『 Mizz 』
참고해 보세요.
필요한 내용이 있으지 모르겠네요. ㅇ_ㅇ;;
----------------------------------------------------------------------------
젊음'은 모든것을 가능하게 만든다.
매일 1억명이 사용하는 프로그램을 함께 만들어보고 싶습니다.
정규 근로 시간을 지키는. 야근 없는 회사와 거래합니다.
각 분야별. 좋은 책'이나 사이트' 블로그' 링크 소개 받습니다. shintx@naver.com
문제를 재현할 수 있는 짧막한 스크립트 샘플을 만들어
문제를 재현할 수 있는 짧막한 스크립트 샘플을 만들어 올려주시면
빠른 도움을 받으실 수 있을 것입니다.
음 ..
read 와는 별 관계 없고, 쉘에서 * 를 wildcard 로 확장해 주기 때문입니다.
set -f 명령으로 glob 을 끄고 해보세요.
스크립트에서 #!/bin/sh -f 와 같이 -f 옵션을 줘도 됩니다.
되면 한다! / feel no sorrow, feel no pain, feel no hurt, there's nothing gained.. only love will then remain.. 『 Mizz 』
댓글 달기