argumenty wiersza poleceń: getopt

Podobne dokumenty
Funkcje zawarte w bibliotece < io.h >

Funkcje zawarte w bibliotece < io.h >

Biblioteka standardowa - operacje wejścia/wyjścia

Wskaźniki do funkcji. Wykład 11. Podstawy programowania ( język C ) Wskaźniki do funkcji (1) Wskaźniki do funkcji (2)

Laboratorium Systemów Operacyjnych. Ćwiczenie 4. Operacje na plikach

Języki programowania. Karolina Mikulska-Rumińska Pokój 573, tel Konsultacje wtorek 9-10.

ISO/ANSI C dostęp do plików ISO/ANSI C. ISO/ANSI C dostęp do plików. ISO/ANSI C dostęp do plików. ISO/ANSI C dostęp do plików

Obsługa plików. Laboratorium Podstaw Informatyki. Kierunek Elektrotechnika. Laboratorium Podstaw Informatyki Strona 1. Kraków 2013

Operacje na plikach. Informatyka. Standardowe strumienie wejścia i wyjścia

ISO/ANSI C dostęp do plików ISO/ANSI C. ISO/ANSI C dostęp do plików. ISO/ANSI C dostęp do plików. ISO/ANSI C dostęp do plików

Pliki. Informacje ogólne. Obsługa plików w języku C

Pliki. Funkcje tworzące pliki i operujące na nich opisane są w części 2 pomocy systemowej. Tworzenie i otwieranie plików:

Ćwiczenie 4. Obsługa plików. Laboratorium Podstaw Informatyki. Kierunek Elektrotechnika. Laboratorium Podstaw Informatyki Strona 1.

Program wykonujący operację na plikach powinien zachować schemat działania zapewniający poprawną pracę:

Łącza nienazwane(potoki) Łącza nienazwane mogą być używane tylko pomiędzy procesami ze sobą powiązanymi.

Wstęp do programowania INP001213Wcl rok akademicki 2017/18 semestr zimowy. Wykład 12. Karol Tarnowski A-1 p.

Programowanie w językach wysokiego poziomu

INFORMATYKA Studia Niestacjonarne Elektrotechnika

Programowanie proceduralne INP001210WL rok akademicki 2018/19 semestr letni. Wykład 6. Karol Tarnowski A-1 p.

Laboratorium z systemów operacyjnych. System plików - funkcje systemowe. Anna Wojak

Wykład VI. Programowanie. dr inż. Janusz Słupik. Gliwice, Wydział Matematyki Stosowanej Politechniki Śląskiej. c Copyright 2014 Janusz Słupik

۰ Elementem jednostkowym takiego pliku jest bajt. ۰ Format pliku binarnego: [bajty pliku][eof]

Podstawy programowania w języku C++

Pliki. Informacje ogólne. Obsługa plików w języku C

Programowanie Proceduralne

Funkcje. czyli jak programować proceduralne. Programowanie Proceduralne 1

Obsługa plików. Systemy Operacyjne 2 laboratorium. Mateusz Hołenko. 25 września 2011

Języki i metodyka programowania. Typy, operatory, wyrażenia. Wejście i wyjście.

Plik jest reprezentowany przez strumień znaków (bajtów) o zmiennej długości. Koniec strumienia identyfikowany jest znacznikiem końca pliku EOF.

Programowanie proceduralne INP001210WL rok akademicki 2015/16 semestr letni. Wykład 6. Karol Tarnowski A-1 p.

Ghost in the machine

Formatowane (tekstowe) wejście/wyjście. Binarne wejście/wyjście.

W języku C każdy plik fizyczny jest ciągiem bajtów, z których każdy może być niezależnie odczytany. Borland 01234

Funkcje matematyczne w C. Programowanie w C Marek Pudełko

Stałe. Funkcje standardowe. Niektóre stałe i funkcje z pliku nagłówkowego math.h. M_E M_LOG2E M_LOG10E M_LN2 M_LN10 M_PI M_PI_2

Argumenty wywołania programu, operacje na plikach

Podstawy programowania w języku C++

wer. 7 z drobnymi modyfikacjami Wojciech Myszka :48:

7 Przygotował: mgr inż. Maciej Lasota

Funkcje. czyli jak programować proceduralne. Programowanie Proceduralne 1

Języki programowania. Przetwarzanie plików amorficznych Konwencja języka C. Część siódma. Autorzy Tomasz Xięski Roman Simiński

wykład III uzupełnienie notatek: dr Jerzy Białkowski Programowanie C/C++ Język C - zarządzanie pamięcią, struktury,

Podstawy programowania w języku C++

OPERACJE WEJŚCIA / WYJŚCIA. wysyła sformatowane dane do standardowego strumienia wyjściowego (stdout)

ISO/ANSI C - funkcje. Funkcje. ISO/ANSI C - funkcje. ISO/ANSI C - funkcje. ISO/ANSI C - funkcje. ISO/ANSI C - funkcje

3 Przygotował: mgr inż. Maciej Lasota

Stałe i zmienne znakowe. Stała znakowa: znak

Operacje powiązane z systemem:

dynamiczny przydział pamięci calloc() memset() memcpy( ) (wskaźniki!! )

Strumienie i pliki. Programowanie Proceduralne 1

Pliki. Operacje na plikach w Pascalu

PRZYKŁADY OPERACJI PLIKOWYCH z wykorzystaniem biblioteki <stdio.h>

Temat zajęć: Obsługa systemu plików.

#include <stdio.h> int main( ) { int x = 10; long y = 20; double s; s = x + y; printf ( %s obliczen %d + %ld = %f, Wynik, x, y, s ); }

Podstawy programowania w języku C++

Programowanie w językach

1. Wprowadzanie danych z klawiatury funkcja scanf

#include <stdio.h> void main(void) { int x = 10; long y = 20; double s; s = x + y; printf ( %s obliczen %d + %ld = %f, Wynik, x, y, s ); }

Tablice, funkcje - wprowadzenie

Zmienne, stałe i operatory

Stałe, znaki, łańcuchy znaków, wejście i wyjście sformatowane

Pobieranie argumentów wiersza polecenia

Lekcja 10. Uprawnienia. Dołączanie plików przy pomocy funkcji include() Sprawdzanie, czy plik istnieje przy pmocy funkcji file_exists()

Wstęp do Programowania, laboratorium 02

Programowanie Procedurale. Pliki w języku C++

PODSTAW PROGRAMOWANIA WYKŁAD 7 ŁAŃCUCHY

Języki i metody programowania I

Operacje na plikach (niskiego poziomu) < IO.H >

Łącza nienazwane(potoki)

MATERIAŁY POMOCNICZE PODSTAWY PROGRAMOWANIA Na podstawie: Programowanie w C - Stworzone na Wikibooks, bibliotece wolny podręczników

Temat: Dynamiczne przydzielanie i zwalnianie pamięci. Struktura listy operacje wstawiania, wyszukiwania oraz usuwania danych.

Katedra Elektrotechniki Teoretycznej i Informatyki. wykład 9 - sem.iii. Dr inż. M. Czyżak

Liczby pseudolosowe. #include <stdio.h> #include <stdlib.h> int main() { printf("%d\n", RAND_MAX); return 0; }

Wykład PASCAL - Pliki tekstowe

Ćwiczenie nr 6. Poprawne deklaracje takich zmiennych tekstowych mogą wyglądać tak:

Katedra Elektrotechniki Teoretycznej i Informatyki. wykład 7- sem.iii. M. Czyżak

2 Przygotował: mgr inż. Maciej Lasota

Instrukcja do laboratorium Systemów Operacyjnych (semestr drugi)

Wstęp do programowania INP003203L rok akademicki 2018/19 semestr zimowy. Laboratorium 2. Karol Tarnowski A-1 p.

1 Podstawy c++ w pigułce.

1 Podstawy c++ w pigułce.

Programowanie Proceduralne

Podstawy programowania. Wykład: 9. Łańcuchy znaków. dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD

Pliki w C/C++ Przykłady na podstawie materiałów dr T. Jeleniewskiego

Część 4 życie programu

ISO/ANSI C dostęp do plików ISO/ANSI C. ISO/ANSI C dostęp do plików. ISO/ANSI C dostęp do plików. ISO/ANSI C dostęp do plików

4. Pliki Informacje ogólne o dostępie do plików w PHP Sprawdzanie istnienia pliku file_exists()

METODY I JĘZYKI PROGRAMOWANIA PROGRAMOWANIE STRUKTURALNE. Wykład 02

Wskaźniki w C. Anna Gogolińska

Języki programowania. Tablice struktur, pliki struktur. Część ósma. Autorzy Tomasz Xięski Roman Simiński

Laboratorium 6: Ciągi znaków. mgr inż. Leszek Ciopiński dr inż. Arkadiusz Chrobot dr inż. Grzegorz Łukawski

int tab[5]; tab[1]; ciągły obszar pamięci, w którym umieszczone są elementy tego samego typu macierz [ ] - dwuargumentowy operator indeksowania

Ćwiczenie 2 Wczytywanie i zapisywanie do plików tekstowych

Języki programowania wysokiego poziomu. PHP cz.2.

Uzupełnienie dot. przekazywania argumentów

Podstawy programowania. Wykład Pętle. Tablice. Krzysztof Banaś Podstawy programowania 1

Pliki wykład 2. Dorota Pylak

Spis treści PLIKI BINARNE W JĘZYKU C. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu. Numer ćwiczenia INF23

iii. b. Deklaracja zmiennej znakowej poprzez podanie znaku

Transkrypt:

argumenty wiersza poleceń: getopt #include <stdio.h> /* getopt2.c getopt2.c */ #include <stdlib.h> #include <unistd.h> { int main(int argc, char *argv[]) int n; int opt; printf("\n argc=%d\n",argc); for(n=0;n<argc;++n) { printf(" *argv[%d] %s\n",n, argv[n]); } printf("\n"); while( (opt=getopt(argc,argv,"a:b:c:"))!= -1 ) { switch (opt) { case 'a' : printf("case \'a\'\n"); printf(" optarg=%s=\n",optarg); break; case 'b' : printf("case \'b\'\n"); printf(" optarg=%s=\n",optarg); break; case 'c' : printf("case \'c\'\n"); printf(" optarg=%s=\n",optarg); break; } } 1 } /* koniec main */

instrukcje wejścia/wyjścia Plik (angielski termin: file) to zbiór powiązanych ze sobą danych. Pojęcie pierwotne i zapewne dlatego (również w informatyce) nieprecyzyjnie zdefiniowane. Dla pracujących na komputerach o strukturze bajtowej pamięci, plik to ciąg bajtów. Gdzie plik może być przechowywany (może istnieć); pamięć operacyjna, dyski magnetyczne, taśmy magnetyczne, terminal, tasiemka papierowa, karty perforowane, dysk optyczny (CD) ; ogólnie nośniki nośniki trwałe, nośniki chwilowe 2

instrukcje wejścia/wyjścia czy ma sens program, który podczas wykonania nie modyfikuje plików ani nie tworzy nowych? mało prawdopodobne...by taki program był przydatny Skoro tak, to program powinien mieć możliwość zapisywania/modyfikowania plików, również w celu wymiany ich z innymi programami 3

instrukcje wejścia/wyjścia buforowane operacje wyjścia/wejścia WE/WY (czym się ryzykuje w razie buforowania WE/WY? ) niebuforowane operacje wyjścia/wejścia (każde wywołanie WE/WY stanowi obciążenie; buforowanie minimalizuje to obciążenie) Ważne: w <stdio.h> są deklaracje struktur i funkcje do wykonywania operacji na plikach. 4

instrukcje wejścia/wyjścia...rozpoczniemy od przeglądu buforowanych operacji wyjścia/wejścia... 5

instrukcje wejścia/wyjścia Otwarcie pliku przy użyciu funkcji fopen #include <stdio.h> FILE * wsk; /* wskaźnik do obiektu typu FILE */... /* nazywany również zmienną plikową */... wsk = fopen( nazwa, tryb_otwarcia); nowy.dat ; fopen( nowy.dat, r ); char buf[]= nowy.dat ; fopen(buf, r ); 6

instrukcje wejścia/wyjścia fopen tryb_otwarcia: read write binary r otwarcie tylko do czytania w otwarcie tylko do pisania; jeśli plik istnieje zostanie obcięty do długości zero a otwarcie do dopisywania (append) ; jeśli zbioru nie ma, zostanie utworzony r+ otwarcie istniejącego zbioru do czytania i pisania (ustawienie na początek pliku) 7

instrukcje wejścia/wyjścia fopen w+ otwarcie do czytania i pisania; jeśli plik istnieje zostanie obcięty do pliku o długości zero; jeśli nie istnieje, zostanie utworzony a+ otwarcie lub utworzenie pliku do czytania i pisania; jeśli plik istnieje, jego początkowa zawartość nie jest modyfikowana; początkową pozycją do czytania jest początek pliku, zapisywane jest na końcu pliku; jeśli pliku nie ma to zostanie utworzony b plik binarny (dla systemu UNIX/LINUX w zasadzie jest to bez znaczenia) 8

instrukcje wejścia/wyjścia fopen x istnieje dodatkowo w gcc, zgłasza żądanie by zbiór był utworzony na nowo możliwe kombinacje rb wx wb+ 9

instrukcje wejścia/wyjścia W pliku stdio.h jest zdefiniowana stała symboliczna EOF, używana jako znacznik błędu albo końca pliku. W systemach UNIX/LINUX zewnętrzna zmienna całkowita errno informuje o przyczynie błędu (aby ta informacja była dostępna, trzeba dołączyć #include <errno.h> ) 10

zeruje znacznik błędu FILE * wsk; int clearerr (wsk); instrukcje wejścia/wyjścia clearerr funkcja ta zeruje także znacznik końca pliku 11

zamyka plik FILE * wsk; int fclose(wsk); instrukcje wejścia/wyjścia fclose Daje w wyniku: EOF, gdy wystąpił błąd lub 0 w przeciwnym przypadku 12

instrukcje wejścia/wyjścia feof daje w wyniku TRUE, gdy napotkano koniec pliku FILE * wsk; int feof(wsk); 13

#include <stdio.h> #include <stdlib.h> int main() { FILE * fp1; int n=0; przykład feof() fp1 = fopen("1.dat","r"); 14

przykład feof() while(!feof(fp1) ) { char c; c=getc(fp1); printf("%c %d feof=%d\n", c,c,feof(fp1) ); /* clearerr(fp1); */ } } /* koniec funkcji main */ 15

instrukcje wejścia/wyjścia ferror daje w wyniku TRUE, gdy wystąpił błąd operacji na pliku FILE * wsk; int ferror(wsk); (chodzi o ostatnią operację na pliku, niezależnie od tego kiedy była wykonana) uwaga: koniec pliku nie jest błędem operacji na pliku! 16

przykład ferror() #include <stdio.h> #include <stdlib.h> int main() { FILE * fp1; int n=0; fp1 = fopen("1.dat","r"); 17

przykład ferror() while(!feof(fp1) ) { char c; } c=getc(fp1); printf("%c %d feof=%d ferror=%d\n", c, c, feof(fp1), ferror(fp1) ); /* clearerr(fp1); */ } /* koniec funkcji main */ 18

wymusza zapisanie bufora FILE * wsk; int fflush(wsk); instrukcje wejścia/wyjścia fflush Daje w wyniku EOF, gdy wystąpił błąd lub 0 w przeciwnym razie. Funkcja fflush zapewnia, że dane są rzeczywiście zapisane do pliku. Funkcje wyjścia nie piszą do pliku, lecz tylko umieszczają dane w buforze. Nie można zakładać, że w momencie kraksy zadania bufor zostanie zapisany do pliku tylko dlatego, że użyto np. funkcji fputc. 19

instrukcje wejścia/wyjścia fgetc czyta kolejny znak z pliku FILE * wsk; int fgetc (wsk); Daje w wyniku kod wczytanego znaku albo EOF, jeżeli wystąpił błąd lub koniec pliku. Uwaga: fgetc zwraca typ int, a nie typ char!! 20

czyta znaki z pliku FILE * wsk; char * ciąg; int n; char * fgets( ciąg, n, wsk); instrukcje wejścia/wyjścia fgets Zwraca adres ciągu przy poprawnym wykonaniu lub NULL, gdy np.. pierwszym odczytanym znakiem jest koniec pliku. Przestaje działać po odczytaniu n-1 znaków lub po napotkaniu \n lub EOF. Znak nowego wiersza \n jest zapamiętywany w ciągu. Po ostatnim odczytanym znaku jest dodawany znak końca łancucha znakowego \0. 21

instrukcje wejścia/wyjścia fileno Daje w wyniku deskryptor pliku. FILE * wsk; int fileno (wsk); Całkowitoliczbowe deskryptory plików są używane tylko w niebuforowanych funkcjach WE/WY. fileno jest przydatne, gdy do tego samego pliku chcemy po jego jednorazowym otwarciu pisać i w sposób buforowany, i w sposób niebuforowany 22

instrukcje wejścia/wyjścia fileno #include <stdio.h> #include <stdlib.h> FILE * fp; int main( ) { char buf[10]="karakorum"; int n; fp=fopen("nic.dat","w+"); if(fp==null) printf("blad otwarcia!!\n"); fprintf(fp,"eureka...\n"); fprintf(fp,"eureka2...\n"); fflush(fp); printf("\n fileno = %d\n", fileno(fp) ); write( fileno(fp), buf, 7); /* niebuforowana instrukcja WY */ fprintf(fp,"\n"); exit(0); } /* koniec main */ 23

Eureka... Eureka2... Karakor instrukcje wejścia/wyjścia fileno poniżej zawartość utworzonego zbioru nic.dat ale gdyby nie było fflush( ), to byłoby KarakorEureka... Eureka2... czyli zafałszowana kolejność zapisów do pliku nic.dat 24

instrukcje wejścia/wyjścia fileno /* dygresja: można inaczej uzyskać deskryptor */ /* bez korzystania z funkcji fileno( ) */ FILE * fp; printf("\n fileno = %d\n", fileno(fp) ); /* lub */ printf("\n fileno = %d\n", fp->_fileno ); /* struktura FILE ma pole _fileno */ 25

instrukcje wejścia/wyjścia fprintf Zapisuje argumenty do pliku FILE *wsk; char * format; int fprintf(wsk, format, argument,...); Funkcja fprintf używa tego samego sposobu formatowania co printf i sprintf. printf pisze do pliku stdout, fprintf do zadanego pliku, a sprintf do łańcucha znakowego (tworzy ciąg znaków) 26

zapisuje znak do pliku FILE * wsk; char c; int fputc(c, wsk); instrukcje wejścia/wyjścia fputc Jako wynik zwraca 0 przy poprawnym działaniu lub EOF, gdy wystąpił błąd. Parametr fputc jst typu char, podczas gdy analogiczna funkcja wejścia fgetc daje w wyniku wczytany znak w postaci liczby całkowitej typu int. 27

instrukcje wejścia/wyjścia fputs Zapisuje ciąg znaków do pliku. FILE *wsk; char * ciąg; int fputs(ciąg,wsk); Wartość zwracana to 0 przy poprawnym zadziałaniu, gdy wystąpił błąd to zwracana jest wartość EOF. 28

instrukcje wejścia/wyjścia fread czyta bloki danych z pliku do tablicy znaków (bezformatowo binarnie) FILE * wsk; int n1, n2; void * ciąg; int fread(ciąg, n1,n2,wsk); Czyta n1*n2 bajtów. Zalecane jest by używać fread z n1=1. Wartość zwracana: liczba wczytanych bloków n2 bądź EOF. 29

Zamyka plik i otwiera inny. instrukcje wejścia/wyjścia freopen FILE * wsk; char * nazwa_pliku; char * tryb_otwarcia; FILE * freopen(nazwa_pliku, tryb_otwarcia, wsk); Daje w wyniku EOF, gdy wystąpił błąd. freopen zamyka plik skojarzony ze wskaźnikiem wsk i otwiera plik o nazwie nazwa_pliku. 30

Czyta argumenty z pliku. FILE * wsk; char * format; instrukcje wejścia/wyjścia fscanf int fscanf(wsk, format, argument,...); Wartość zwracano to liczba odczytanych argumentów lub EOF, gdy wystąpił błąd. fscanf czyta z zadanego pliku scanf czyta z pliku stdin sscanf czyta z łańcucha znakowego (przetwarza ciąg znaków) 31

instrukcje wejścia/wyjścia fseek Zmienia bieżącą pozycję pliku. FILE * wsk; int odstęp; int początek; int fseek(wsk, odstęp, początek); Wartość zwracana: 0 przy poprawnym działaniu, inna liczba gdy wystąpił błąd. Oto jak ustawia pozycję pliku: początek bieżąca pozycja ustawiona na 0 odstęp bajtów 1 bieżąca pozycja + odstęp bajtów 2 koniec pliku + odstęp bajtów 32

instrukcje wejścia/wyjścia ftell Zwraca przesunięcie w bajtach od początku pliku do bieżącej pozycji. FILE * wsk; long ftell(wsk); Jeśli wystąpił błąd, to wartościa zwracaną jest -1L. 33

instrukcje wejścia/wyjścia fwrite Zapisuje bloki danych do pliku (działa odwrotnie do fread, oczywiście jest funkcją bezformatową binarną) FILE *wsk; void * ciąg; int n1; int n2; int fwrite(ciag, n1, n2, wsk); /* n1 to liczba bajtów w bloku, n2 to liczba bloków */ fwrite zapisuje n2 bloków danych z ciągu do pliku wskazywanego przez wsk. Powinna zwrócić n2; każda inna wartość oznacza błąd. Zalecane jest używanie z n1=1. 34

instrukcje wejścia/wyjścia getc Czyta kolejny znak z pliku. FILE * wsk; int getc(wsk); Daje w wyniku kod wczytanego znaki (ASCII) albo EOF, gdy wystąpił błąd lub koniec pliku. 35

instrukcje wejścia/wyjścia getchar czyta kolejny znak z pliku stdin int getchar(); Wartość zwracana to kod wczytanego znaku albo EOF, gdy wystąpił błąd, np. koniec pliku. 36

instrukcje wejścia/wyjścia gets czyta znaki z pliku stdin do ciągu znaków (czyta łańcuch znakowy) char * gets( char * ciąg); Wartość zwracana to wskaźnik do łańcucha znakowego albo NULL, gdy wystąpił błąd, np. gdy pierwszym wczytanym znakiem jest znak końca pliku. uwagi: czyta do najbliższego znaku \n, lecz w przeciwieństwie do fgets() nie przepisuje go! 37

instrukcje wejścia/wyjścia getw czyta słowo (tzn. liczbę całkowitą) z pliku FILE * wsk; int getw(wsk); Zwraca wczytaną liczbę całkowitą lub EOF, gdy wystąpił błąd. Ze względu na to, że EOF jest dopuszczalną liczbą całkowitą, należy użyć feof i ferror, aby sprawdzić czy nastąpił bląd. 38

instrukcje wejścia/wyjścia printf zapisuje argumenty do pliku stdout char * format; int printf(format, argument,...); Wartość zwracana to 0 przy poprawnym działaniu lub EOF, gdy wystąpił błąd. /* fprintf jest podobna do printf fprintf(stdout,format,argument,...); */ 39

instrukcje wejścia/wyjścia putc Zapisuje znak do pliku. FILE * wsk; char c; int putc(c, wsk); Daje w wyniku kod zapisanego znaku lub EOF, gdy wystąpił błąd. 40

Zapisuje znak do pliku stdout char c; int putchar(c); instrukcje wejścia/wyjścia putchar Wartość zwracana to kod zapisanego znaku lub EOF, gdy wystąpił błąd. 41

instrukcje wejścia/wyjścia puts Zapisuje ciąg znaków do pliku stdout, kończąc znakiem \n. char * ciąg; int puts( ciąg); Zwraca EOF, gdy nastąpi błąd. puts jest wygodną metodą wypisywania komunikatów do pliku stdout. puts ("This is a message."); 42

instrukcje wejścia/wyjścia putw zapisuje słowo (liczbę całkowitą) do pliku FILE * wsk; int i; int putw(i,wsk); Wartość zwracana to zapisana liczba całkowita lub EOF, gdy wystąpił błąd. Ponieważ EOF jest dopuszczalną liczbą całkowitą, należy użyć feof i ferror, aby sprawdzić czy wystąpił błąd. 43

instrukcje wejścia/wyjścia scanf Czyta argumenty z pliku stdin. char * format; int scanf(format, argument...); Wartość zwracana to liczba odczytanych argumentów lub EOF w przypadku błędu. 44

instrukcje wejścia/wyjścia sscanf Czyta argument (argumenty) z ciągu znaków. char * ciąg; char * format; int sscanf(ciąg, format, argument...); Wartość zwracana to liczba odczytanych argumentów albo w przypadku błędu EOF. Funkcja sscanf używa tego samego mechanizmu formatowania co fscanf i scanf. Różnica między tymi funkcjami polega na tym, że scanf czyta z pliku stdin, fscanf z zadanego pliku, a sscanf przetwarza ciąg znaków 45

instrukcje wejścia/wyjścia tmpfile Tworzy plik tymczasowy i otwiera go do zapisywania FILE * tmpfile(); Wartość zwracana to wskaźnik do FILE lub wskaźnik zerowy NULL, gdy wystąpił błąd. Plik tymczasowy jest usuwany przy zakończeniu programu. FILE * wsk; wsk=tmpfile() ; int rak=7; putw(rak,wsk); fseek(wsk,0,0); 46

instrukcje wejścia/wyjścia ungetc Powoduje wycofanie znaku do pliku, tak że następne wykonanie getc da ponownie ten sam znak. FILE * wsk; int c; int ungetc(c, wsk); Wartość zwracana to znak c (jako wartość ASCII) lub EOF, gdy wystąpił błąd. Tylko jeden znak może być wycofany bez ponownego odczytu. EOF nie może być wycofany. Funkcja fseek anuluje efekty działania ungetc. 47

usuwa plik instrukcje wejścia/wyjścia unlink #include <unistd.h> /* tam jest prototyp funkcji */ int unlink(char * nazwa_pliku); Wartością zwracaną jest 0 lub EOF, jeśli nastąpił błąd. Parametrem funkcji jest nazwa pliku, a nie wskaźnik do FILE. Oznacza to, że nie jest konieczne otwarcie pliku przed jego usunięciem. 48

usuwa kartotekę instrukcje wejścia/wyjścia rmdir #include <unistd.h> /* tam jest prototyp funkcji */ int rmdir(char * nazwa_pliku); Wartością zwracaną jest 0 lub EOF, jeśli nastąpił błąd. Parametrem funkcji jest nazwa kartoteki, a nie wskaźnik do FILE. Kartoteka musi być pusta by mogła być usunięta. 49

instrukcje wejścia/wyjścia remove usuwa plik lub kartotekę #include <stdlib.h> /* tam jest prototyp funkcji */ int remove(char * nazwa); Wartością zwracaną jest 0 lub EOF, jeśli nastąpił błąd. Działa jak unlink dla zbiorów i jak rmdir dla kartotek. 50

instrukcje wejścia/wyjścia rename int rename( char *old, char *new); Funkcja zwraca wartość -1, jeśli będzie błąd. Dodatkowo ustawia kod błedu w zmiennej errno, możliwe wartości to np. ENOENT informujący że plik nie istnieje, czy EACCES informujący że nie ma zezwolenia na dostęp do pliku 51

instrukcje wejścia/wyjścia niebuforowane close creat eof lseek open read tell write (jest ich znacznie mniej niż buforowanych) 52

/* open otwiera zbiór */ #include <fcntl.h> #include <sys/type.h> #include <sys/stat.h> instrukcje wejścia/wyjścia niebuforowane open int open (const char *filename, int flags[, mode_t mode]) open( 22.dat, O_RDONLY, 0664); /* trzeci parametr ma znaczenie w przypadku tworzenia pliku - kod dostępu dla użytkownika, grupy, świata */ 53

instrukcje wejścia/wyjścia niebuforowane open O_RDONLY otwarty do odczytu O_WRONLY otwarty do zapisu O_RDWR otwarty do odczytu i zapisu O_APPEND dodaje nowe dane na końcu pliku O_CREAT tworzy plik O_TRUNC jeśli plik istnieje, jest obcinany do długości zero O_EXCL istnienie pliku to błąd O_BINARY otwarty w trybie binarnym (tylko w systemie WINDOWS) O_TEXT otwarty w trybie tekstowym (tylko w systemie WINDOWS) 54

instrukcje wejścia/wyjścia niebuforowane open O_EXLOCK program dostaje wyłączność na używanie pliku ( exclusive lock ) /* w przypadku błędu open zwraca wartość 1 */ /* dodatkowo następujące warunki błędu dostępne przez errno są dostarczane : */ 55

instrukcje wejścia/wyjścia niebuforowane open EACCES plik istnieje lecz nie można go czytać/pisać po nim jak zażądano we flags ; plik nie istnieje i nie ma zezwolenia na zapis w danej kartotece tak więc plik nie może być utworzony EEXIST jednocześnie O_CREAT oraz O_EXCL są wymienione we flags zaś wymieniony zbiór już istnieje EINTR operacja open została przerwana przez zewnętrzny sygnał EISDIR argument we flags wymaga write access zaś plik jest kartoteką EMFILE zadanie (proces) ma za dużo otwartych plików ENFILE system zbiorów odmawia zezwolenia na otwarcie kolejnego pliku 56

instrukcje wejścia/wyjścia niebuforowane open ENOENT plik o podanej nazwie nie istnieje, zaś we flags nie wymieniono O_CREAT ENOSPC nie można utworzyć nowego pliku, gdyż nie ma miejsca na urządzeniu ( no disk space left ) 57

instrukcje wejścia/wyjścia niebuforowane #include <stdio.h> open #include <stdlib.h> #include <fcntl.h> #include <sys/types.h> #include <sys/stat.h> int main () { char buf[20]="kaskada"; int index; /* to będzie deskryptor pliku*/ index=open("nic.dat",o_rdwr O_TRUNC O_CREAT, 0664); /* do czytania i pisania; jeśli istnieje skróć plik do zera; jeśli plik nie istnieje to go utwórz */ *(buf+7)='\n'; write(index,buf,8); exit(0); } /* koniec main */ 58

instrukcje wejścia/wyjścia niebuforowane open /* jaka będzie zawartość zbioru nic.dat po wykonaniu programu z poprzedniego slajdu? */ 59

instrukcje wejścia/wyjścia niebuforowane S.Oualline, rozdział 14, strona 246 open pisanie/czytanie buforowane i niebuforowane... (deskryptor) (nazwa symboliczna) (przeznaczenie pliku) 0 STDIN_FILENO standardowe wejście 1 STDOUT_FILENO standardowe wyjście 2 STDERR_FILENO standardowa obsługa błędów 60

instrukcje wejścia/wyjścia niebuforowane creat /* tworzy plik */ int creat (const char *filename, mode_t mode) ta postać jest zastępowana przez open (filename, O_WRONLY O_CREAT O_TRUNC, mode) /* co to jest mode? */ 61

instrukcje wejścia/wyjścia niebuforowane close /* zamyka plik */ /* może być konieczne dołączenie #include <unistd.h> */ int close (int deskryptor_pliku); Zwraca wartość 1, gdy wystąpił błąd. Otwarte pliki są zamykane automatycznie w momencie zakończenia programu. Jednak ze względu na możliwość załamania się zadania (systemu) w najmniej odpowiedniej chwili, zaleca się zamykania plików, gdy przestają być wykorzystywane. 62

instrukcje wejścia/wyjścia niebuforowane eof /* sprawdza znacznik końca pliku */ int eof (deskryptor_pliku); Wartość zwracana to 1, gdy wystąpił błąd funkcji eof, 0 gdy nie ma końca pliku oraz 1, gdy wystąpił koniec pliku. uwaga: funkcji eof() często nie ma (np. w gcc) 63

instrukcje wejścia/wyjścia niebuforowane lseek /* zmienia bieżącą pozycję pliku - jak fseek dla buforowanych*/ #include <unistd.h> long lseek (int deskryptor pliku, int odstęp, int początek); Wartością zwracaną jest -1L, gdy wystąpił błąd. początek bieżąca pozycja ustawiona na 0 odstęp bajtów 1 bieżąca pozycja + odstęp bajtów 2 koniec pliku + odstęp bajtów 64

instrukcje wejścia/wyjścia niebuforowane tell /* podaje bieżącą pozycję w pliku - w bajtach */ long tell (int deskryptor_pliku); Daje w wyniku 1, gdy nastąpi błąd 65

instrukcje wejścia/wyjścia niebuforowane read #include <unistd.h> int read (int deskryptor_pliku, void *buffer, int size) ; buffer to wskaźnik do miejsca pamięci, gdzie wczytany ciąg bajtów jest zapisywany; uwaga ciąg bajtów nie jest uzupełniany bajtem zerowym! size ile bajtów wczytać; jeśli nie ma tyle bajtów w zbiorze to wczytanych zostanie odpowiednio mniej Wartość zwracana - liczba przeczytanych bajtów lub 1, gdy nastąpił błąd. 66

instrukcje wejścia/wyjścia niebuforowane write #include <unistd.h> int write (int deskryptor_pliku, void *buffer, int size) ; buffer to wskaźnik do miejsca pamięci skąd pobierany jest ciąg bajtów do zapisania w pliku o deskryptorze deskryptor_pliku; ten ciąg bajtów nie jest uzupełniany bajtem zerowym! Wartość zwracana liczba zapisanych bajtów lub 1, gdy wystąpił błąd. 67

instrukcje WY/WE - uzupełnienie FILE * fdopen (int deskryptor, const char *tryb_otwarcia) fdopen zwraca wskaźnik do FILE, umożliwia zatem dalsze pisanie po pliku w sposób buforowany (gdy wcześniej otwarto plik w sposób niebuforowany przez open i uzyskano deskryptor). Argument tryb_otwarcia jest taki sam jak w przypadku fopen, np. w czy w+. (poznalismy już fileno które działa w przeciwnym kierunku ) 68

pożyteczne funkcje pracujące na pojedynczych znakach #include <ctype.h> Testowanie znaku: int isalnum(int c) prawda jeśli c jest alphanumeryczne int isalpha(int c) prawda jeśli c jest znakiem int isascii(int c) prawda jeśli c jest znakiem ASCII int iscntrl(int c) prawda jeśli c jest znakiem kontrolnym int isdigit(int c) prawda jeśli c jest cyfrą int isgraph(int c) prawda jeśli c jest znakiem graficznym int islower(int c) prawda jeśli c jest małą literą 69

pożyteczne funkcje pracujące na pojedynczych znakach #include <ctype.h> Testowanie znaku: int isprint(int c) prawda jeśli c jest znakiem drukowalnym int ispunct (int c) prawda jeśli c jest znakiem interpunkcyjnym, tj. jest znakiem drukowalnym, nie alfanumeryczny ani spacja int isspace(int c) prawda jeśli c jest znakiem spacja int isupper(int c) prawda jeśli c jest dużą literą int isxdigit(int c) prawda jeśli c jest cyfrą heksadecymalną 70

pożyteczne funkcje pracujące na pojedynczych znakach #include <ctype.h> Konwersja znaku: int toascii(int c) zamienia c na ASCII, poprzez ustawienie bitów nr 8,9,... na zero int tolower(int c) zamienia c na małą literę int toupper(int c) zamienia c na dużą literę 71

errno kod błędu Większość funkcji bibliotecznych zwraca szczególną wartość dla zaznaczenia, że zawiodły. np. 1, zerowy wskaźnik NULL, stałą jak EOF itp.. Mówi to jednak tylko, że zdażył się błąd. Jaki? należy skontrolować jaki kod błędu został zapisany w errno. Zmienna erno jest zadeklarowana w errno.h. Kody błędu są przedstawione w opisach funkcji. Funkcje nie zmieniają wartości errno jeśli błędu nie było. Tym samym wartość errno po udanym zawołaniu funkcji niekoniecznie jest zero! Oczywiście po tym jak funkcja zakończyła się błędnie, można sprawdzić, co zapisane jest w errno; można także wyzerować errno przed zawołaniem funkcji. 72

errno #include <stdio.h> #include <stdlib.h> #include <errno.h> int n; main() { /* rmdir("testowa_kartoteka"); */ n=mkdir("testowa_kartoteka",0774); if(errno==eexist) printf("\n!! EEXIST=%d\n",EEXIST); printf("\n n=%d\n",n); exit(0); } /* koniec funkcji main*/ 73

funkcje matematyczne należy dołączyć plik #include <math.h> oraz w kompilacji dodać pewien klucz gcc program.c -lm abs wartość bezwzględna (zwraca wartość typu int) acos arcus cosinus asin arcus sinus atan arcus tangens 74

funkcje matematyczne atan2 arcus tangens (pewna odmiana) atoi atof przekształca ciąg znaków na liczbę całkowitą przekształca ciąg znaków na liczbę rzeczywistą atol przekształca ciąg znaków na liczbę całkowitą long ceil podaje najmniejszą liczbę całkowitą nie mniejszą niż cos cosinus cosh exp fabs cosinus hiperboliczny e do potęgi argument wartość bezwzględna (zwraca wartość rzeczywistą) 75

floor fmod funkcje matematyczne największa liczba całkowita nie większa od argumentu dzielenie modulo (reszta z dzielenia) log logarytm naturalny log10 logarytm dziesiętny pow potęga pow(a,b) to a do potęgi b sin sinus sinh sqrt sinus hiperboliczny pierwiastek kwadratowy tan tangens tanh tangens hiperboliczny 76

funkcje matematyczne srand48 - służy do inicjalizacji generatora liczb pseudolosowych z przedziału (0., 1.) void srand48 (long int seed) drand48 - generator liczb pseudolosowych z przedziału (0.,1.) double drand48 (void) 77

stałe matematyczne w <math.h> HUGE maksymalna wartość liczby zmiennoprzecinkowej typu float M_E liczba e M_LOG2E logarytm o podstawie 2 z liczby e M_LOG10E logarytm o podstawie 10 z liczby e M_LN2 logarytm naturalny z 2 M_LN10 logarytm naturalny z 10 M_PI π 78

M_PI_2 π /2. M_PI_4 π /4. M_1_PI 1/ π M_2_PI 2/ π stałe matematyczne w <math.h> M_2_SQRTPI 2/ sqrt (π) M_SQRT2 sqrt(2) M_SQRT1_2 1./sqrt(2) MAXFLOAT -- The maximum value of a non-infinite single-precision floating point number. HUGE_VAL - dodatnia nieskończoność 79

struktury danych wskaźnik zerowy NULL NULL 80

struktury danych lista jednokierunkowa 81

odmierzanie odcinków czasu #include <sys/types.h> #include <sys/times.h> main() { struct tms before, after ; times(&before); /*... place code to be timed here... */ times(&after); printf("user time: %ld\n", after.tms_utime - before.tms_utime); printf("system time: %ld\n", after.tms_stime - before.tms_stime); /* czas podany w tikach zegara */ exit(0); } /* koniec funkcji main */ 82

odmierzanie odcinków czasu #include <time.h> clock_t start, end; double cpu_time_used; start = clock();... /* tu program coś robi... */ end = clock(); cpu_time_used = ((double) (end - start)) / CLOCKS_PER_SEC; 83

odmierzanie odcinków czasu funkcja times #include <sys/times.h> struct tms alfa; /* potrzebna definicja obiektu */ struct tms *buffer; buffer=& alfa; clock_t times (struct tms *buffer) /* wywołanie funkcji */ clock_t tms_utime Całkowity czas procesora które proces (zadanie) zużyło na wykonywanie instrukcji procesu clock_t tms_stime czas który procesor zużył na obsługę procesu (funkcja times umieszcza informację o zużytym czasie w *buffer) 84

#include <time.h> odmierzanie odcinków czasu funkcja clock() clock_t clock (void) funkcja ta zwraca bieżący czas CPU; sens ma przede wszystkim różnica wartości zwracanych przez kolejne wywołanie clock() clock_t == int ( == long int ) w przypadku błędu clock() zwraca wartość (clock_t)(-1) 85

odmierzanie odcinków czasu przykład #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <time.h> #include <sys/times.h> #include <math.h> struct tms alfa; 86

odmierzanie odcinków czasu przykład { int main() float sum; long n,m,na,nb; int k; struct tms * buffer; buffer= &alfa; printf(" CLOCKS_PER_SEC %d\n", CLOCKS_PER_SEC); 87

odmierzanie odcinków czasu przykład na= times(buffer); m= clock(); printf("\n pocz. (*buffer).tms_utime %d\n", (*buffer).tms_utime ); printf("\n pocz. (*buffer).tms_stime %d\n", (*buffer).tms_stime ); printf("\n pocz. m=%d clock()\n",m); sum=0.; for(k=0;k<1000*1000*10;++k) sum+= k/1.e5 + exp(-5.+(float)k/1.375e7)+log( (float)k); 88

odmierzanie odcinków czasu przykład nb= times(buffer); n = nb - na; m= clock(); printf("\n (*buffer).tms_utime %d\n", (*buffer).tms_utime ); printf("\n (*buffer).tms_stime %d\n", (*buffer).tms_stime ); printf("\nn=%d nb=%d na=%d\n",n, nb, na); printf("\n m=%d clock()",m); printf("\n"); } /* koniec main */ 89

odmierzanie odcinków czasu przykład CLOCKS_PER_SEC 1000000 pocz. (*buffer).tms_utime 0 pocz. (*buffer).tms_stime 0 pocz. m=469 clock() (*buffer).tms_utime 67 (*buffer).tms_stime 0 n=67 nb=441236179 na=441236112 m=670770 clock() 90

czas CPU (czas kalendarzowy, liczony od jakiegoś zdarzenia) czas procesora (czas zużyty, np. na przeczytanie książki zużyto 7 godzin) (w GNU C wyjątkowo clock() zwraca zużyty system time + user time ) Np. time() zwraca czas kalendarzowy liczony w sekundach od 1 stycznia 1970, godz. 00:00. 91

Czas kalendarzowy w dużej rozdzielczości Można go uzyskać np. używając funkcji gettimeofday int gettimeofday (struct timeval *tp, NULL) struct timeval { time_t tv_sec; /* seconds */ suseconds_t tv_usec; /* microseconds */ }; 92