2009년 상반기 사업계획
|
|
- 아인 태
- 6 years ago
- Views:
Transcription
1 시그널 IT CookBook, 유닉스시스템프로그래밍
2 학습목표 시그널의기본개념을이해한다. 시그널을보내는방법을이해한다. 시그널을받아서처리하는기본적인방법을이해한다. 시그널집합의개념과사용방법을이해한다. sigaction 함수를사용해시그널을처리하는방법을이해한다. 알람시그널의처리방법을이해한다. 시그널관련기타함수들의사용방법을이해한다. 2/38
3 목차 시그널의개념 시그널의종류 시그널보내기 시그널핸들러함수 시그널집합 sigaction 함수의활용 알람시그널과인터벌타이머 기타시그널관련함수 3/38
4 시그널의개념 시그널 소프트웨어인터럽트프로세스에뭔가발생했음을알리는간단한메시지를비동기적으로보내는것 발생사유 0 으로나누기처럼프로그램에서예외적인상황이일어나는경우 kill 함수처럼시그널을보낼수있는함수를사용해서다른프로세스에시그널을보내는경우 사용자가 Ctrl+C 와같이인터럽트키를입력한경우 시그널처리방법 각시그널에지정된기본동작수행. 대부분의기본동작은프로세스종료 시그널을무시 시그널처리를위한함수 ( 시그널핸들러 ) 를지정해놓고시그널을받으면해당함수호출 시그널이발생하지않도록블록처리 4/38
5 시그널의종류 이외에도시그널의종류는다양함 ( 표 7-7 참조 ) 5/38
6 시그널보내기 [1] kill 명령 프로세스에시그널을보내는명령 예 : 3255번프로세스에 9번시그널 (SIGKILL) 보내기 -> 프로세스강제종료 # kill 시그널보내기 : kill(2) #include <sys/types.h> #include <signal.h> int kill(pid_t pid, int sig); pid 가 0 보단큰수 : pid 로지정한프로세스에시그널발송 pid 가 -1 이아닌음수 : 프로세스그룹 ID 가 pid 의절대값인프로세스그룹에속하고시그널을보낼권한을가지고있는모든프로세스에시그널발송 pid 가 0 : 특별한프로세스를제외하고프로세스그룹 ID 가시그널을보내는프로세스의프로세스그룹 ID 와같은모든프로세스에게시그널발송 pid 가 -1 : 시그널을보낸는프로세스의유효사용자 ID 가 root 가아니면, 특별한프로세스를제외하고프로세스의실제사용자 ID 가시그널을보내는프로세스의유효사용자 ID 와같은모든프로세스에시그널발송 6/38
7 [ 예제 7-1] kill 함수사용하기 ex7_1.c 01 #include <sys/types.h> 02 #include <unistd.h> 03 #include <signal.h> 04 #include <stdio.h> int main(void) { 07 printf("before SIGCONT Signal to parent.\n"); kill(getppid(), SIGCONT); printf("before SIGQUIT Signal to me.\n"); kill(getpid(), SIGQUIT); printf("after SIGQUIT Signal.\n"); return 0; 18 } # ex7_1.out Before SIGCONT Signal to parent. Before SIGQUIT Signal to me. 끝 (Quit)( 코어덤프 ) SIGQUIT 의기본동작은코어덤프 7/38
8 시그널보내기 [2] 시그널보내기 : raise(2) #include <signal.h> int raise(int sig); 함수를호출한프로세스에시그널발송 시그널보내기 : abort(3) #include <stdlib.h> void abort(void); 함수를호출한프로세스에 SIGABRT시그널발송 SIGABRT 시그널은프로세스를비정상적으로종료시키고코어덤프생성 8/38
9 시그널핸들러함수 [1] 시그널핸들러 시그널을받았을때이를처리하기위해지정된함수 프로세스를종료하기전에처리할것이있거나, 특정시그널에대해종료하고싶지않을경우지정 시그널핸들러지정 : signal(3) #include <signal.h> void (*signal(int sig, void (*disp)(int)))(int); disp : sig 로지정한시그널을받았을때처리할방법 시그널핸들러함수명 SIG_IGN : 시그널을무시하도록지정 SIG_DFL : 기본처리방법으로처리하도록지정 signal 함수는시그널이들어올때마다시그널핸들러를호출하려면매번시그널핸들러를재지정해야함. 9/38
10 [ 예제 7-2] signal 함수사용하기 ex7_2.c void handler(int signo) { 08 printf("signal Handler Signal Number : %d\n", signo); 09 psignal(signo, "Received Signal"); 10 } int main(void) { 13 void (*hand)(int); hand = signal(sigint, handler); 16 if (hand == SIG_ERR) { 17 perror("signal"); 18 exit(1); 19 } printf("wait 1st Ctrl+C... : SIGINT\n"); 22 pause(); 23 printf("after 1st Signal Handler\n"); 24 printf("wait 2nd Ctrl+C... : SIGINT\n"); 25 pause(); 26 printf("after 2nd Signal Handler\n");27 28 return 0; 29 } # ex7_2.out Wait 1st Ctrl+C... : SIGINT ^CSignal Handler Signal Number : 2 Received Signal: Interrupt After 1st Signal Handler Wait 2nd Ctrl+C... : SIGINT ^C# 두번째 Ctrl+C 는처리못함 10/38
11 [ 예제 7-3] 시그널핸들러재지정하기 ex7_3.c void handler(int signo) { 08 void (*hand)(int); 09 hand = signal(sigint, handler); 10 if (hand == SIG_ERR) { 11 perror("signal"); 12 exit(1); 13 } printf("signal Handler Signal Number: %d\n", signo); 16 psignal(signo, "Received Signal"); 17 }... # ex7_3.out Wait 1st Ctrl+C... : SIGINT ^CSignal Handler Signal Number: 2 Received Signal: Interrupt 두번째 Ctrl+C 도처리 시그널핸들러재지정 After 1st Signal Handler Wait 2nd Ctrl+C... : SIGINT ^CSignal Handler Signal Number: 2 Received Signal: Interrupt After 2nd Signal Handler 11/38
12 시그널핸들러함수 [2] 시그널핸들러지정 : sigset(3) #include <signal.h> void (*sigset(int sig, void (*disp)(int)))(int); disp : sig 로지정한시그널을받았을때처리할방법 시그널핸들러함수명 SIG_IGN : 시그널을무시하도록지정 SIG_DFL : 기본처리방법으로처리하도록지정 sigset 함수는 signal 함수와달리시그널핸들러가한번호출된후에기본동작으로재설정하지않고, 시그널핸들러를자동으로재정한다. 12/38
13 [ 예제 7-4] sigset 함수사용하기 ex7_4.c void handler(int signo) { 08 printf("signal Handler Signal Number : %d\n", signo); 09 psignal(signo, "Received Signal"); 10 } int main(void) { 13 if (sigset(sigint, handler) == SIG_ERR) { 14 perror("sigset"); 15 exit(1); 16 } printf("wait 1st Ctrl+C... : SIGINT\n"); 19 pause(); 20 printf("after 1st Signal Handler\n"); 21 printf("wait 2nd Ctrl+C... : SIGINT\n"); 22 pause(); 23 printf("after 2nd Signal Handler\n"); return 0; 26 } 시그널핸들러를재지정하지않아도됨 # ex7_4.out Wait 1st Ctrl+C... : SIGINT ^CSignal Handler Signal Number: 2 Received Signal: Interrupt After 1st Signal Handler Wait 2nd Ctrl+C... : SIGINT ^CSignal Handler Signal Number: 2 Received Signal: Interrupt After 2nd Signal Handler 13/38
14 시그널집합 시그널집합의개념 시그널을개별적으로처리하지않고복수의시그널을처리하기위해도입한개념 POSIX 에서도입 시그널집합의처리를위한구조체 sigset_t typedef struct { unsigned int sigbits[4]; } sigset_t; 시그널을비트마스트로표현. 각비트가특정시그널과 1:1 로연결 비트값이 1 이면해당시그널이설정된것이고, 0 이면시그널설정안된것임 14/38
15 시그널집합처리함수 [1] 시그널집합비우기 : sigemptyset(3) #include <signal.h> int sigemptyset(sigset_t *set); 시그널집합에서모든시그널을 0으로설정 시그널집합에모든시그널설정 : sigfillset(3) #include <signal.h> int sigfillset(sigset_t *set); 시그널집합에서모든시그널을 1로설정 시그널집합에시그널설정추가 : sigaddset(3) #include <signal.h> int sigaddset(sigset_t *set, int signo); signo 로지정한시그널을시그널집합에추가 15/38
16 시그널집합처리함수 [2] 시그널집합에서시그널설정삭제 : sigdelset(3) #include <signal.h> int sigdelset(sigset_t *set, int signo); signo로지정한시그널을시그널집합에서삭제 시그널집합에설정된시그널확인 : sigismember(3) #include <signal.h> int sigismember(sigset_t *set, int signo); signo로지정한시그널이시그널집합에포함되어있는지확인 16/38
17 [ 예제 7-5] 시그널집합처리함수사용하기 ex7_5.c 01 #include <signal.h> 02 #include <stdio.h> int main(void) { 05 sigset_t st; sigemptyset(&st); 시그널집합비우기 sigaddset(&st, SIGINT); 시그널추가 10 sigaddset(&st, SIGQUIT); if (sigismember(&st, SIGINT)) 시그널설정확인 13 printf("sigint is setting.\n"); printf("** Bit Pattern: %x\n",st. sigbits[0]); return 0; 18 } 6 은 2 진수로 이므로오른쪽에서 2 번, 3 번비트가 1 로설정 SIGINT 는 2 번, SIGQUIT 는 3 번시그널 # ex7_5.out SIGINT is setting. ** Bit Pattern: 6 17/38
18 sigaction 함수의활용 [1] sigaction 함수 signal 이나 sigset 함수처럼시그널을받았을때이를처리하는함수지정 signal, sigset 함수보다다양하게시그널제어가능 sigaction 구조체 struct sigaction { int sa_flags; union { void (*sa_handler)(); void (*sa_sigaction)(int, siginfo_t *, void *); } _funcptr; sigset_t sa_mask; }; sa_flags : 시그널전달방법을수정할플래그 ( 다음쪽참조 ) sa_handler/sa_sigaction : 시그널처리를위한동작지정 sa_flags 에 SA_SIGINFO 가설정되어있지않으면 sa_handler 에시그널처리동작지정 sa_flags 에 SA_SIGINFO 가설정되어있으면 sa_sigaction 멤버사용 sa_mask : 시그널핸들러가수행되는동안블록될시그널을지정한시그널집합 18/38
19 sigaction 함수의활용 [2] sa_flags 에지정할수있는값 (sys/signal.h) 19/38
20 sigaction 함수의활용 [3] sigaction 함수 #include <signal.h> int sigaction(int sig, const struct sigaction *restrict act, struct sigaction *restrict oact); sig : 처리할시그널 act : 시그널을처리할방법을지정한구조체주소 oact : 기존에시그널을처리하던방법을저장할구조체주소 첫번째인자로 SIGKILL 과 SIGSTOP 을제외한어떤시그널도올수있음 20/38
21 [ 예제 7-6] sigaction 함수사용하기 (1) ex7_6.c void handler(int signo) { 08 psignal(signo, "Received Signal:"); 09 sleep(5); 10 printf("in Signal Handler, After Sleep\n"); 11 } int main(void) { 14 struct sigaction act; sigemptyset(&act.sa_mask); 17 sigaddset(&act.sa_mask, SIGQUIT); 18 act.sa_flags = 0; 19 act.sa_handler = handler; 20 if (sigaction(sigint, &act, (struct sigaction *)NULL) < 0) { 21 perror("sigaction"); 22 exit(1); 23 } fprintf(stderr, "Input SIGINT: "); 26 pause(); 27 fprintf(stderr, "After Signal Handler\n"); return 0; 30 } sa_mask 초기화 시그널핸들러지정 SIGQUIT 시그널을블록시키기위해추가 시그널받기위해대기 (pause 함수 ) # ex7_6.out Input SIGINT: ^CReceived Signal:: Interrupt ^\In Signal Handler, After Sleep 끝 (Quit)( 코어덤프 ) 21/38
22 [ 예제 7-7] sigaction 함수사용하기 (SA_RESETHAND) ex7_7_arg.c void handler(int signo) { 08 psignal(signo, "Received Signal:"); 09 sleep(5); 10 printf("in Signal Handler, After Sleep\n"); 11 } int main(void) { 14 struct sigaction act; sigemptyset(&act.sa_mask); 17 sigaddset(&act.sa_mask, SIGQUIT); 18 act.sa_flags = SA_RESETHAND; 19 act.sa_handler = handler; 20 if (sigaction(sigint, &act, (struct sigaction *)NULL) < 0) { 21 perror("sigaction"); 22 exit(1); 23 } fprintf(stderr, "Input SIGINT: "); 26 pause(); 27 fprintf(stderr, "After Signal Handler\n"); return 0; 30 } SA_RESETHAND 지정 시그널핸들러가한번호출된후에시그널처리방법이기본처리방법으로재설정 # ex7_7.out Input SIGINT: ^CReceived Signal:: Interrupt ^CIn Signal Handler, After Sleep # 22/38
23 sigaction 함수의활용 [4] sa_flags 에 SA_SIGINFO 플래그를지정하면시그널발생원인을알수있다. 시그널핸들러의형식 void handler (int sig, siginfo_t *sip, ucontext_t *ucp); sip : 시그널이발생한원인을담은 siginfo_t 구조체포인터 ucp : 시그널을받는프로세스의내부상태를나타내는구조체포인터 siginfo_t 구조체 typedef struct { int si_signo; int si_errno; int si_code; union sigval si_value; union { } data; } siginfo_t; si_signo : 시그널번호 si_errno : 0 또는오류번호 si_code : 시그널발생원인코드 data : 시그널의종류에따라값저장 23/38
24 sigaction 함수의활용 [5] 시그널발생원인코드 시그널발생원인출력 : psiginfo(3) #include <siginfo.h> void psiginfo(siginfo_t *pinfo, char *s); pinfo : 시그널발생원인정보를저장한구조체, s: 출력할문자열 24/38
25 [ 예제 7-8] 시그널발생원인검색하기 ex7_8.c void handler(int signo, siginfo_t *sf, ucontext_t *uc) { 09 psiginfo(sf, "Received Signal:"); 10 printf("si_code : %d\n ±, sf->si_code); 11 } int main(void) { 14 struct sigaction act; act.sa_flags = SA_SIGINFO; 17 act.sa_sigaction = (void (*)(int, siginfo_t *, void *))handler; 18 sigemptyset(&act.sa_mask); 19 if (sigaction(sigusr1, &act, (struct sigaction *)NULL) < 0) { 20 perror("sigaction"); 21 exit(1); 22 } pause(); return 0; 27 } SA_SIGINFO 플래그설정 sigaction 함수설정 오류메시지출력 # ex7_8.out& [1] 2515 SIGUSR1 시그널보내기 # kill -USR # Received Signal: : User Signal 1 ( from process 1579 ) si_code : 0 25/38
26 알람시그널 알람시그널 일정한시간이지난후에자동으로시그널이발생하도록하는시그널 일정시간후에한번발생시키거나, 일정간격을두고주기적으로발송가능 알람시그널생성 : alarm(2) #include <unistd.h> unsigned int alarm(unsigned int sec); sec : 알람이발생시킬때까지남은시간 ( 초단위 ) 일정시간이지나면 SIGALRM 시그널발생 프로세스별로알람시계가하나밖에없으므로알람은하나만설정가능 26/38
27 [ 예제 7-9] alarm 함수사용하기 ex7_9.c 01 #include <unistd.h> 02 #include <signal.h> 03 #include <siginfo.h> 04 #include <stdio.h> void handler(int signo) { 07 psignal(signo, "Received Signal"); 08 } int main(void) { 11 sigset(sigalrm, handler); alarm(2); 14 printf("wait...\n"); 15 sleep(3); return 0; 2 초설정 18 } # ex7_9.out Wait... Received Signal: Alarm Clock 27/38
28 인터벌타이머 타이머의종류 ITIMER_REAL : 실제시간사용. SIGALRM 시그널발생 ITIMER_VIRTUAL : 프로세스의가상시간사용. SIGVTALRM 시그널발생 ITIMER_PROF : 시스템이프로세스를위해실행중인시간과프로세스의가상시간을모두사용. SIGPROF 시그널발생 ITIMER_REALPROF : 실제시간사용. 멀티스레드프로그램의실제실행시간측정시사용. SIGPROF 시그널발생 타이머정보검색 : getitimer(2) #include <sys/time.h> int getitimer(int which, struct itimerval *value); 타이머설정 : setitimer(2) #include <sys/time.h> int setitimer(int which, const struct itimerval *value, struct itimerval *ovalue); 28/38
29 인터벌타이머 which : 타이머종류 value : 타이머정보구조체포인터 struct itimerval { struct timeval it_interval; struct timeval it_value; }; struct timeval { time_t tv_sec; suseconds_t tv_usec; }; 29/38
30 [ 예제 7-10] 인터벌타이머설정하기 ex7_10.c int main(void) { 12 struct itimerval it; sigset(sigalrm, handler); 15 it.it_value.tv_sec = 3; 16 it.it_value.tv_usec = 0; 17 it.it_interval.tv_sec = 2; 18 it.it_interval.tv_usec = 0; 19 타이머간격 : 2 초타이머에현재남은시간 : 3 초 3 초후에최초시그널발생이후 2 초간격으로시그널발생 20 if (setitimer(itimer_real, &it, (struct itimerval *)NULL) == -1) { 21 perror("setitimer"); 22 exit(1); 23 } while (1) { 26 if (getitimer(itimer_real, &it) == -1) { 27 perror("getitimer"); 28 exit(1); 29 } 30 printf("%d sec, %d msec.\n", (int)it.it_value.tv_sec, # ex7_10.out 2 sec, msec. 1 sec, msec. 0 sec, msec. Timer Invoked.. 1 sec, msec. 0 sec, msec. 31 (int)it.it_value.tv_usec); Timer Invoked.. 32 sleep(1); 1 sec, msec. 33 } 남은시간정보출력 0 sec, msec. 34 Timer Invoked.. 35 return 0; 1 sec, msec. 36 } 30/38
31 기타시그널처리함수 [1] 시그널정보출력 : psignal(3) #include <siginfo.h> void psignal(int sig, const char *s); s에지정한문자열을붙여정보출력 시그널정보출력 : strsignal(3) #include <string.h> char *strsignal(int sig); 인자로받은시그널을가리키는이름을문자열로리턴 31/38
32 기타시그널처리함수 [2] 시그널블록킹과해제 #include <signal.h> int sighold(int sig); int sigrelse(int sig); 인자로받은시그널을시그널마스크에추가하거나해제 시그널집합블록과해제 : sigprocmask(2) #include <signal.h> int sigprocmask(int how, const sigset_t *restrict set, sigset_t *restrict oset); how : 시그널을블록할것인지, 해제할것인지여부 SIG_BLOCK : set 에지정한시그널집합을시그널마스크에추가 SIG_UNBLOCK : set 에지정한시그널집합을시그널마스크에서제거 SIG_SETMASK : set 에지정한시그널집합으로현재시그널마스크대체 set : 블록하거나해제할시그널집합주소 oset : NULL 또는이전설정값을저장한시그널집합주소 32/38
33 [ 예제 7-11] 시그널블록함수사용하기 ex7_11.c void handler(int signo) { 08 char *s; 시그널이름리턴 s = strsignal(signo); 11 printf("received Signal : %s\n", s); 12 } int main(void) { 15 if (sigset(sigint, handler) == SIG_ERR) { 16 perror("sigset"); 17 exit(1); 18 } sighold(sigint); pause(); return 0; 25 } SIGINT 블록설정 시그널핸들러설정 SIGINT 시그널을안받는다 # ex7_11.out ^C^C^C^C^C 33/38
34 [ 예제 7-12] sigprocmask 함수사용하기 ex7_12.c int main(void) { 06 sigset_t new; sigemptyset(&new); 09 sigaddset(&new, SIGINT); 10 sigaddset(&new, SIGQUIT); 11 sigprocmask(sig_block, &new, (sigset_t *)NULL); printf("blocking Signals : SIGINT, SIGQUIT\n"); 14 printf("send SIGQUIT\n"); 15 kill(getpid(), SIGQUIT); 16 SIGQUIT 시그널보내기 17 printf("unblocking Signals\n"); 18 sigprocmask(sig_unblock, &new, (sigset_t *)NULL); return 0; 21 } 블록해제후시그널을받아종료 시그널집합에 SIGINT, SIGQUIT 설정 시그널집합블록해제 시그널집합블록설정 # ex7_12.out Blocking Signals : SIGINT, SIGQUIT Send SIGQUIT UnBlocking Signals 끝 (Quit)( 코어덤프 ) 34/38
35 기타시그널처리함수 [3] 시그널대기 : sigpause(3) #include <signal.h> int sigpause(int sig); sig : 시그널이올때까지대기할시그널 시그널기다리기 : sigsuspend(2) #include <signal.h> int sigsuspend(const sigset_t *set); set : 기다리려는시그널을지정한시그널집합 35/38
36 [ 예제 7-13] sigsuspend 함수사용하기 ex7_13.c void handler(int signo) { 07 psignal(signo, "Received Signal:"); 08 } int main(void) { 11 sigset_t set; sigset(sigalrm, handler); sigfillset(&set); 16 sigdelset(&set, SIGALRM); alarm(3); printf("wait...\n"); sigsuspend(&set); return 0; 25 } 알람시그널설정 시그널기다리기 기다릴시그널설정 # ex7_13.out Wait... ^C^CReceived Signal:: Alarm Clock 36/38
37 기타시그널처리함수 [4] 시그널보내기 : sigsend(2) #include <signal.h> int sigsend(idtype_t idtype, id_t id, int sig); idtype : id에지정한값의종류 id : 시그널을받을프로세스나프로세스그룹 sig : 보내려는시그널 37/38
38 기타시그널처리함수 [5] 시그널무시처리 : sigignore(3) #include <signal.h> int sigignore(int sig); sig : 무시할시그널번호 인자로지정한시그널의처리방법을 SIG_IGN으로설정 38/38
39 IT CookBook, 유닉스시스템프로그래밍
Microsoft PowerPoint - ch07_시그널 [호환 모드]
학습목표 시그널의기본개념을이해한다. 시그널을보내는방법을이해한다. 시그널을받아서처리하는기본적인방법을이해한다. 시그널집합의개념과사용방법을이해한다. sigaction 함수를사용해시그널을처리하는방법을이해한다. 알람시그널의처리방법을이해한다. 시그널관련기타함수들의사용방법을이해한다. 시그널 IT CookBook, 유닉스시스템프로그래밍 2/38 목차 시그널의개념 시그널의종류
<4D F736F F F696E74202D BDC3B1D7B3CEB0FA20BDC3B1D7B3CE20C3B3B8AE2E707074>
10 장시그널과시그널처리 시그널과시그널처리 - sigemptyset, sigfillset - sigaddset, sigdelset, sigismember - sigaction - sigprocmask - kill, raise - alarm - pause 1 1. 서론 시그널의종류 이름설명 DA SIGABRT abort() 를호출할때발생 SIGALRM 설정된알람시간이경과한겨우발생
본 강의에 들어가기 전
유닉스프로그래밍및실습 9 장. 시그널 1. 시그널개념 시그널생명주기 시그널이발생한다. 커널이해당시그널을쌓아둔다.( 동일한시그널이오는경우하나만 ) 가능한시점에서커널이적절하게처리한다 커널의처리방법 시그널무시 아무런동작을하지않는다 절대무시할수없는시그널 SIGKILL SIGSTOP 시그널을붙잡아처리 현재코드경로를따라가는실행을중단하고, 시그널마다등록된함수로점프 기본동작
Microsoft PowerPoint - 10_Signal
Operating System Laboratory 시그널 - IPC - 시그널의종류 - 시그널구현함수 IPC 프로세스간통신 (Inter-Process Communication) 실행중인프로세스간에데이터를주고받는기법 IPC 에는매우많은방법이있다! File Pipe/Named pipe Socket Shared memory Message passing Remote
Microsoft PowerPoint - SP6장-시그널.ppt [호환 모드]
UNIX System Programming Ki-Hyun, JUNG Email : kingjung@paran.com 구성 1 장 : 기본적인개념들과기초적인용어들 2 장 : 파일을다루는시스템호출 primitives 3 장 : 파일에대한문맥상의특성 4 장 : 유닉스디렉토리개념 5 장 : 유닉스프로세스의기본적인성질과제어 6 장 : 프로세스간통신 7 장 : 유용한유닉스프로세스간통신기법
1장. 유닉스 시스템 프로그래밍 개요
Unix 프로그래밍및실습 7 장. 시그널 - 과제보충 응용과제 1 부모프로세스는반복해서메뉴를출력하고사용자로부터주문을받아자식프로세스에게주문내용을알린다. (SIGUSR1) ( 일단주문을받으면음식이완료되기전까지 SIGUSR1 을제외한다른시그널은모두무시 ) timer 자식프로세스는주문을받으면조리를시작한다. ( 일단조리를시작하면음식이완성되기전까지 SIGALARM 을제외한다른시그널은모두무시
Chap04(Signals and Sessions).PDF
Signals and Session Management 2002 2 Hyun-Ju Park (Signal)? Introduction (1) mechanism events : asynchronous events - interrupt signal from users : synchronous events - exceptions (accessing an illegal
좀비프로세스 2
Signal & Inter-Process Communication Department of Computer Engineering Kyung Hee University. Choong Seon Hong 1 좀비프로세스 2 좀비프로세스 (zombie process) 좀비프로세스란프로세스종료후메모리상에서사라지지않는프로세스 좀비프로세스의생성이유. 자식프로세스는부모프로세스에게실행결과에대한값을반환해야한다.
제1장 Unix란 무엇인가?
1 시그널 2 11.1 시그널 시그널 시그널은예기치않은사건이발생할때이를알리는소프트웨어인터럽트이다. 시그널발생예 SIGFPE 부동소수점오류 SIGPWR 정전 SIGALRM 알람시계울림 SIGCHLD 자식프로세스종료 SIGINT 키보드로부터종료요청 (Ctrl-C) SIGSTP 키보드로부터정지요청 (Ctrl-Z) 3 주요시그널 시그널이름 의미 기본처리 SIGABRT
슬라이드 1
Task 통신및동기화 : 시그널 (Signal) Chapter #10 Cooperating Processes Signal 개요 Signal 처리 Signal 전송 타이머처리 강의목차 Unix System Programming 2 Cooperating Processes (1) Independent process cannot affect or be affected
/chroot/lib/ /chroot/etc/
구축 환경 VirtualBox - Fedora 15 (kernel : 2.6.40.4-5.fc15.i686.PAE) 작동 원리 chroot유저 ssh 접속 -> 접속유저의 홈디렉토리 밑.ssh의 rc 파일 실행 -> daemonstart실행 -> daemon 작동 -> 접속 유저만의 Jail 디렉토리 생성 -> 접속 유저의.bashrc 의 chroot 명령어
<4D F736F F F696E74202D20B8AEB4AABDBA20BFC0B7F920C3B3B8AEC7CFB1E22E BC8A3C8AF20B8F0B5E55D>
리눅스 오류처리하기 2007. 11. 28 안효창 라이브러리함수의오류번호얻기 errno 변수기능오류번호를저장한다. 기본형 extern int errno; 헤더파일 라이브러리함수호출에실패했을때함수예 정수값을반환하는함수 -1 반환 open 함수 포인터를반환하는함수 NULL 반환 fopen 함수 2 유닉스 / 리눅스 라이브러리함수의오류번호얻기 19-1
The Pocket Guide to TCP/IP Sockets: C Version
인터넷프로토콜 6 장 중급소켓프로그래밍 (2) 목차 제 6 장중급소켓프로그래밍 6.1 소켓옵션 6.2 시그널 6.3 넌블로킹입 / 출력 6.4 멀티태스킹 6.5 멀티플렉싱 6.6 다수의수신자처리 2 시그널 (Signal) 시그널이란? 예상치않은이벤트발생에따른일종의소프트웨어인터럽트 Ex) ctrl + c, ctrl + z, 자식프로세스의종료 외부에서프로세스에게전달할수있는유일한통로
ABC 11장
12 장고급응용 0 수행중인프로그램 프로세스 모든프로세스는유일한프로세스식별번호 (PID) 를가짐 유닉스에서는 ps 명령을사용하여프로세스목록을볼수있음 12-1 프로세스 $ ps -aux USER PID %CPU %MEM SZ RSS TT STAT START TIME COMMAND blufox 17725 34.0 1.6 146 105 i2 R 15:13 0:00
<4D F736F F F696E74202D FC7C1B7CEBCBCBDBA20BBFDBCBAB0FA20BDC7C7E0205BC8A3C8AF20B8F0B5E55D>
학습목표 프로세스를생성하는방법을이해한다. 프로세스를종료하는방법을이해한다. exec함수군으로새로운프로그램을실행하는방법을이해한다. 프로세스를동기화하는방법을이해한다. 프로세스생성과실행 IT CookBook, 유닉스시스템프로그래밍 2/24 목차 프로세스생성 프로세스종료함수 exec 함수군활용 exec 함수군과 fork 함수 프로세스동기화 프로세스생성 [1] 프로그램실행
2009년 상반기 사업계획
프로세스생성과실행 IT CookBook, 유닉스시스템프로그래밍 학습목표 프로세스를생성하는방법을이해한다. 프로세스를종료하는방법을이해한다. exec함수군으로새로운프로그램을실행하는방법을이해한다. 프로세스를동기화하는방법을이해한다. 2/24 목차 프로세스생성 프로세스종료함수 exec 함수군활용 exec 함수군과 fork 함수 프로세스동기화 3/24 프로세스생성 [1]
System Programming Lab
System Programming Lab Week 4: Shell Schedule for your own shell 1 st shell 기본기능 fork / exec Background Processing/ Sequential Execution ls, find, grep 2 nd Environment variables/ Shell variables built-in
Chapter #01 Subject
Device Driver March 24, 2004 Kim, ki-hyeon 목차 1. 인터럽트처리복습 1. 인터럽트복습 입력검출방법 인터럽트방식, 폴링 (polling) 방식 인터럽트서비스등록함수 ( 커널에등록 ) int request_irq(unsigned int irq, void(*handler)(int,void*,struct pt_regs*), unsigned
<4D F736F F F696E74202D FB8DEB8F0B8AE20B8C5C7CE205BC8A3C8AF20B8F0B5E55D>
학습목표 통신프로그램이무엇인지이해한다. 을이용한 IPC 기법을이해한다. 함수를사용해프로그램을작성할수있다. IT CookBook, 유닉스시스템프로그래밍 2/20 목차 의개념 함수 해제함수 의보호모드변경 파일의크기확장 매핑된메모리동기화 데이터교환하기 의개념 파일을프로세스의메모리에매핑 프로세스에전달할데이터를저장한파일을직접프로세스의가상주소공간으로매핑 read, write
Microsoft PowerPoint - 09-Pipe
9. 파이프 상명대학교소프트웨어학부 파이프 시그널은이상한사건이나오류를처리하는데는이용하지만, 한프로세스로부터다른프로세스로대량의정보를전송하는데는부적합하다. 파이프 한프로세스를다른관련된프로세스에연결시켜주는단방향의통신채널 2 pipe() Usage #include int pipe(int filedes[2]); 3 < ex_1.c > #include
2009년 상반기 사업계획
메모리매핑 IT CookBook, 유닉스시스템프로그래밍 학습목표 통신프로그램이무엇인지이해한다. 메모리매핑을이용한 IPC 기법을이해한다. 메모리매핑함수를사용해프로그램을작성할수있다. 2/20 목차 메모리매핑의개념 메모리매핑함수 메모리매핑해제함수 메모리매핑의보호모드변경 파일의크기확장 매핑된메모리동기화 데이터교환하기 3/20 메모리매핑의개념 메모리매핑 파일을프로세스의메모리에매핑
11장 포인터
Dynamic Memory and Linked List 1 동적할당메모리의개념 프로그램이메모리를할당받는방법 정적 (static) 동적 (dynamic) 정적메모리할당 프로그램이시작되기전에미리정해진크기의메모리를할당받는것 메모리의크기는프로그램이시작하기전에결정 int i, j; int buffer[80]; char name[] = data structure"; 처음에결정된크기보다더큰입력이들어온다면처리하지못함
Microsoft PowerPoint - ch09_파이프 [호환 모드]
학습목표 파이프를이용한 IPC 기법을이해한다. 이름없는파이프를이용해통신프로그램을작성할수있다. 이름있는파이프를이용해통신프로그램을작성할수있다. 파이프 IT CookBook, 유닉스시스템프로그래밍 2/20 목차 파이프의개념 이름없는파이프만들기 복잡한파이프생성 양방향파이프활용 이름있는파이프만들기 파이프의개념 파이프 두프로세스간에통신할수있도록해주는특수파일 그냥파이프라고하면일반적으로이름없는파이프를의미
2009년 상반기 사업계획
파이프 IT CookBook, 유닉스시스템프로그래밍 학습목표 파이프를이용한 IPC 기법을이해한다. 이름없는파이프를이용해통신프로그램을작성할수있다. 이름있는파이프를이용해통신프로그램을작성할수있다. 2/20 목차 파이프의개념 이름없는파이프만들기 복잡한파이프생성 양방향파이프활용 이름있는파이프만들기 3/20 파이프의개념 파이프 두프로세스간에통신할수있도록해주는특수파일 그냥파이프라고하면일반적으로이름없는파이프를의미
OCW_C언어 기초
초보프로그래머를위한 C 언어기초 4 장 : 연산자 2012 년 이은주 학습목표 수식의개념과연산자및피연산자에대한학습 C 의알아보기 연산자의우선순위와결합방향에대하여알아보기 2 목차 연산자의기본개념 수식 연산자와피연산자 산술연산자 / 증감연산자 관계연산자 / 논리연산자 비트연산자 / 대입연산자연산자의우선순위와결합방향 조건연산자 / 형변환연산자 연산자의우선순위 연산자의결합방향
금오공대 컴퓨터공학전공 강의자료
C 프로그래밍프로젝트 Chap 14. 포인터와함수에대한이해 2013.10.09. 오병우 컴퓨터공학과 14-1 함수의인자로배열전달 기본적인인자의전달방식 값의복사에의한전달 val 10 a 10 11 Department of Computer Engineering 2 14-1 함수의인자로배열전달 배열의함수인자전달방식 배열이름 ( 배열주소, 포인터 ) 에의한전달 #include
2009년 상반기 사업계획
소켓프로그래밍활용 IT CookBook, 유닉스시스템프로그래밍 학습목표 소켓인터페이스를활용한다양한프로그램을작성할수있다. 2/23 목차 TCP 기반프로그래밍 반복서버 동시동작서버 동시동작서버-exec함수사용하기 동시동작서버-명령행인자로소켓기술자전달하기 UDP 프로그래밍 3/23 TCP 기반프로그래밍 반복서버 데몬프로세스가직접모든클라이언트의요청을차례로처리 동시동작서버
슬라이드 1
마이크로컨트롤러 2 (MicroController2) 2 강 ATmega128 의 external interrupt 이귀형교수님 학습목표 interrupt 란무엇인가? 기본개념을알아본다. interrupt 중에서가장사용하기쉬운 external interrupt 의사용방법을학습한다. 1. Interrupt 는왜필요할까? 함수동작을추가하여실행시키려면? //***
PowerPoint 프레젠테이션
UNIX 및실습 8 장. 프로세스와사용자 명령익히기 1 학습목표 유닉스에서프로세스가무엇인지그개념을이해한다. 프로세스와관련된유닉스명령의사용방법을익힌다. 포그라운드처리와백그라운드처리의차이를이해한다. 사용자정보를보는명령의사용방법을익힌다. 2 01. 프로세스의개념과종류 프로세스 (process) 현재시스템에서실행중인프로그램 프로세스는고유번호를가진다. Process
chap12(process).hwp
제 12 장프로세스 프로세스는파일과더불어유닉스운영체제가제공하는핵심개념중의하나이다. 유닉스시스템을깊이있게이해하기위해서는프로세스에대해정확히이해해야한다. 이장에서는프로그램이시작되는과정, 프로세스의구조, 프로세스생성및프로그램실행메커니즘, 프로세스사이의시그널등에대해서자세히살펴본다. 12.1 프로그램시작및종료 유닉스에서프로그램은어떻게실행이시작되고종료될까? 프로그램은 12.3절에서살펴볼
6주차.key
6, Process concept A program in execution Program code PCB (process control block) Program counter, registers, etc. Stack Heap Data section => global variable Process in memory Process state New Running
3. 다음장에나오는 sigprocmask 함수의설명을참고하여다음프로그램의출력물과그출력물이화면이표시되는시점을예측하세요. ( 힌트 : 각줄이표시되는시점은다음 4 가지중하나. (1) 프로그램수행직후, (2) kill 명령실행직후, (3) 15 #include <signal.
학번 : 이름 : 1. 다음가정하에서아래프로그램의출력물을예측하세요. 가정 : 부모프로세스의 process id=20100, 자식프로세스의 process id=20101. int glob = 31; /* external variable in initialized data */ char buf[] = "a write to stdout\n"; int main(void)
슬라이드 1
-Part3- 제 4 장동적메모리할당과가변인 자 학습목차 4.1 동적메모리할당 4.1 동적메모리할당 4.1 동적메모리할당 배울내용 1 프로세스의메모리공간 2 동적메모리할당의필요성 4.1 동적메모리할당 (1/6) 프로세스의메모리구조 코드영역 : 프로그램실행코드, 함수들이저장되는영역 스택영역 : 매개변수, 지역변수, 중괄호 ( 블록 ) 내부에정의된변수들이저장되는영역
Microsoft PowerPoint - chap10-함수의활용.pptx
#include int main(void) { int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); return 0; } 1 학습목표 중 값에 의한 전달 방법과
<C1A63130C0E5C7C1B7CEBCBCBDBA2E687770>
제 10 장프로세스프로그래밍 프로세스시작 / 종료 자식프로세스생성 프로세스내에서새로운프로그램실행 시그널 시스템부팅 10.1 프로그램시작및종료 Unix 에서프로그램은어떻게실행이시작되고종료될까? 프로그램은 10.3 절에서살펴볼 exec 시스템호출에의해실행된다. 이호출은실행될프로그램의시작루틴에게명령줄인수 (command-line arguments) 와환경변수 (environment
Microsoft PowerPoint - chap13-입출력라이브러리.pptx
#include int main(void) int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); return 0; 1 학습목표 스트림의 기본 개념을 알아보고,
chap 5: Trees
5. Threaded Binary Tree 기본개념 n 개의노드를갖는이진트리에는 2n 개의링크가존재 2n 개의링크중에 n + 1 개의링크값은 null Null 링크를다른노드에대한포인터로대체 Threads Thread 의이용 ptr left_child = NULL 일경우, ptr left_child 를 ptr 의 inorder predecessor 를가리키도록변경
untitled
if( ) ; if( sales > 2000 ) bonus = 200; if( score >= 60 ) printf(".\n"); if( height >= 130 && age >= 10 ) printf(".\n"); if ( temperature < 0 ) printf(".\n"); // printf(" %.\n \n", temperature); // if(
[ 마이크로프로세서 1] 2 주차 3 차시. 포인터와구조체 2 주차 3 차시포인터와구조체 학습목표 1. C 언어에서가장어려운포인터와구조체를설명할수있다. 2. Call By Value 와 Call By Reference 를구분할수있다. 학습내용 1 : 함수 (Functi
2 주차 3 차시포인터와구조체 학습목표 1. C 언어에서가장어려운포인터와구조체를설명할수있다. 2. Call By Value 와 Call By Reference 를구분할수있다. 학습내용 1 : 함수 (Function) 1. 함수의개념 입력에대해적절한출력을발생시켜주는것 내가 ( 프로그래머 ) 작성한명령문을연산, 처리, 실행해주는부분 ( 모듈 ) 자체적으로실행되지않으며,
PowerPoint 프레젠테이션
KeyPad Device Control - Device driver Jo, Heeseung HBE-SM5-S4210 에는 16 개의 Tack Switch 를사용하여 4 행 4 열의 Keypad 가장착 4x4 Keypad 2 KeyPad 를제어하기위하여 FPGA 내부에 KeyPad controller 가구현 KeyPad controller 16bit 로구성된
Microsoft PowerPoint - ch09 - 연결형리스트, Stack, Queue와 응용 pm0100
2015-1 프로그래밍언어 9. 연결형리스트, Stack, Queue 2015 년 5 월 4 일 교수김영탁 영남대학교공과대학정보통신공학과 (Tel : +82-53-810-2497; Fax : +82-53-810-4742 http://antl.yu.ac.kr/; E-mail : ytkim@yu.ac.kr) 연결리스트 (Linked List) 연결리스트연산 Stack
Microsoft PowerPoint - chap11-포인터의활용.pptx
#include int main(void) int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); return 0; 1 학습목표 포인터를 사용하는 다양한 방법에
Microsoft PowerPoint - chap02-C프로그램시작하기.pptx
#include int main(void) { int num; printf( Please enter an integer "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); return 0; } 1 학습목표 을 작성하면서 C 프로그램의
리눅스 프로세스 관리
프로세스 (Process) Process 프로그램이나명령어를실행하면메모리에적재되어실제로실행되고있는상태를의미 이러한프로세스들은프로세스가시작하면서할당받는프로세스식별번호인 PID(Process ID), 해당프로세스를실행한부모프로세스를나타내는 PPID(Parent Process ID), UID 와 GID 정보를통해해당프로세스가어느사용자에속해있는지, 프로세스가파일에대해갖는권한및프로세스가실행된터미널,
A Hierarchical Approach to Interactive Motion Editing for Human-like Figures
단일연결리스트 (Singly Linked List) 신찬수 연결리스트 (linked list)? tail 서울부산수원용인 null item next 구조체복습 struct name_card { char name[20]; int date; } struct name_card a; // 구조체변수 a 선언 a.name 또는 a.date // 구조체 a의멤버접근 struct
제1장 Unix란 무엇인가?
1 12 장파이프 2 12.1 파이프 파이프원리 $ who sort 파이프 3 물을보내는수도파이프와비슷 한프로세스는쓰기용파일디스크립터를이용하여파이프에데이터를보내고 ( 쓰고 ) 다른프로세스는읽기용파일디스크립터를이용하여그파이프에서데이터를받는다 ( 읽는다 ). 한방향 (one way) 통신 파이프생성 파이프는두개의파일디스크립터를갖는다. 하나는쓰기용이고다른하나는읽기용이다.
PowerPoint 프레젠테이션
C 언어포인터정복하기 16 강. 포인터로자료구조화하기 TAE-HYONG KIM COMPUTER ENG, KIT 2 학습내용 구조체멤버와구조체포인터멤버 다른구조체 ( 변수 ) 를가리키는구조체 ( 변수 ) 연결된리스트 의구성및관리 포인터로 연결된리스트 탐색하기 3 중첩구조체에자료저장하기 중첩된구조체변수에값저장하기 struct person { char PRID[15];
5. 소켓 프로그래밍
Chapter 5. 소켓프로그래밍 목차 5.1 소켓옵션들 5.2 신호 (Signals) 5.3 넌블로킹입 출력 (Nonblocking I/O) 5.4 멀티태스킹 (Multitasking) 5.5 멀티플렉싱 (Multiplexing) 5.6 여러수신자들 (Multiple Recipients) 5.1 소켓옵션들 TCP/IP 프로토콜개발자들은대부분의애플리케이션들을만족시킬수있는디폴트동작에대해많은시간고려
비트와바이트 비트와바이트 비트 (Bit) : 2진수값하나 (0 또는 1) 를저장할수있는최소메모리공간 1비트 2비트 3비트... n비트 2^1 = 2개 2^2 = 4개 2^3 = 8개... 2^n 개 1 바이트는 8 비트 2 2
비트연산자 1 1 비트와바이트 비트와바이트 비트 (Bit) : 2진수값하나 (0 또는 1) 를저장할수있는최소메모리공간 1비트 2비트 3비트... n비트 2^1 = 2개 2^2 = 4개 2^3 = 8개... 2^n 개 1 바이트는 8 비트 2 2 진수법! 2, 10, 16, 8! 2 : 0~1 ( )! 10 : 0~9 ( )! 16 : 0~9, 9 a, b,
이번장에서학습할내용 동적메모리란? malloc() 와 calloc() 연결리스트 파일을이용하면보다많은데이터를유용하고지속적으로사용및관리할수있습니다. 2
제 17 장동적메모리와연결리스트 유준범 (JUNBEOM YOO) Ver. 2.0 jbyoo@konkuk.ac.kr http://dslab.konkuk.ac.kr 본강의자료는생능출판사의 PPT 강의자료 를기반으로제작되었습니다. 이번장에서학습할내용 동적메모리란? malloc() 와 calloc() 연결리스트 파일을이용하면보다많은데이터를유용하고지속적으로사용및관리할수있습니다.
슬라이드 1
/ 유닉스시스템개요 / 파일 / 프로세스 01 File Descriptor file file descriptor file type unix 에서의파일은단지바이트들의나열임 operating system 은파일에어떤포맷도부과하지않음 파일의내용은바이트단위로주소를줄수있음 file descriptor 는 0 이나양수임 file 은 open 이나 creat 로 file
K&R2 Reference Manual 번역본
typewriter structunion struct union if-else if if else if if else if if if if else else ; auto register static extern typedef void char short int long float double signed unsigned const volatile { } struct
본 강의에 들어가기 전
C 기초특강 종합과제 과제내용 구조체를이용하여교과목이름과코드를파일로부터입력받아관리 구조체를이용하여학생들의이름, 학번과이수한교과목의코드와점수를파일로부터입력 학생개인별총점, 평균계산 교과목별이수학생수, 총점및평균을계산 결과를파일에저장하는프로그램을작성 2 Makefile OBJS = score_main.o score_input.o score_calc.o score_print.o
Lab 3. 실습문제 (Single linked list)_해답.hwp
Lab 3. Singly-linked list 의구현 실험실습일시 : 2009. 3. 30. 담당교수 : 정진우 담당조교 : 곽문상 보고서제출기한 : 2009. 4. 5. 학과 : 학번 : 성명 : 실습과제목적 : 이론시간에배운 Singly-linked list를실제로구현할수있다. 실습과제내용 : 주어진소스를이용해 Singly-linked list의각함수를구현한다.
61 62 63 64 234 235 p r i n t f ( % 5 d :, i+1); g e t s ( s t u d e n t _ n a m e [ i ] ) ; if (student_name[i][0] == \ 0 ) i = MAX; p r i n t f (\ n :\ n ); 6 1 for (i = 0; student_name[i][0]!= \ 0&&
The Pocket Guide to TCP/IP Sockets: C Version
인터넷프로토콜 6 장 중급소켓프로그래밍 목차 제 6 장중급소켓프로그래밍 6.1 소켓옵션 6.2 시그널 6.3 넌블로킹입 / 출력 6.4 멀티태스킹 6.5 멀티플렉싱 6.6 다수의수신자처리 2 소켓옵션 소켓옵션 (socket options) 소켓의기본동작을변경 소켓코드와프로토콜구현코드에대한세부적인제어가능 소켓옵션관련함수 #include
1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 #define _CRT_SECURE_NO_WARNINGS #include #include main() { char ch; printf(" 문자 1개를입력하시오 : "); scanf("%c", &ch); if (isalpha(ch))
제9장 프로세스 제어
제 9 장프로세스제어 리눅스시스템프로그래밍 청주대학교전자공학과 한철수 제 9 장 목차 프로세스생성 프로그램실행 입출력재지정 프로세스그룹 시스템부팅 2 9.1 절 프로세스생성 fork() 시스템호출 새로운프로그램을실행하기위해서는먼저새로운프로세스를생성해야하는데, fork() 시스템호출이새로운프로세스를생성하는유일한방법임. 함수프로토타입 pid_t fork(void);
4. What will be the output of this program? Explain results for each variable and each thread. #include "apue.h" int var=1; pthread_mutex_t lock; void
학번 : 이름 : 1. What will be the output of this program? assumption: parent's process id=10100, child process id=10101. #include "apue.h" char buf[] = "a write to stdout\n"; int main(void) int var; /* automatic
3. 다음장에나오는 sigprocmask 함수의설명을참고하여다음프로그램의출력물과그출력물이화면이표시되는시점을예측하세요. ( 힌트 : 각줄이표시되는시점은다음 6 가지중하나. (1) 프로그램수행직후, (2) 5 초후 (3) 10 초후 (4) 15 #include <signa
학번 : 이름 : 1. 다음가정하에서아래프로그램의출력물을예측하세요. 가정 : 부모프로세스의 process id=10100, 자식프로세스의 process id=10101. char buf[] = "a write to stdout\n"; int var; /* automatic variable on the stack */ pid_t pid; int glob = 31;
C++ Programming
C++ Programming 예외처리 Seo, Doo-okok clickseo@gmail.com http://www.clickseo.com 목 차 예외처리 2 예외처리 예외처리 C++ 의예외처리 예외클래스와객체 3 예외처리 예외를처리하지않는프로그램 int main() int a, b; cout > a >> b; cout
PowerPoint 프레젠테이션
Web server porting 2 Jo, Heeseung Web 을이용한 LED 제어 Web 을이용한 LED 제어프로그램 web 에서데이터를전송받아타겟보드의 LED 를조작하는프로그램을작성하기위해다음과같은소스파일을생성 2 Web 을이용한 LED 제어 LED 제어프로그램작성 8bitled.html 파일을작성 root@ubuntu:/working/web# vi
PowerPoint 프레젠테이션
UNIX 및실습 8 장. 프로세스와사용자명령 익히기 1 학습목표 유닉스에서프로세스가무엇인지그개념을이해한다. 프로세스와관련된명령의사용방법을익힌다. 포그라운드처리와백그라운드처리의차이를이해한다. 사용자정보를보는명령의사용방법을익힌다. 2 Section 01 프로세스란 프로세스 (process) 현재시스템에서실행중인프로그램 프로세스는고유번호를가진다. Process ID
chap7.key
1 7 C 2 7.1 C (System Calls) Unix UNIX man Section 2 C. C (Library Functions) C 1975 Dennis Ritchie ANSI C Standard Library 3 (system call). 4 C?... 5 C (text file), C. (binary file). 6 C 1. : fopen( )
학번 : 이름 1. 다음프로그램실행결과를예측하시오. $./a.out & [1] 7216 $ kill -USR $ kill -USR 아래학생이작성한쓰레드코드의문제점을설명하시오. void* thread_main() { pthread_mutex_t
학번 : 이름 1. 다음프로그램실행결과를예측하시오. $./a.out & [1] 7216 $ kill -USR1 7216 $ kill -USR2 7216 2. 아래학생이작성한쓰레드코드의문제점을설명하시오. void* thread_main() pthread_mutex_t lock=pthread_mutex_initializer; pthread_mutex_lock(&lock);
Microsoft PowerPoint - Lecture_Note_7.ppt [Compatibility Mode]
Unix Process Department of Computer Engineering Kyung Hee University. Choong Seon Hong 1 유닉스기반다중서버구현방법 클라이언트들이동시에접속할수있는서버 서비스를동시에처리할수있는서버프로세스생성을통한멀티태스킹 (Multitasking) 서버의구현 select 함수에의한멀티플렉싱 (Multiplexing)
C 프로그래밊 개요
구조체 2009 년 5 월 19 일 김경중 강의계획수정 일자계획 Quiz 실습보강 5 월 19 일 ( 화 ) 구조체 Quiz ( 함수 ) 5 월 21 일 ( 목 ) 구조체저녁 6 시 5 월 26 일 ( 화 ) 포인터 5 월 28 일 ( 목 ) 특강 (12:00-1:30) 6 월 2 일 ( 화 ) 포인터 Quiz ( 구조체 ) 저녁 6 시 6 월 4 일 ( 목
Lab 4. 실습문제 (Circular singly linked list)_해답.hwp
Lab 4. Circular singly-linked list 의구현 실험실습일시 : 2009. 4. 6. 담당교수 : 정진우 담당조교 : 곽문상 보고서제출기한 : 2009. 4. 12. 학과 : 학번 : 성명 : 실습과제목적 : 이론시간에배운 Circular Singly-linked list를실제로구현할수있다. 실습과제내용 : 주어진소스를이용해 Circular
Microsoft PowerPoint - chap03-변수와데이터형.pptx
#include int main(void) { int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num %d\n", num); return 0; } 1 학습목표 의 개념에 대해 알아본다.
Microsoft PowerPoint - chap06-2pointer.ppt
2010-1 학기프로그래밍입문 (1) chapter 06-2 참고자료 포인터 박종혁 Tel: 970-6702 Email: jhpark1@snut.ac.kr 한빛미디어 출처 : 뇌를자극하는 C프로그래밍, 한빛미디어 -1- 포인터의정의와사용 변수를선언하는것은메모리에기억공간을할당하는것이며할당된이후에는변수명으로그기억공간을사용한다. 할당된기억공간을사용하는방법에는변수명외에메모리의실제주소값을사용하는것이다.
untitled
Step Motor Device Driver Embedded System Lab. II Step Motor Step Motor Step Motor source Embedded System Lab. II 2 open loop, : : Pulse, 1 Pulse,, -, 1 +5%, step Step Motor (2),, Embedded System Lab. II
Microsoft PowerPoint - chap05-제어문.pptx
int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); 1 학습목표 제어문인,, 분기문에 대해 알아본다. 인 if와 switch의 사용 방법과 사용시 주의사항에 대해 알아본다.
컴파일러
YACC 응용예 Desktop Calculator 7/23 Lex 입력 수식문법을위한 lex 입력 : calc.l %{ #include calc.tab.h" %} %% [0-9]+ return(number) [ \t] \n return(0) \+ return('+') \* return('*'). { printf("'%c': illegal character\n",
C 언어 프로그래밊 과제 풀이
과제풀이 (1) 홀수 / 짝수판정 (1) /* 20094123 홍길동 20100324 */ /* even_or_odd.c */ /* 정수를입력받아홀수인지짝수인지판정하는프로그램 */ int number; printf(" 정수를입력하시오 => "); scanf("%d", &number); 확인 주석문 가필요한이유 printf 와 scanf 쌍
UI TASK & KEY EVENT
KEY EVENT & STATE 구현 2007. 1. 25 PLATFORM TEAM 정용학 차례 Key Event HS TASK UI TASK LONG KEY STATE 구현 소스코드및실행화면 질의응답및토의 2 KEY EVENT - HS TASK hs_task keypad_scan_keypad hs_init keypad_pass_key_code keypad_init
1장. 유닉스 시스템 프로그래밍 개요
9 장. 파이프 Unix 프로그래밍및실습 1 강의내용 1 절개요 2 절이름없는파이프 3 절이름있는파이프 http://lily.mmu.ac.kr/lecture/13u2/ch09.pdf 책에나온내용반드시 man 으로확인할것! UNIX, LINUX 등시스템마다차이가있을수있음을반드시인식 2 기본실습 #1 [ 예제 9-1] ~ [ 예제 9-7] ( 각 10점 ) 과제개요
기술문서 LD_PRELOAD 와공유라이브러리를사용한 libc 함수후킹 정지훈
기술문서 LD_PRELOAD 와공유라이브러리를사용한 libc 함수후킹 정지훈 binoopang@is119.jnu.ac.kr Abstract libc에서제공하는 API를후킹해본다. 물론이방법을사용하면다른라이브러리에서제공하는 API들도후킹할수있다. 여기서제시하는방법은리눅스후킹에서가장기본적인방법이될것이기때문에후킹의워밍업이라고생각하고읽어보자 :D Content 1.
Microsoft PowerPoint - ch07 - 포인터 pm0415
2015-1 프로그래밍언어 7. 포인터 (Pointer), 동적메모리할당 2015 년 4 월 4 일 교수김영탁 영남대학교공과대학정보통신공학과 (Tel : +82-53-810-2497; Fax : +82-53-810-4742 http://antl.yu.ac.kr/; E-mail : ytkim@yu.ac.kr) Outline 포인터 (pointer) 란? 간접참조연산자
제 14 장포인터활용 유준범 (JUNBEOM YOO) Ver 본강의자료는생능출판사의 PPT 강의자료 를기반으로제작되었습니다.
제 14 장포인터활용 유준범 (JUNBEOM YOO) Ver. 2.0 jbyoo@konkuk.ac.kr http://dslab.konkuk.ac.kr 본강의자료는생능출판사의 PPT 강의자료 를기반으로제작되었습니다. 이번장에서학습할내용 이중포인터란무엇인가? 포인터배열 함수포인터 다차원배열과포인터 void 포인터 포인터는다양한용도로유용하게활용될수있습니다. 2 이중포인터
Microsoft PowerPoint - chap04-연산자.pptx
int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); } 1 학습목표 수식의 개념과 연산자, 피연산자에 대해서 알아본다. C의 를 알아본다. 연산자의 우선 순위와 결합 방향에
Microsoft PowerPoint - Chapter_09.pptx
프로그래밍 1 1 Chapter 9. Structures May, 2016 Dept. of software Dankook University http://embedded.dankook.ac.kr/~baeksj 구조체의개념 (1/4) 2 (0,0) 구조체 : 다양한종류의데이터로구성된사용자정의데이터타입 복잡한자료를다루는것을편하게해줌 예 #1: 정수로이루어진 x,
SYN flooding
Hacking & Security Frontier SecurityFirst SYN flooding - SYN flooding 공격의원리와코드그리고대응 by amur, myusgun, leemeca 2008. 09. myusgun Agenda 개요...3 원리...3 위협...4 잠깐! - 문서에관하여...4 이문서는...4 Code...4 대응방안...4 소스코드...5
제1장 Unix란 무엇인가?
1 소켓 2 1 소켓 클라이언트 - 서버모델 네트워크응용프로그램 클리이언트 - 서버모델을기반으로동작한다. 클라이언트 - 서버모델 하나의서버프로세스와여러개의클라이언트로구성된다. 서버는어떤자원을관리하고클라이언트를위해자원관련서비스를제공한다. 3 소켓의종류 소켓 네트워크에대한사용자수준의인터페이스를제공 소켓은양방향통신방법으로클라이언트 - 서버모델을기반으로프로세스사이의통신에매우적합하다.
구조체정의 자료형 (data types) 기본자료형 (primitive data types) : char, int, float 등과같이 C 언어에서제공하는자료형. 사용자정의자료형 (user-defined data types) : 다양한자료형을묶어서목적에따라새로운자료형을
(structures) 구조체정의 구조체선언및초기화 구조체배열 구조체포인터 구조체배열과포인터 구조체와함수 중첩된구조체 구조체동적할당 공용체 (union) 1 구조체정의 자료형 (data types) 기본자료형 (primitive data types) : char, int, float 등과같이 C 언어에서제공하는자료형. 사용자정의자료형 (user-defined
< E20C6DFBFFEBEEE20C0DBBCBAC0BB20C0A7C7D12043BEF0BEEE20492E707074>
Chap #2 펌웨어작성을위한 C 언어 I http://www.smartdisplay.co.kr 강의계획 Chap1. 강의계획및디지털논리이론 Chap2. 펌웨어작성을위한 C 언어 I Chap3. 펌웨어작성을위한 C 언어 II Chap4. AT89S52 메모리구조 Chap5. SD-52 보드구성과코드메모리프로그래밍방법 Chap6. 어드레스디코딩 ( 매핑 ) 과어셈블리어코딩방법
중간고사
중간고사 예제 1 사용자로부터받은두개의숫자 x, y 중에서큰수를찾는알고리즘을의사코드로작성하시오. Step 1: Input x, y Step 2: if (x > y) then MAX
윤성우의 열혈 TCP/IP 소켓 프로그래밍
C 프로그래밍프로젝트 Chap 22. 구조체와사용자정의자료형 1 2013.10.10. 오병우 컴퓨터공학과 구조체의정의 (Structure) 구조체 하나이상의기본자료형을기반으로사용자정의자료형 (User Defined Data Type) 을만들수있는문법요소 배열 vs. 구조체 배열 : 한가지자료형의집합 구조체 : 여러가지자료형의집합 사용자정의자료형 struct
untitled
while do-while for break continue while( ) ; #include 0 i int main(void) int meter; int i = 0; while(i < 3) meter = i * 1609; printf("%d %d \n", i, meter); i++; return 0; i i< 3 () 0 (1)
Microsoft PowerPoint - chap12-고급기능.pptx
#include int main(void) int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); return 0; 1 학습목표 가 제공하는 매크로 상수와 매크로
PowerPoint 프레젠테이션
Chapter 08 함수 01 함수의개요 02 함수사용하기 03 함수와배열 04 재귀함수 함수의필요성을인식한다. 함수를정의, 선언, 호출하는방법을알아본다. 배열을함수의인자로전달하는방법과사용시장점을알아본다. 재귀호출로해결할수있는문제의특징과해결방법을알아본다. 1.1 함수의정의와기능 함수 (function) 특별한기능을수행하는것 여러가지함수의예 Page 4 1.2
<4D F736F F F696E74202D20B8B6C0CCC5A9B7CEC7C1B7CEBCBCBCAD202834C1D6C2F7207E2038C1D6C2F729>
8주차중간고사 ( 인터럽트및 A/D 변환기문제및풀이 ) Next-Generation Networks Lab. 외부입력인터럽트예제 문제 1 포트 A 의 7-segment 에초시계를구현한다. Tact 스위치 SW3 을 CPU 보드의 PE4 에연결한다. 그리고, SW3 을누르면하강 에지에서초시계가 00 으로초기화된다. 동시에 Tact 스위치 SW4 를 CPU 보드의
제1장 Unix란 무엇인가?
4 장파일 컴퓨터과학과박환수 1 2 4.1 시스템호출 컴퓨터시스템구조 유닉스커널 (kernel) 하드웨어를운영관리하여다음과같은서비스를제공 파일관리 (File management) 프로세스관리 (Process management) 메모리관리 (Memory management) 통신관리 (Communication management) 주변장치관리 (Device
Microsoft PowerPoint - [2009] 02.pptx
원시데이터유형과연산 원시데이터유형과연산 원시데이터유형과연산 숫자데이터유형 - 숫자데이터유형 원시데이터유형과연산 표준입출력함수 - printf 문 가장기본적인출력함수. (stdio.h) 문법 ) printf( Test printf. a = %d \n, a); printf( %d, %f, %c \n, a, b, c); #include #include
(Asynchronous Mode) ( 1, 5~8, 1~2) & (Parity) 1 ; * S erial Port (BIOS INT 14H) - 1 -
(Asynchronous Mode) - - - ( 1, 5~8, 1~2) & (Parity) 1 ; * S erial Port (BIOS INT 14H) - 1 - UART (Univ ers al As y nchronous Receiver / T rans mitter) 8250A 8250A { COM1(3F8H). - Line Control Register
0. 표지에이름과학번을적으시오. (6) 1. 변수 x, y 가 integer type 이라가정하고다음빈칸에 x 와 y 의계산결과값을적으시오. (5) x = (3 + 7) * 6; x = 60 x = (12 + 6) / 2 * 3; x = 27 x = 3 * (8 / 4
Introduction to software design 2012-1 Final 2012.06.13 16:00-18:00 Student ID: Name: - 1 - 0. 표지에이름과학번을적으시오. (6) 1. 변수 x, y 가 integer type 이라가정하고다음빈칸에 x 와 y 의계산결과값을적으시오. (5) x = (3 + 7) * 6; x = 60 x
untitled
int i = 10; char c = 69; float f = 12.3; int i = 10; char c = 69; float f = 12.3; printf("i : %u\n", &i); // i printf("c : %u\n", &c); // c printf("f : %u\n", &f); // f return 0; i : 1245024 c : 1245015
Chapter 4. LISTS
6. 동치관계 (Equivalence Relations) 동치관계 reflexive, symmetric, transitive 성질을만족 "equal to"(=) 관계는동치관계임. x = x x = y 이면 y = x x = y 이고 y = z 이면 x = z 동치관계를이용하여집합 S 를 동치클래스 로분할 동일한클래스내의원소 x, y 에대해서는 x y 관계성립
Microsoft PowerPoint - chap6 [호환 모드]
제 6 장프로세스 (Process) 숙대창병모 1 내용 프로세스시작 / 종료 명령중인수 / 환경변수 메모리배치 / 할당 비지역점프 숙대창병모 2 프로세스시작 / 종료 숙대창병모 3 Process Start Kernel exec system call user process Cstart-up routine call return int main(int argc,
int main(void) int a; int b; a=3; b=a+5; printf("a : %d \n", a); printf("b : %d \n", b); a b 3 a a+5 b &a(12ff60) &b(12ff54) 3 a 8 b printf(" a : %x \
? 1 int main(void) int a; int b; a=3; b=a+5; printf("a : %d \n", a); printf("b : %d \n", b); a b 3 a a+5 b &a(12ff60) &b(12ff54) 3 a 8 b printf(" a : %x \n", &a); printf(" b : %x \n", &b); * : 12ff60,
10.
10. 10.1 10.2 Library Routine: void perror (char* str) perror( ) str Error 0 10.3 10.3 int fd; /* */ fd = open (filename, ) /*, */ if (fd = = -1) { /* */ } fcnt1 (fd, ); /* */ read (fd, ); /* */ write