Poprzedni wykład [ ] :
|
|
- Magdalena Lipińska
- 6 lat temu
- Przeglądów:
Transkrypt
1 Poprzedni wykład [ ] : - Operacje plikowe; pliki binarne i tekstowe - Wejście/wyjście: znakowe, wierszowe, formatowane, i niskopoziomowe ( fukcje: fread / fwrite ) - Dynamiczny przydział pamięci ( malloc / calloc ) - Tablice wskaźników - Wskaźniki na wskaźniki i tablice wielowymiarowe; związek tablic wielowymiarowych z tablicami wskaźników Adam Rycerz [ wyklad09.pdf ] Strona 1 z 36
2 Argumenty wiersza poleceń Systemy operacyjne, w których uruchamiamy skompilowane programy w języku C, umożliwiają przekazywanie parametrów z wiersza poleceń do uruchamianego programu. W chwili wywołania, funkcja main otrzymuje 2 argumenty: pierwszy (typu int ) to liczba parametrów wywołania, zwyczajowo nazywana narg (ang. number of arguments) drugi zwyczajowo argv (ang. argument vector) to tablica wskaźników znakowych, której kolejne komórki przechowują adresy napisów zawierających poszczególne argumenty wpisane w wierszu poleceń [ jak również nazwę programu na początku i wskaźnik pusty na końcu ]. Adam Rycerz [ wyklad09.pdf ] Strona 2 z 36
3 Przykładowo, program echo, który po wypisuje argumenty z wiersza poleceń na standardowe wyjście, po wywołaniu: $ echo ahoj, przygodo otrzyma argument narg o wartości 3 oraz tablicę z elementami argv[0] argv[2] wskazującymi na następujące napisy: [ argv[narg] zawiera zawsze wskaźnik pusty: NULL <=> synonim 0. ] Adam Rycerz [ wyklad09.pdf ] Strona 3 z 36
4 Pierwsza wersja: traktujemy argv jako tablicę wskaźników: #include <stdio.h> /* echo argumentów wywołania: Wersja 1 */ int main(int narg, char *argv[]) { int i; for (i = 1; i < narg; i++) printf( %s%s, argv[i], (i<narg-1)? : ); printf( \n ); } return 0; Adam Rycerz [ wyklad09.pdf ] Strona 4 z 36
5 Druga wersja (zaawansowana) argv to także synonim wskaźnika na wskaźnik znakowy: #include <stdio.h> /* echo argumentów wywołania: Wersja 2 */ int main(int narg, char *argv[]) { while (--narg > 0) printf( %s%s, *++argv, (narg>1)? : ); printf( \n ); return 0; } Adam Rycerz [ wyklad09.pdf ] Strona 5 z 36
6 Bezpośredniu po uruchomieniu programu (<=> wywołaniu funkcji main) wartość argv wskazuje na pierwszy element (argv[0]) w tablicy wskaźników (powiązany z napisem: echo ). Operacja zwiększenia wskaźnika o 1 (++argv) przesuwa wskaźnik z elementu argv[0] do elementu argv[1]. W każdym kolejnym powtórzeniu pętli while przesuwamy zatem wskaźnik argv do kolejnego napisu / argumentu-wiersza-poleceń, ( dereferencja *argv zwróci wskaźnik do pierwszego znaku wspomnianego napisu ). Jednocześnie w każdym powtórzeniu pętli zmniejszamy wartość narg o 1, dopóki jest ona ( po zmniejszeniu! ) > 0. [ Tym sposobem, wypisanych zostanie narg-1 argumentów, kolejno od argv[1] do argv[narg-1]; po każdym za wyjątkiem ostatniego dodatkowo pojawi się spacja. ] Adam Rycerz [ wyklad09.pdf ] Strona 6 z 36
7 Instrukcja wypisująca argumenty i spacje może jeszcze zostać zastąpiona nieco krótszą wersją: printf((narg>1)? %s : %s, *++argv); gdzie korzystamy z faktu, że pierwszy argument funkcji printf (zawierający specyfikacje przekształcenia) również może być jak każdy argument każdej funkcji wyrażeniem wymagającym wykonania obliczeń. W kolejnym przykładzie, rozważymy program będący uproszczoną wersją polecenia cat systemu Unix. W szczególności, $ cat a.c b.c wypisuje na standardowe wyjście zawartość plików a.c i b.c. [ Zatem aby np. dokleić b.c do a.c, piszemy: $ cat a.c b.c > a.c ] Adam Rycerz [ wyklad09.pdf ] Strona 7 z 36
8 #include <stdio.h> #include <stdlib.h> /* zob. funkcja exit */ /* Sklejanie plików - wg Kernighan&Ritchie, 1994 */ int main(int narg, char *argv[]) { FILE *fp; void filecopy(file *, FILE *); /* kopiuje plik */ char *prog = argv[0]; /* nazwa programu */ if ( narg == 1 ) /* kopiuj standardowe wejście */ filecopy(stdin, stdout); else { /* c.d.n. */ Adam Rycerz [ wyklad09.pdf ] Strona 8 z 36
9 /* c.d. else <=> (narg > 1) */ while (--narg>0) if (NULL==(fp=fopen(*++argv, rb ))) { fprintf(stderr, %s: cannot open %s\n, prog, *argv); exit(1); } else { /* przypadek bez błędów: */ filecopy(fp, stdout); fclose(fp); } } if (ferror(stdout)) { fprintf(stderr, %s: stdout error\n, prog); exit(2); } exit(0); } Adam Rycerz [ wyklad09.pdf ] Strona 9 z 36
10 Ponownie, użyliśmy strumienia błędów ( stderr ) aby komunikaty o błędach trafiały zawsze na ekran ( również w przypadku, gdy wyjście programu jest przekierowane do pliku ). Pierwszym nowym elementem jest funkcja standardowa exit: Wewnętrz funkcji main instrukcja exit(wyrażenie); jest równoważna instrukcji: return wyrażenie; ma jednak tę przewagę, że pozwala natychmiast przerwać działanie programu, także w środku wykonywania innej funkcji. [ Argument funkcji exit zostanie przekazany do procesu, który wywołał program; funkcja exit automatycznie wywołuje fclose dla wszystkich otwartych plików i wypisuje dane w buforach. ] Adam Rycerz [ wyklad09.pdf ] Strona 10 z 36
11 Drugi nowy element to funkcja ferror zadeklarowana jako: int ferror(file *fp); Funkcja ferror zwraca wartość niezerową, gdy dla strumienia fp wystąpi jakiś błąd. [ Podobna funkcja: int feof(file *) ] [ Błędy dotyczące standardowego wyjścia są raczej rzadkie (np. przepełnienie partycji dysku), w poważnym programie musimy jednak zadbać o zwracanie wartości opisującej taki stan. ] Ostatni element funkcja kopiująca pliki ( zob. wyklad07.pdf ): void filecopy(file *ifp, FILE *ofp) { int c; while (EOF!= (c=getc(ifp))) putc(c, ofp); } Adam Rycerz [ wyklad09.pdf ] Strona 11 z 36
12 UWAGA o maskach w systemie Unix: Polecenia systemowe, jeśli to tylko możliwe przyjmują jako argumenty tzw. maski. Przykładowo, $ cat *.c wyświetli zawartość wszystkich plików (w bieżącym katalogu), któtych nazwy kończą się wzorcem.c, zaś $ cat *.c > all-souce-files.c sklei zawartość tych plików i zapisze w jednym pliku. Nasz program oczywiście nie będzie rozwijał masek automatycznie, możemy jednak napisać: $./a.out `ls *.c` Wówczas, system operacyjny przekaże wynik polecenia ( ls *.c ) jako listę argumentów do naszego programu. Adam Rycerz [ wyklad09.pdf ] Strona 12 z 36
13 Trzecim przykładem, ilustrującym zastosowanie argumentów wiersza poleceń, będzie ulepszona wersja programu wypisującego wiersze zawierające szukany wzorzec ( por. wyklad05.pdf ). Tym razem, podążymy za schematem polecenia grep systemu Unix szukany wzorzec będzie pierwszym argumentem wywołania programu. Dla dalszego usprawnienia działania programu, użyjemy funkcji biblioteki standardowej: strstr(s,t) zadeklarowanej w nagłówku <string.h>, która zwraca wskaźnik do pierwszego wystąpienia ciągu znaków t w napisie s lub NULL, jeśli szukany wzorzec ( t ) nie został znaleziony w napisie ( s ). Adam Rycerz [ wyklad09.pdf ] Strona 13 z 36
14 #include <stdio.h> #include <string.h> #define MAXLINE 1000 /* maks. dlugosc wiersza */ /* ==> Wypisz wiersze zawierające wzorzec, podany jako argument wywołania programu <== */ int main(int narg, char *argv[]) { char line[maxline+1]; /* + miejsce na '\0' */ int found = 0; if (narg!= 2) fprintf(stderr, USAGE: %s pattern\n,argv[0]); else { /* c.d.n. */ Adam Rycerz [ wyklad09.pdf ] Strona 14 z 36
15 /* c.d. else <=> (narg == 2) */ } while (NULL!= fgets(line, MAXLINE+1, stdin)) if (NULL!= strstr(line,argv[1])) { printf( %s,line); /* \n jest już zawarte w line (!) */ found++; } } return found; Adam Rycerz [ wyklad09.pdf ] Strona 15 z 36
16 Argumenty opcjonalne wywołania programu Polecenia systemu Unix najczęściej posiadają parametry (lub przełączniki) opcjonalne, podawane po znaku -. Przykładowo, $ ls *.c wypisze tylko nazwy plików pasujących do maski *.c, zaś $ ls -l *.c wypisze szczegółowe informacje o tych plikach: -rw-r--r--+ 1 adamr staff 145 Nov 14 19:42 co-robi.c -rw-r--r--+ 1 adamr staff 202 Oct 22 00:40 silnia.c -rw-r--r-- 1 adamr staff 820 Dec 16 00:53 sklej.c -rw-r--r--+ 1 adamr staff 822 Nov 14 13:11 wzorzec.c [ W maskach: * = dowolny ciąg ( nie-białych ) znaków;? = 1 znak. ] Adam Rycerz [ wyklad09.pdf ] Strona 16 z 36
17 Pokażemy teraz, jak zmodyfikować program wyszukujący wzorzec tak, aby posiadał dwa opcjonalne przełączniki: -x (ang. except ) powoduje, że program wypisuje wszystkie wiersze oprócz tych zawierających wzorzec. -n (ang. numbering) podaje numery wypisywanych wierszy Chcemy, aby przełączniki można było podawać w dowolnej kolejności; użyteczną możliwością jest także grupowanie opcji: $./a.out -nx wzorzec => powinny zostać wypisane wiersze niezawierające wzorca, poprzedzone numerami. [ Naturalnie, program wywołany bez opcji powinien działać jak poprzednio, tj. wypisywać wiersze zawierające wzorzec, bez numeracji. ] Adam Rycerz [ wyklad09.pdf ] Strona 17 z 36
18 #include <stdio.h> #include <string.h> #define MAXLINE 1000 /* maks. dlugosc wiersza */ /* ==> Wypisz wiersze zawierające wzorzec, podany jako argument wywołania programu <== */ int main(int narg, char *argv[]) { char *prog = argv[0]; /* nazwa programu */ char line[maxline+1]; long lineno = 0; /* numer wiersza */ int c, exc = 0, num = 0, found = 0; /* c.d.n. */ Adam Rycerz [ wyklad09.pdf ] Strona 18 z 36
19 while (--narg > 0 && (*++argv)[0] == '-') while ((c = *++argv[0])) /* <=> c!= \0 */ switch (c) { case 'x': exc = 1; break; case 'n': num = 1; break; default: fprintf(stderr, %s: illegal option -%c\n, prog, c); narg = 0; found = -1; break; } Adam Rycerz [ wyklad09.pdf ] Strona 19 z 36
20 } if (narg!= 1) fprintf(stderr, "USAGE: %s -x -n pattern\n, prog); else while (NULL!= fgets(line,maxline+1,stdin)) { lineno++; if ( exc!= (NULL!=strstr(line,*argv)) ) { if (num) printf("%8ld: ", lineno); printf("%s", line); found++; } } return found; Adam Rycerz [ wyklad09.pdf ] Strona 20 z 36
21 Z każdym powtórzeniem pierwszej pętli while, wartość narg zostaje zmiejszona o 1, a wartość argv zwiększona o 1. Jeśli nie wystąpiły błędy, na końcu trafiamy na argument, którego pierwszy znak ( *argv[0] lub **argv ) nie jest już znakiem - A zatem jest to argument obowiązkowy (nasz wzorzec), reprezentowany przez argv[0] (lub *argv ). Warto podkreślić, że nawiasy w wyrażeniu (*++argv)[0] są konieczne, ponieważ [] wiąże mocniej niż ++, a zatem bez nawiasów, de facto dostalibyśmy: *++(argv[0]) Korzystamy z tego w drugiej pętli while, która przegląda kolejne znaki napisu argv[0] zwiększamy zatem wskaźnik argv[0], natomiast argv pozostaje niezmieniony (!) Adam Rycerz [ wyklad09.pdf ] Strona 21 z 36
22 Przykładowo, wywołanie programu: $./a.out -n int\ < wzorzec2.c wyszuka wzorzec int (spację wprowadzamy pisząc \ ) w pliku źródłowym tego programu ( wzorzec2.c ). Wynikiem będzie: 8: int main(int narg, char *argv[]) 12: int c, exc = 0, num = 0, found = 0; Otrzymaliśmy zatem linie kodu źródłowego, zawierające deklaracje obiektów typu int. Adam Rycerz [ wyklad09.pdf ] Strona 22 z 36
23 Wskaźniki do funkcji Funkcje w języku C nie są zmiennymi, można jednak definiować wskaźniki do funkcji ( taki wskaźnik przechowuje adres fragmentu kodu wykonywalnego, który jest realizacją danej funkcji ). Wskaźniki do funkcji już są zmiennymi, mogą być zatem przypisywane, grupowane w tablicach, przekazywane do funkcji, jak również zwracane przez funkcje. [ Nie istnieje jednak żadna arytmetyka wskaźników do funkcji, nie można również przydzielić/zwolnić pamięci za ich pośrednictwem. ] Deklaracja wskaźnika do funkcji (jako zmiennej!) wg szablonu: typ-powrotu (*nazwa-wskaźnika)(typy-argumentów); dodatkowe nawiasy otaczające nazwę są konieczne, bez nich zadeklarowalibyśby po prostu funkcję zwracającą wskaźnik. Adam Rycerz [ wyklad09.pdf ] Strona 23 z 36
24 Przykładowo, jeśli gdzieś w programie zdefiniujemy funkcję: void fun(int a) { printf("moja ulubiona liczba to %d\n", a); } a następnie w funkcji main pojawi się deklaracja: void (*fun_ptr)(int) = &fun; wówczas, naszą funkcje możemy wywołać na dwa ( równoważne! ) sposoby: po pierwsze, wprost: fun(7); lub też przez wskaźnik: (*fun_ptr)(7); Adam Rycerz [ wyklad09.pdf ] Strona 24 z 36
25 Podobnie ( trochę podobnie ) jak w przypadku tablic, nazwa funkcji jest także synonimem wskaźnika do funkcji. [ Konwencja jest tutaj trochę mniej przejrzysta: W przypadku tablicy, nazwa była synonimem wskaźnika do pierwszego elementu, a nie co całej tablicy; TUTAJ brak takiego rozróżnienia ] Dla naszej funkcji ( fun ) poprawna będzie także deklaracja wskaźnika do funkcji: void (*fun_ptr)(int) = fun; /* usunięto & (!)*/ i wywołanie przez wskaźnik w postaci: fun_ptr(10); /* usunięto operator * (!) */ Jak widać, użyte poprzednio operatory & i * nie są konieczne; wybór konwencji jak zawsze jest kwestią indywidualnych upodobań. Adam Rycerz [ wyklad09.pdf ] Strona 25 z 36
26 Tablice wskaźników funkcji W analogii do zwykłych wskaźników, wskaźniki na funkcje także mogą być grupowane w tablice. W przykładzie poniżej, wybieramy jedno z 3 działań arytmetycznych na liczbach a i b (dodawanie, odejmowanie, lub mnożenia). [zob. ] #include <stdio.h> void add(int a, int b) { printf("addition is %d\n", a+b); } void subtract(int a, int b) { printf("subtraction is %d\n", a-b); } void multiply(int a, int b) { printf("multiplication is %d\n", a*b); } Adam Rycerz [ wyklad09.pdf ] Strona 26 z 36
27 int main() { /* Tablica wskaźników funkcji: fun_ptr_arr */ void (*fun_ptr_arr[])(int, int) = {add, subtract, multiply}; int ch, a = 15, b = 10; printf("enter Choice: 0 for add, "1 for subtract and 2 for multiply\n"); scanf("%d", &ch); if (ch < 0 ch > 2) return 1; (*fun_ptr_arr[ch])(a, b); } return 0; Adam Rycerz [ wyklad09.pdf ] Strona 27 z 36
28 Wskaźniki do funkcji jako argumenty funkcji Podobnie jak zwykłe wskaźniki, także wskaźniki do funkcji mogą być przekazywane jako argumenty lub zwracane przez funkcje. Taki mechanizm w wielu sytuacjach pozwala uniknąć niekorzystnego zjawiska tzw. redundancji kodu. Redundancja kodu polega na tym, że skomplikowana procedura ( np. minimalizacja funkcji, poszukiwanie miejsce zerowych, albo znany z poprzednich wykładów algorytm quicksort ) musi zostać przepisana w kilku, niemal identycznych wersjach, wyłącznie po to aby np. obliczać wartości różnych funkcji do minimalizacji, albo wywoływać funkcje porównujące obiekty do posortowania. Adam Rycerz [ wyklad09.pdf ] Strona 28 z 36
29 W takich sytuacjach, zdecydowanie lepiej jest napisać jedną funkcję, wykonującą naszą procedurę, której parametrem jest wskaźnik na funkcję (np. porównującą 2 obiekty). [ Taką funkcję możemy poźniej wywołać kilkakrotnie, przekazując jej np. wskaźniki do różnych funkcji porównujących. ] Potrzeba unikania redundancji kodu wynika wprost z zasady: ==> Pisanie programu nigdy się nie kończy. Kiedy zajdzie potrzeba ulepszenia implementacji kluczowego algorytmu zmiany będziemy wprowadzać w jednej wersji, a nie w kilku podobnych. Adam Rycerz [ wyklad09.pdf ] Strona 29 z 36
30 Elementarny przykład: Funkcja wrapper() operuje na argumencie void fun() wskaźniku powiązanym kolejno z dwiema różnymi funkcjami zewnętrznymi. [ zob. ] #include <stdio.h> void fun1() { printf("i am fun1\n"); } void fun2() { printf("i am fun2\n"); } /* Funkcja wywołująca inne f-cje przez wskaźnik */ void wrapper(void (*fun)()) { fun(); } int main() { wrapper(fun1); wrapper(fun2); return 0; } Adam Rycerz [ wyklad09.pdf ] Strona 30 z 36
31 Inny ( równoważny! ) zapis funkcji wrapper() oraz main() [ niekorzystający z synonimów wskaźników do funkcji ]: void wrapper(void (*fun)()) { (*fun)(); } int main() { wrapper( &fun1 ); wrapper( &fun2 ); return 0; } Adam Rycerz [ wyklad09.pdf ] Strona 31 z 36
32 Jeśli zachodzi potrzeba, aby funkcja przekazywana przez wskaźnik do innej funkcji także miała swoje argumenty, często możemy ją tak zaprojektować, aby argumentami były wskaźniki ogólne ( void* ). Mechanizm ten wykorzystuje m.in. funkcja qsort z biblioteki standardowej, zadeklarowana w nagłówku <stdlib.h> w następujący sposób: void qsort(void *base, size_t nel, size_t width, int (*compar)(const void *, const void *)); Argumentami są: tablica do posortowania ( base ), liczba elementów ( nel ), rozmiar 1 elementu ( width ), oraz wskaźnik do funkcji wykonującej porównanie 2 elementów ( compar ). Adam Rycerz [ wyklad09.pdf ] Strona 32 z 36
33 Przykład: sortujemy tablicę liczb typu double #include <stdio.h> #include <stdlib.h> int comp(const void *a, const void *b) { double x = *(double *)a, y = *(double *)b; if ( x>y ) return 1; else if (x<y) return -1; else return 0; } Adam Rycerz [ wyklad09.pdf ] Strona 33 z 36
34 int main() { double arr[] = {10.0, 10.0/2, 10.0/3, 3*4, 9}; int i, n = sizeof(arr)/sizeof(arr[0]); qsort(arr, n, sizeof(double), comp); for (i=0; i<n; i++) printf((i < n-1)? "%g " : "%g\n", arr[i]); return 0; } Adam Rycerz [ wyklad09.pdf ] Strona 34 z 36
35 Struktury Ważnym typem danych w języku C są struktury: struktura to jedna lub kilka zmiennych, które mogą być różnych typów, połączonych w tak, aby możliwe były odwołania za pomocą wspólnej nazwy. Naturalnym zastosowaniem struktur są wszelkie bazy danych; pojedynczy rekord może być np. strukturą zawierającą imię, nazwisko, adres, i numer telefonu danej osoby: strukt rekord { char *fnam, *snam, *addr; int phone; } r = { Jan, Kowalski, ul. Osobliwa 1, 5568}; Adam Rycerz [ wyklad09.pdf ] Strona 35 z 36
36 Po takiej deklaracji, fraza: struct rekord może być dalej używana jak nazwa typu, możemy np. deklarować zmienne: struct rekord a, b, c; dokonywać przypisań: a = r; jak również przekazywać struktury do funkcji i definiować funkcje zwracające struktury; struktury można także zagnieżdżać. [ Jeśli jednocześnie z deklaracją struktury zadeklarujemy wszystkie zmienne, identyfikator struktury ( tutaj: rekord ) można pominąć. ] Odwołania do składowych (pól) struktury mają postać: nazwa-struktury.nazwa-pola Przykład: printf( %s %d\n, a.snam, a.phone); Adam Rycerz [ wyklad09.pdf ] Strona 36 z 36
Programowanie proceduralne INP001210WL rok akademicki 2015/16 semestr letni. Wykład 6. Karol Tarnowski A-1 p.
Programowanie proceduralne INP001210WL rok akademicki 2015/16 semestr letni Wykład 6 Karol Tarnowski karol.tarnowski@pwr.edu.pl A-1 p. 411b Plan wykładu Operacje wejścia-wyjścia Dostęp do plików Struktury
Obsługa plików. Laboratorium Podstaw Informatyki. Kierunek Elektrotechnika. Laboratorium Podstaw Informatyki Strona 1. Kraków 2013
Laboratorium Podstaw Informatyki Strona 1 Laboratorium Podstaw Informatyki Kierunek Elektrotechnika Obsługa plików Kraków 2013 Laboratorium Podstaw Informatyki Strona 2 Obsługa plików Zanim będziemy mogli
Wstęp do Programowania, laboratorium 02
Wstęp do Programowania, laboratorium 02 Zadanie 1. Napisać program pobierający dwie liczby całkowite i wypisujący na ekran największą z nich. Zadanie 2. Napisać program pobierający trzy liczby całkowite
Temat: Dynamiczne przydzielanie i zwalnianie pamięci. Struktura listy operacje wstawiania, wyszukiwania oraz usuwania danych.
Temat: Dynamiczne przydzielanie i zwalnianie pamięci. Struktura listy operacje wstawiania, wyszukiwania oraz usuwania danych. 1. Rodzaje pamięci używanej w programach Pamięć komputera, dostępna dla programu,
METODY I JĘZYKI PROGRAMOWANIA PROGRAMOWANIE STRUKTURALNE. Wykład 02
METODY I JĘZYKI PROGRAMOWANIA PROGRAMOWANIE STRUKTURALNE Wykład 02 NAJPROSTSZY PROGRAM /* (Prawie) najprostszy przykład programu w C */ /*==================*/ /* Między tymi znaczkami można pisać, co się
ISO/ANSI C - funkcje. Funkcje. ISO/ANSI C - funkcje. ISO/ANSI C - funkcje. ISO/ANSI C - funkcje. ISO/ANSI C - funkcje
Funkcje (podprogramy) Mianem funkcji określa się fragment kodu, który może być wykonywany wielokrotnie z różnych miejsc programu. Ogólny zapis: typ nazwa(argumenty) ciało funkcji typ określa typ danych
Ćwiczenie 4. Obsługa plików. Laboratorium Podstaw Informatyki. Kierunek Elektrotechnika. Laboratorium Podstaw Informatyki Strona 1.
Laboratorium Podstaw Informatyki Strona 1 Laboratorium Podstaw Informatyki Kierunek Elektrotechnika Ćwiczenie 4 Obsługa plików Kraków 2010 Laboratorium Podstaw Informatyki Strona 2 Obsługa plików Zanim
Tablice, funkcje - wprowadzenie
Tablice, funkcje - wprowadzenie Przemysław Gawroński D-10, p. 234 Wykład 5 25 marca 2019 (Wykład 5) Tablice, funkcje - wprowadzenie 25 marca 2019 1 / 12 Outline 1 Tablice jednowymiarowe 2 Funkcje (Wykład
Biblioteka standardowa - operacje wejścia/wyjścia
Biblioteka standardowa - operacje wejścia/wyjścia Przemysław Gawroński D-10, p. 234 Wykład 6 15 stycznia 2019 (Wykład 6) Biblioteka standardowa - operacje wejścia/wyjścia 15 stycznia 2019 1 / 14 Outline
wykład II uzupełnienie notatek: dr Jerzy Białkowski Programowanie C/C++ Język C - funkcje, tablice i wskaźniki wykład II dr Jarosław Mederski Spis
i cz. 2 Programowanie uzupełnienie notatek: dr Jerzy Białkowski 1 i cz. 2 2 i cz. 2 3 Funkcje i cz. 2 typ nazwa ( lista-parametrów ) { deklaracje instrukcje } i cz. 2 typ nazwa ( lista-parametrów ) { deklaracje
Wskaźniki w C. Anna Gogolińska
Wskaźniki w C Anna Gogolińska Zmienne Zmienną w C można traktować jako obszar w pamięci etykietowany nazwą zmiennej i zawierający jej wartość. Przykład: kod graficznie int a; a a = 3; a 3 Wskaźniki Wskaźnik
Stałe i zmienne znakowe. Stała znakowa: znak
Stałe i zmienne znakowe. Stała znakowa: znak Na przykład: a, 1, 0 c Każdy znak jest reprezentowany w pamięci przez swój kod. Kody alfanumerycznych znaków ASCII to liczby z przedziału [32, 127]. Liczby
Poprzedni wykład [ ] :
Poprzedni wykład [ 27.11.2018 ] : - Funkcje i struktura programu - Zasady podziału programu na pliki ( nagłówki, pliki źródłowe, kody pośrednie, plik wykonywalny ) - Polecenie make i pliki Makefile - Preprocesor
Wstęp do programowania 1
Wstęp do programowania 1 Argumenty funkcji main Bożena Woźna-Szcześniak bwozna@gmail.com Jan Długosz University, Poland Wykład 11 Argumenty funkcji main dwa równoważne sposoby int main(int argc, char*
Pobieranie argumentów wiersza polecenia
Pobieranie argumentów wiersza polecenia 2. Argumenty wiersza polecenia Lista argumentów Lista argumentów zawiera cały wiersz poleceń, łącznie z nazwą programu i wszystkimi dostarczonymi argumentami. Przykłady:
Podstawy programowania w języku C++
Podstawy programowania w języku C++ Część jedenasta Przetwarzanie plików amorficznych Konwencja języka C Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie
Programowanie Proceduralne
Programowanie Proceduralne Struktury Bożena Woźna-Szcześniak bwozna@gmail.com Jan Długosz University, Poland Wykład 10 Co dziś będzie: Definiowanie struktury Deklarowanie zmiennych bȩda cych strukturami
Programowanie proceduralne INP001210WL rok akademicki 2018/19 semestr letni. Wykład 6. Karol Tarnowski A-1 p.
Programowanie proceduralne INP001210WL rok akademicki 2018/19 semestr letni Wykład 6 Karol Tarnowski karol.tarnowski@pwr.edu.pl A-1 p. 411B Plan prezentacji Wskaźnik do pliku Dostęp do pliku: zapis, odczyt,
Funkcje zawarte w bibliotece < io.h >
PLIKOWE OPERACJE WEJŚCIA - WYJŚCIA Język C/C++ nie ma wbudowanych żadnych instrukcji umożliwiających wykonywanie operacji wejścia-wyjścia! Służą do tego funkcje biblioteczne. Funkcje zawarte w bibliotece
1 Podstawy c++ w pigułce.
1 Podstawy c++ w pigułce. 1.1 Struktura dokumentu. Kod programu c++ jest zwykłym tekstem napisanym w dowolnym edytorze. Plikowi takiemu nadaje się zwykle rozszerzenie.cpp i kompiluje za pomocą kompilatora,
Pliki. Informacje ogólne. Obsługa plików w języku C
Pliki Informacje ogólne Plik jest pewnym zbiorem danych, zapisanym w systemie plików na nośniku danych (np. dysku twardym, pendrive, płycie DVD itp.). Może posiadać określone atrybuty, a odwołanie do niego
Wskaźniki do funkcji. Wykład 11. Podstawy programowania ( język C ) Wskaźniki do funkcji (1) Wskaźniki do funkcji (2)
Podstawy programowania ( język C ) Wskaźniki do funkcji Wykład 11. Tomasz Marks - Wydział MiNI PW -1- Tomasz Marks - Wydział MiNI PW -2- Wskaźniki do funkcji (1) W języku C funkcje nie są zmiennymi, ale
2 Przygotował: mgr inż. Maciej Lasota
Laboratorium nr 2 1/7 Język C Instrukcja laboratoryjna Temat: Wprowadzenie do języka C 2 Przygotował: mgr inż. Maciej Lasota 1) Wprowadzenie do języka C. Język C jest językiem programowania ogólnego zastosowania
Katedra Elektrotechniki Teoretycznej i Informatyki. wykład 12 - sem.iii. M. Czyżak
Katedra Elektrotechniki Teoretycznej i Informatyki wykład 12 - sem.iii M. Czyżak Język C - preprocesor Preprocesor C i C++ (cpp) jest programem, który przetwarza tekst programu przed przekazaniem go kompilatorowi.
Pliki. Informacje ogólne. Obsługa plików w języku C
Pliki Informacje ogólne Plik jest pewnym zbiorem danych, zapisanym w systemie plików na nośniku danych. Może posiadać określone atrybuty, a odwołanie do niego odbywa się poprzez nazwę. Każdy plik ma skończoną
Funkcje zawarte w bibliotece < io.h >
PLIKOWE OPERACJE WEJŚCIA - WYJŚCIA Język C/C++ nie ma wbudowanych żadnych instrukcji umożliwiających wykonywanie operacji wejścia-wyjścia! Służą do tego funkcje biblioteczne. Funkcje zawarte w bibliotece
Wskaźniki. Przemysław Gawroński D-10, p marca Wykład 2. (Wykład 2) Wskaźniki 8 marca / 17
Wskaźniki Przemysław Gawroński D-10, p. 234 Wykład 2 8 marca 2019 (Wykład 2) Wskaźniki 8 marca 2019 1 / 17 Outline 1 Wskaźniki 2 Tablice a wskaźniki 3 Dynamiczna alokacja pamięci (Wykład 2) Wskaźniki 8
Wstęp do programowania INP003203L rok akademicki 2018/19 semestr zimowy. Laboratorium 2. Karol Tarnowski A-1 p.
Wstęp do programowania INP003203L rok akademicki 2018/19 semestr zimowy Laboratorium 2 Karol Tarnowski karol.tarnowski@pwr.edu.pl A-1 p. 411B Plan prezentacji Komentarze Funkcja printf() Zmienne Łańcuchy
Wykład VI. Programowanie. dr inż. Janusz Słupik. Gliwice, 2014. Wydział Matematyki Stosowanej Politechniki Śląskiej. c Copyright 2014 Janusz Słupik
Wykład VI Wydział Matematyki Stosowanej Politechniki Śląskiej Gliwice, 2014 c Copyright 2014 Janusz Słupik Operacje na plikach Operacje na plikach Aby móc korzystać z pliku należy go otworzyć w odpowiednim
Lab 9 Podstawy Programowania
Lab 9 Podstawy Programowania (Kaja.Gutowska@cs.put.poznan.pl) Wszystkie kody/fragmenty kodów dostępne w osobnym pliku.txt. Materiały pomocnicze: Wskaźnik to specjalny rodzaj zmiennej, w której zapisany
Funkcja (podprogram) void
Funkcje Co to jest funkcja? Budowa funkcji Deklaracja, definicja i wywołanie funkcji Przykłady funkcji definiowanych przez programistę Przekazywanie argumentów do funkcji Tablica jako argument funkcji
Podstawy programowania skrót z wykładów:
Podstawy programowania skrót z wykładów: // komentarz jednowierszowy. /* */ komentarz wielowierszowy. # include dyrektywa preprocesora, załączająca biblioteki (pliki nagłówkowe). using namespace
1 Podstawy c++ w pigułce.
1 Podstawy c++ w pigułce. 1.1 Struktura dokumentu. Kod programu c++ jest zwykłym tekstem napisanym w dowolnym edytorze. Plikowi takiemu nadaje się zwykle rozszerzenie.cpp i kompiluje za pomocą kompilatora,
ISO/ANSI C - funkcje. Funkcje. ISO/ANSI C - funkcje. ISO/ANSI C - funkcje. ISO/ANSI C - funkcje. ISO/ANSI C - funkcje
Funkcje (podprogramy) Mianem funkcji określa się fragment kodu, który może być wykonywany wielokrotnie z różnych miejsc programu. Ogólny zapis: typ nazwa(argumenty) ciało funkcji typ określa typ danych
Języki i metodyka programowania. Wprowadzenie do języka C
Literatura: Brian W. Kernighan, Dennis M. Ritchie Język Ansi C, Wydawnictwa Naukowo - Techniczne, 2007 http://cm.bell-labs.com/cm/cs/cbook/index.html Scott E. Gimpel, Clovis L. Tondo Język Ansi C. Ćwiczenia
Argumenty wywołania programu, operacje na plikach
Temat zajęć: Argumenty wywołania programu, operacje na plikach Autor: mgr inż. Sławomir Samolej Zagadnienie 1. (Zmienne statyczne) W języku C można decydować o sposobie przechowywania zmiennych. Decydują
Wstęp do programowania INP001213Wcl rok akademicki 2017/18 semestr zimowy. Wykład 12. Karol Tarnowski A-1 p.
Wstęp do programowania INP001213Wcl rok akademicki 2017/18 semestr zimowy Wykład 12 Karol Tarnowski karol.tarnowski@pwr.edu.pl A-1 p. 411B Plan prezentacji (1) Obsługa łańcuchów znakowych getchar(), putchar()
Część 4 życie programu
1. Struktura programu c++ Ogólna struktura programu w C++ składa się z kilku części: część 1 część 2 część 3 część 4 #include int main(int argc, char *argv[]) /* instrukcje funkcji main */ Część
Podstawy programowania. Wykład Pętle. Tablice. Krzysztof Banaś Podstawy programowania 1
Podstawy programowania. Wykład Pętle. Tablice. Krzysztof Banaś Podstawy programowania 1 Pętle Pętla jest konstrukcją sterującą stosowaną w celu wielokrotnego wykonania tego samego zestawu instrukcji jednokrotne
Języki i metodyka programowania. Typy, operatory, wyrażenia. Wejście i wyjście.
Typy, operatory, wyrażenia. Wejście i wyjście. Typy, operatory, wyrażenia Zmienna: [] [ '[' ']' ] ['=' ]; Zmienna to fragment pamięci o określonym
Języki programowania. Przetwarzanie plików amorficznych Konwencja języka C. Część siódma. Autorzy Tomasz Xięski Roman Simiński
Języki programowania Część siódma Przetwarzanie plików amorficznych Konwencja języka C Autorzy Tomasz Xięski Roman Simiński Niniejsze opracowanie zawiera skrót treści wykładu, lektura tych materiałów nie
Programowanie w C++ Wykład 5. Katarzyna Grzelak. 26 marca kwietnia K.Grzelak (Wykład 1) Programowanie w C++ 1 / 40
Programowanie w C++ Wykład 5 Katarzyna Grzelak 26 marca 2018 9 kwietnia 2018 K.Grzelak (Wykład 1) Programowanie w C++ 1 / 40 Pojęcia z poprzedniego wykładu Podział programu na funkcje podział na niezależne
Podstawy programowania, Poniedziałek , 8-10 Projekt, część 1
Podstawy programowania, Poniedziałek 30.05.2016, 8-10 Projekt, część 1 1. Zadanie Projekt polega na stworzeniu logicznej gry komputerowej działającej w trybie tekstowym o nazwie Minefield. 2. Cele Celem
Podstawy programowania. Wykład Funkcje. Krzysztof Banaś Podstawy programowania 1
Podstawy programowania. Wykład Funkcje Krzysztof Banaś Podstawy programowania 1 Programowanie proceduralne Pojęcie procedury (funkcji) programowanie proceduralne realizacja określonego zadania specyfikacja
Podstawy Programowania. Obsługa błędów, przeszukiwanie i sortowanie tablic
Podstawy Programowania Wykład VIII Obsługa błędów, przeszukiwanie i sortowanie tablic Robert Muszyński ZPCiR IIAiR PWr Zagadnienia: źródła błędów, organizacja obsługi błędów, standardowe funkcje obsługi
Wskaźniki. Programowanie Proceduralne 1
Wskaźniki Programowanie Proceduralne 1 Adresy zmiennych Sterta 1 #include 2 3 int a = 2 ; 4 5 int main ( ) 6 { 7 int b = 3 ; 8 9 printf ( " adres zmiennej a %p\n", &a ) ; 10 printf ( " adres
Elementy języka C. ACprogramislikeafastdanceonanewlywaxeddancefloorbypeople carrying razors.
Wykład 3 ACprogramislikeafastdanceonanewlywaxeddancefloorbypeople carrying razors. Waldi Ravens J. Cichoń, P. Kobylański Wstęp do Informatyki i Programowania 75 / 146 deklaracje zmiennych instrukcja podstawienia
Programowanie I C / C++ laboratorium 03 arytmetyka, operatory
Programowanie I C / C++ laboratorium 03 arytmetyka, operatory Jarosław Piersa Wydział Matematyki i Informatyki, Uniwersytet Mikołaja Kopernika 2013-02-19 Typ znakowy Typ znakowy Typ wyliczeniowy # include
Tablice (jedno i wielowymiarowe), łańcuchy znaków
Tablice (jedno i wielowymiarowe), łańcuchy znaków wer. 8 z drobnymi modyfikacjami! Wojciech Myszka Katedra Mechaniki i Inżynierii Materiałowej 2017-04-07 09:35:32 +0200 Zmienne Przypomnienie/podsumowanie
Struktury, unie, formatowanie, wskaźniki
Struktury, unie, formatowanie, wskaźniki 1. Napisz aplikację, która na wejściu dostaje napis postaci W Roku Pańskim 1345, władca Henryk 12, na rzecz swoich 143209 poddanych uchwalił dekret o 20 procentowej
Podstawy programowania. Wykład 6 Wskaźniki. Krzysztof Banaś Podstawy programowania 1
Podstawy programowania. Wykład 6 Wskaźniki Krzysztof Banaś Podstawy programowania 1 Adresy zmiennych Język C pozwala na operowanie adresami w pamięci stąd, między innymi, kwalifikowanie C jako języka relatywnie
Formatowane (tekstowe) wejście/wyjście. Binarne wejście/wyjście.
Formatowane (tekstowe) wejście/wyjście. Binarne wejście/wyjście. wer. 10 z drobnymi modyfikacjami! Wojciech Myszka 2018-03-27 09:06:38 +0200 Część I Formatowane (tekstowe) wejście/wyjście Otwarcie pliku
Uwagi dotyczące notacji kodu! Moduły. Struktura modułu. Procedury. Opcje modułu (niektóre)
Uwagi dotyczące notacji kodu! Wyrazy drukiem prostym -- słowami języka VBA. Wyrazy drukiem pochyłym -- inne fragmenty kodu. Wyrazy w [nawiasach kwadratowych] opcjonalne fragmenty kodu (mogą być, ale nie
۰ Elementem jednostkowym takiego pliku jest bajt. ۰ Format pliku binarnego: [bajty pliku][eof]
1 Plik jest wydzielonym fragmentem pamięci (najczęściej dyskowej) posiadającym nazwę. Z punktu widzenia C plik jest ciągiem bajtów, z których każdy może zostać oddzielnie odczytany. Zgodnie ze standardem
Co nie powinno być umieszczane w plikach nagłówkowych:
Zawartość plików nagłówkowych (*.h) : #include #define ESC 27 dyrektywy dołączenia definicje stałych #define MAX(x,y) ((x)>(y)?(x):(y)) definicje makr int menu(char* tab[], int ilosc); struct
I - Microsoft Visual Studio C++
I - Microsoft Visual Studio C++ 1. Nowy projekt z Menu wybieramy File -> New -> Projekt -> Win32 Console Application w okienku Name: podajemy nazwę projektu w polu Location: wybieramy miejsce zapisu i
Wskaźniki. Informatyka
Materiały Wskaźniki Informatyka Wskaźnik z punktu widzenia programisty jest grupą komórek pamięci (rozmiar wskaźnika zależy od architektury procesora, najczęściej są to dwa lub cztery bajty ), które mogą
Laboratorium Podstaw Informatyki. Kierunek Elektrotechnika. Ćwiczenie 1. Podstawy. Wprowadzenie do programowania w języku C. Katedra Metrologii AGH
Laboratorium Podstaw Informatyki Kierunek Elektrotechnika Ćwiczenie 1 Podstawy Wprowadzenie do programowania w języku C Kraków 2010 Twój pierwszy program w C Program w języku C, jak i w wielu innych językach
1. Wartość, jaką odczytuje się z obszaru przydzielonego obiektowi to: a) I - wartość b) definicja obiektu c) typ oboektu d) p - wartość
1. Wartość, jaką odczytuje się z obszaru przydzielonego obiektowi to: a) I - wartość b) definicja obiektu c) typ oboektu d) p - wartość 2. Poprawna definicja wskażnika b to: a) float *a, **b = &a; b) float
Podstawy Informatyki. Inżynieria Ciepła, I rok. Wykład 10 Kurs C++
Podstawy Informatyki Inżynieria Ciepła, I rok Wykład 10 Kurs C++ Historia Lata 70-te XX w język C (do pisania systemów operacyjnych) "The C programming language" B. Kernighan, D. Ritchie pierwszy standard
Tablice i struktury. czyli złożone typy danych. Programowanie Proceduralne 1
Tablice i struktury czyli złożone typy danych. Programowanie Proceduralne 1 Tablica przechowuje elementy tego samego typu struktura jednorodna, homogeniczna Elementy identyfikowane liczbami (indeksem).
1 Wskaźniki i zmienne dynamiczne, instrukcja przed zajęciami
1 Wskaźniki i zmienne dynamiczne, instrukcja przed zajęciami Celem tych zajęć jest zrozumienie i oswojenie z technikami programowania przy pomocy wskaźników w języku C++. Proszę przeczytać rozdział 8.
4. Tablica dwuwymiarowa to jednowymiarowa tablica wskaźników do jednowymiarowych tablic danego typu.
Języki i paradygmaty programowania 1 studia stacjonarne 2018/19 Lab 6. Tablice znakowe o dwóch indeksach, przekazywanie tablic do funkcji cd., dynamiczna alokacja pamięci, funkcje przetwarzające ciągi
1. Pierwszy program. Kompilator ignoruje komentarze; zadaniem komentarza jest bowiem wyjaśnienie programu człowiekowi.
1. Pierwszy program // mój pierwszy program w C++ #include using namespace std; cout
main( ) main( void ) main( int argc, char argv[ ] ) int MAX ( int liczba_1, liczba_2, liczba_3 ) źle!
Funkcja wysoce niezależny blok definicji i instrukcji programu (podprogram) Każdy program napisany w języku C/C++ zawiera przynajmniej jedną funkcję o predefiniowanej nazwie: main( ). Najczęściej wykorzystuje
Zmienne, stałe i operatory
Zmienne, stałe i operatory Przemysław Gawroński D-10, p. 234 Wykład 2 4 marca 2019 (Wykład 2) Zmienne, stałe i operatory 4 marca 2019 1 / 21 Outline 1 Zmienne 2 Stałe 3 Operatory (Wykład 2) Zmienne, stałe
Operacje wejścia/wyjścia odsłona pierwsza
Bogdan Kreczmer ZPCiR IIAiR PWr pokój 307 budynek C3 bogdan.kreczmer@pwr.wroc.pl Copyright c 2005 2008 Bogdan Kreczmer Niniejszy dokument zawiera materiały do wykładu na temat programowania obiektowego.
Podstawy algorytmiki i programowania - wykład 4 C-struktury
1 Podstawy algorytmiki i programowania - wykład 4 C-struktury Treści prezentowane w wykładzie zostały oparte o: S. Prata, Język C++. Szkoła programowania. Wydanie VI, Helion, 2012 www.cplusplus.com Jerzy
Podstawowe elementy proceduralne w C++ Program i wyjście. Zmienne i arytmetyka. Wskaźniki i tablice. Testy i pętle. Funkcje.
Podstawowe elementy proceduralne w C++ Program i wyjście Zmienne i arytmetyka Wskaźniki i tablice Testy i pętle Funkcje Pierwszy program // Niezbędne zaklęcia przygotowawcze ;-) #include using
Pliki w C/C++ Przykłady na podstawie materiałów dr T. Jeleniewskiego
Pliki w C/C++ Przykłady na podstawie materiałów dr T. Jeleniewskiego 1 /24 Pisanie pojedynczych znaków z klawiatury do pliku #include void main(void) { FILE *fptr; // wkaznik do pliku, tzw. uchwyt
Wstęp do programowania 1
Wstęp do programowania 1 Struktury Bożena Woźna-Szcześniak bwozna@gmail.com Jan Długosz University, Poland Wykład 12 Struktura dla dat - przykład #include struct Date { int y; short m; short
funkcje rekurencyjne Wykład 12. Podstawy programowania (język C) Funkcje rekurencyjne (1) Funkcje rekurencyjne (2)
Podstawy programowania (język C) funkcje rekurencyjne Wykład 12. Tomasz Marks - Wydział MiNI PW -1- Tomasz Marks - Wydział MiNI PW -2- Funkcje rekurencyjne (1) W języku C funkcja moŝe wywoływać samą siebie.
Tablice wielowymiarowe. Przykład tablica 2-wymiarowa. Przykład. Przykład 3-wymiarowy. Tak naprawdę nie istnieją w C! Rozważmy tablicę o rozmiarze 3x2
Tablice wielowymiarowe Przykład tablica 2-wymiarowa Tak naprawdę nie istnieją w C! Tak naprawdę C i Java dopuszczają tworzenie tablic tablic tablica 2-wymiarowa = tablica (zwykłych) tablic tablica 3-wymiarowa
Podstawy programowania w języku C++
Podstawy programowania w języku C++ Część trzynasta Tablice struktur, pliki struktur Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie zawiera skrót treści
JĘZYK SHELL JEST PEŁNYM JĘZYKIEM PROGRAMOWANIA
JĘZYK SHELL JEST PEŁNYM JĘZYKIEM PROGRAMOWANIA, który zawiera: zmienne, konstrukcje warunkowe i iteracyjne (IF-THEN-ELSE, CASE, DO WHILE, DO UNTIL), konfigurowane środowisko użytkownika. METAZNAKI zestaw
Podstawy Programowania
Podstawy Programowania Wykład VIII Obsługa błędów, przeszukiwanie i sortowanie tablic Robert Muszyński ZPCiR IIAiR PWr Zagadnienia: źródła błędów, organizacja obsługi błędów, standardowe funkcje obsługi
Łącza nienazwane(potoki) Łącza nienazwane mogą być używane tylko pomiędzy procesami ze sobą powiązanymi.
Przykład: $ ls more Łącza nienazwane(potoki) Łącza nienazwane mogą być używane tylko pomiędzy procesami ze sobą powiązanymi. Tworzenie łącza #include int pipe(int filedes[2]); Przykład: int
Podstawy Programowania. Obsługa błędów, przeszukiwanie i sortowanie tablic
Podstawy Programowania Wykład VIII Obsługa błędów, przeszukiwanie i sortowanie tablic Robert Muszyński ZPCiR IIAiR PWr Zagadnienia: źródła błędów, organizacja obsługi błędów, standardowe funkcje obsługi
Inne darmowe! kompilatory języka C działające m.in. po systemem WINDOWS:
Inne darmowe! kompilatory języka C działające m.in. po systemem WINDOWS: IDE (ang. integrated development environment) działające online [ nie trzeba niczego instalować! ]: https://www.onlinegdb.com Wielosystemowe
Programowanie w C++ Wykład 5. Katarzyna Grzelak. 16 kwietnia K.Grzelak (Wykład 1) Programowanie w C++ 1 / 27
Programowanie w C++ Wykład 5 Katarzyna Grzelak 16 kwietnia 2018 K.Grzelak (Wykład 1) Programowanie w C++ 1 / 27 Pojęcia z poprzednich wykładów Tablica to ciag obiektów tego samego typu, zajmujacy ciagły
Wstęp do programowania
wykład 8 Agata Półrola Wydział Matematyki i Informatyki UŁ semestr zimowy 2018/2019 Podprogramy Czasami wygodnie jest wyodrębnić jakiś fragment programu jako pewną odrębną całość umożliwiają to podprogramy.
utworz tworzącą w pamięci dynamicznej tablicę dwuwymiarową liczb rzeczywistych, a następnie zerującą jej wszystkie elementy,
Lista 3 Zestaw I Zadanie 1. Zaprojektować i zaimplementować funkcje: utworz tworzącą w pamięci dynamicznej tablicę dwuwymiarową liczb rzeczywistych, a następnie zerującą jej wszystkie elementy, zapisz
Poprzedni wykład: - Elementarz formatowanego wejścia/wyjścia (podstawowe. - Sterowanie: instrukcje i bloki; instrukcja warunkowa (decyzje
Poprzedni wykład: - Elementarz formatowanego wejścia/wyjścia (podstawowe specyfikacje przekształcenia dla funkcji printf, scanf) - Sterowanie: instrukcje i bloki; instrukcja warunkowa (decyzje wielowariantowe);
Wstęp do programowania
wykład 10 Agata Półrola Wydział Matematyki i Informatyki UŁ semestr zimowy 2018/2019 Przesyłanie argumentów - cd Przesyłanie argumentów do funkcji - tablice wielowymiarowe Przekazywanie tablic wielowymiarowych
Warto też w tym miejscu powiedzieć, że w C zero jest rozpoznawane jako fałsz, a wszystkie pozostałe wartości jako prawda.
Nazwa implementacji: Nauka języka C wyrażenia warunkowe if- Autor: Piotr Fiorek Opis implementacji: Poznanie struktury oraz zastosowania wyrażeń warunkowych if- w języku C. W programie realizującym jakiś
C-struktury wykład. Dorota Pylak
C-struktury wykład Dorota Pylak C-struktury W języku C++, jak w każdym języku obiektowym, mamy możliwość definiowania własnych typów danych, wraz z określeniem operacji, jakie na tych danych można wykonywać.
Tablice deklaracja, reprezentacja wewnętrzna
Tablice deklaracja, reprezentacja wewnętrzna Tablica jest zmienną złożoną z elementów tego samego typu. Obejmuje ona ciągły obszar pamięci operacyjnej dokładnie tak duży, aby zmieścić wszystkie jej elementy.
Operacje na plikach. Informatyka. Standardowe strumienie wejścia i wyjścia
Materiały Operacje na plikach Informatyka Operacje wejścia-wyjścia w C/C++: Podejście proceduralne Podejście obiektowe Standardowe strumienie wejścia i wyjścia stdin - strumień wejściowy (klawiatura) cin
Podstawy programowania w języku C++
Podstawy programowania w języku C++ Część siódma Przetwarzanie tablic znaków Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie zawiera skrót treści wykładu,
Algorytmy i złożoności. Wykład 3. Listy jednokierunkowe
Algorytmy i złożoności Wykład 3. Listy jednokierunkowe Wstęp. Lista jednokierunkowa jest strukturą pozwalającą na pamiętanie danych w postaci uporzadkowanej, a także na bardzo szybkie wstawianie i usuwanie
Wykład VII. Programowanie. dr inż. Janusz Słupik. Gliwice, 2014. Wydział Matematyki Stosowanej Politechniki Śląskiej. c Copyright 2014 Janusz Słupik
Wykład VII Wydział Matematyki Stosowanej Politechniki Śląskiej Gliwice, 2014 c Copyright 2014 Janusz Słupik Kompilacja Kompilator C program do tłumaczenia kodu źródłowego na język maszynowy. Preprocesor
Laboratorium Systemów Operacyjnych. Ćwiczenie 4. Operacje na plikach
Laboratorium Systemów Operacyjnych Ćwiczenie 4. Operacje na plikach Wykonanie operacji wymaga wskazania pliku, na którym operacja ma zostać wykonana. Plik w systemie LINUX identyfikowany jest przez nazwę,
Wstęp do wskaźników w języku ANSI C
Wstęp do wskaźników w języku ANSI C / Materiał dydaktyczny pomocniczy do przedmiotu Informatyka sem.iii kier. Elektrotechnika/ 1. Wprowadzenie W języku ANSI C dla każdego typu X (wbudowanego, pochodnego,
Szablony klas, zastosowanie szablonów w programach
Szablony klas, zastosowanie szablonów w programach 1. Szablony klas i funkcji 2. Szablon klasy obsługującej uniwersalną tablicę wskaźników 3. Zastosowanie metody zwracającej przez return referencję do
Tablice, funkcje, wskaźniki - wprowadzenie
Tablice, funkcje, wskaźniki - wprowadzenie Przemysław Gawroński D-10, p. 234 Wykład 4 19 listopada 2018 (Wykład 4) Tablice, funkcje, wskaźniki - wprowadzenie 19 listopada 2018 1 / 37 Outline 1 Tablice
Programowanie komputerowe. Zajęcia 1
Programowanie komputerowe Zajęcia 1 Code::Blocks - tworzenie projektu Create New Project Console Application -> C++ Wybierz nazwę projektu Stworzy się nowy projekt z wpisaną funkcją main Wpisz swój program
Podstawy Programowania Podstawowa składnia języka C++
Podstawy Programowania Podstawowa składnia języka C++ Katedra Analizy Nieliniowej, WMiI UŁ Łódź, 3 października 2013 r. Szablon programu w C++ Najprostszy program w C++ ma postać: #include #include
Programowanie strukturalne i obiektowe
Programowanie strukturalne i obiektowe Język C część I Opracował: Grzegorz Flesik Literatura: A. Majczak, Programowanie strukturalne i obiektowe, Helion, Gliwice 2010 P. Domka, M. Łokińska, Programowanie
Wskaźniki a tablice Wskaźniki i tablice są ze sobą w języku C++ ściśle związane. Aby się o tym przekonać wykonajmy cwiczenie.
Część XXII C++ w Wskaźniki a tablice Wskaźniki i tablice są ze sobą w języku C++ ściśle związane. Aby się o tym przekonać wykonajmy cwiczenie. Ćwiczenie 1 1. Utwórz nowy projekt w Dev C++ i zapisz go na