Referencje. Referencje. Zasady zaliczeń. Zasady zaliczeń. Zasady zaliczeń. Zaawansowane Programowanie Obiektowe. Informacje organizacyjne:
|
|
- Franciszek Mazur
- 6 lat temu
- Przeglądów:
Transkrypt
1 Referencje Informacje organizacyjne: Wykład: środy, 13:15 14:45 Strona główna www z komunikatami: Zaawansowane Programowanie Obiektowe k.trojanowski@uksw.edu.pl maile zbiorowe i anonimowe są ignorowane (konieczne jest imię i nazwisko) 1 2 Referencje Informacje organizacyjne: Zasady zaliczenia ZPO Dodatkowo: dostęp do komunikatów nt. Programowania Obiektowego przez RSS 2.0: 1. Trzeba zaliczyć zajęcia laboratoryjne (ćwiczenia) ZPO. 2. Potem można próbować zaliczyć wykład ZPO (podejść do egzaminu). Przykładowe aplikacje do RSS 2.0: MS Win: FeedDemon Ubuntu: LightRead, Liferea Android: Feedly ios: Feedly, Newsify Nigdy w odwrotnej kolejności. 3 4 Zasady zaliczenia zajęć laboratoryjnych Zasady zaliczenia zajęć laboratoryjnych Jest 7 zajęć w semestrze. Na każdych zajęciach można uzyskać 0, 1, 2, 3, 4 lub 5 pkt. Na zajęciach zawsze ustalony jest minimalny zestaw zadań do realizacji. Wykonanie tego zestawu w całości gwarantuje co najmniej 3 pkt. Oprócz zadań zestawu minimalnego podawane są na zajęciach jeszcze inne zadania, za które można zdobyć pozostałe dwa punkty. Można mieć tylko 2 razy 0 pkt. za udział w zajęciach. Jeżeli przydarzy się to 3 razy, jedne zajęcia można odrobić na koniec semestru. Odrobienie polega na samodzielnym wykonaniu na ostatnich zajęciach dodatkowego zadania, którego zakres dotyczy całego materiału, niezależnie od tego, które zajęcia zostały zaliczone na zero i są odrabiane
2 Zasady zaliczenia zajęć laboratoryjnych Zasady zaliczenia wykładów Warunkiem koniecznym zaliczenia całego semestru jest spełnienie łącznie następujących trzech wymagań: (1) zebranie co najmniej połowy ze wszystkich możliwych do uzyskania punktów, (2) ewentualnie niezaliczenie nie więcej niż dwóch zajęć w semestrze. Wykład kończy się egzaminem pisemnym. Do egzaminu dopuszczone zostaną tylko te osoby, które wcześniej otrzymają zaliczenie z ćwiczeń. Należy je uzyskać przed rozpoczęciem sesji egzaminacyjnej. Przewidywane są dwa terminy egzaminu. 7 8 Zasady zaliczenia wykładów Zestaw egzaminacyjny będzie zawierał pytania z teorii programowania obiektowego oraz dobrych praktyk programistycznych. Na egzaminie nie będzie natomiast wymagane napisanie kodu programu. Może być jednak wymagane poprawne zinterpretowanie kodu podanego w materiale egzaminacyjnym (pytania w rodzaju: "dlaczego ten program nie zostanie skompilowany? - znajdź błąd", lub "co pojawi się w oknie konsoli po wykonaniu tego programu?". Strumienie Manipulatory bezargumentowe 9 Własne manipulatory bezargumentowe Tworzymy je jako funkcje globalne 1. z dokładnie jednym parametrem, który musi być typu referencja do strumienia ; 2. wartością zwracaną musi być ten sam odnośnik. ostream& mój_manip(ostream& strum) { // tutaj nasz kod działający na strumieniu return strum; ios_base::fmtflags flagi_domyslne; ostream& naukowy(ostream& str) { flagi_domyslne = str.flags(); str.setf(ios::showpos ios::showpoint); str.setf(ios::scientific, ios::floatfield); str.precision(12); return str; ostream& normalny(ostream& str) { str.flags(flagi_domyslne); return str; ostream& przec(ostream& str) { return str << ", "; int main(int argc, char *argv[]) { double x = ; cout << naukowy << x << przec << normalny << x << endl; Taki manipulator można wstawiać do strumienia kaskadowo wraz z innymi argumentami czy manipulatorami dzięki temu, że zwraca referencję do strumienia, na rzecz którego został wywołany
3 Własne manipulatory bezargumentowe We wszystkich przypadkach w poprzednim przykładzie parametr wywołania funkcji definiującej manipulator ma typ ostream& To daje elastyczność: nigdzie nie jest powiedziane, że to musi być cout może to być dowolny strumień reprezentowany obiektem ostream lub obiektem dowolnej klasy dziedziczącej po ostream (np. fstream, etc.) Strumienie Manipulatory z argumentami (efektory) 13 Manipulatory z argumentami Aby używać predefiniowanych manipulatorów argumentowych: #include <iomanip> setw(int szer) - ustawia szerokość pola wydruku dla najbliższej operacji na strumieniu. Działa jak opisana wcześniej metoda width(int), ale nie zwraca liczby, tylko odniesienie do strumienia. W ten sposób określana jest minimalna szerokość pola: jeśli wyprowadzana liczba zajmuje więcej znaków, to odpowiednie pole wydruku zostanie zwiększone setfill(int znak) - ustawia znak, którym będą wypełniane puste miejsca jeśli szerokość pola wydruku jest większa niż ilość wyprowadzanych znaków (domyślnie jest to znak odstępu) Manipulatory z argumentami Aby używać predefiniowanych manipulatorów argumentowych, należy dołączyć plik nagłówkowy iomanip setprecision(int prec) - ustawia precyzję jak metoda precision, ale nie jest zwracana poprzednia wartość, tylko odniesienie do strumienia setbase(int baza) - wypisuje liczby całkowite używając podstawy baza (8, 10 lub 16) Manipulatory z argumentami Uniwersalny manipulator do działania na poszczególnych flagach setiosflags(long flag) ustawia flagę formatowania tak jak jednoargumentowa metoda setf, czyli,,or uje'' argument flag z flagą stanu formatowania; resetiosflags(long flag) odpowiednik metody unsetf. Manipulatory z argumentami int j = 10; cout << j << endl; cout << hex; cout << j << endl; cout << resetiosflags(ios_base::hex); // cout.unsetf( ios_base::hex ); cout << setiosflags(ios_base::oct); // cout.setf( ios_base::oct ); cout << j << endl; Wyjście: 10 a
4 Własne manipulatory z argumentami Aby utworzyć własne manipulatory z argumentami używamy techniki tworzenia efektorów. Efektor to para: 1. Prosta klasa posiadająca pole oraz konstruktor, który pobiera parametr będący argumentem wywołania manipulatora, oraz 2. Przeciążona funkcja operator<< do wstawienia odpowiednich danych do strumienia. Efektor przykład: 1. Prosta klasa posiadająca pole oraz konstruktor: class Fixw { string str; // pole do przechowania podanej wartości public: Fixw(const string& s, int width) : str(s, 0, width) {; friend ostream& operator<<(ostream& os, const Fixw& fw); ; 2. Przeciążona funkcja, korzystająca ze zdefiniowanej klasy: ostream& operator<<(ostream& os, const Fixw& fw) { return os << fw.str; Efektor przykład: class Fixw { string str; public: Fixw(const string& s, int width) : str(s, 0, width) { friend ostream& operator<<(ostream& os, const Fixw& fw); ; ostream& operator<<(ostream& os, const Fixw& fw) { return os << fw.str; Wykorzystujemy tu konstruktor klasy string : string ( const string& str, size_t pos, size_t n = npos ); Wykorzystanie przykładowego efektora: cout << Fixw(string, i) << endl; za pomocą wywołania konstruktora Fixw tworzony jest obiekt tymczasowy, który jest przekazywany do globalnej funkcji operator<< Obiekt tymczasowy typu Fixw pozostaje w pamięci aż do zakończenia instrukcji. zawartość obiektu inicjalizujemy łańcuchem tekstowym z którego bierzemy fragment zaczynający się od pozycji pos i o długości n Efektor inny przykład: typedef unsigned long ulong; class Bin { ulong n; public: Bin(ulong nn) { n = nn; friend ostream& operator<<(ostream& os, const Bin& b); ; friend ostream& operator<<(ostream& os, const Bin& b) { const ulong ULMAX = numeric_limits<ulong>::max(); ulong bit = ~(ULMAX >> 1); // ustawiamy najwyższy bit while(bit) { os << (b.n & bit? '1' : '0'); bit >>= 1; Wykorzystanie przykładowego efektora: ostringstream s; s << Bin(0x UL); ~(ULMAX >> 1) daje wartość unsigned long z ustawionym najstarszym bitem. Wartość ta jest przesuwana w prawo w kolejnych iteracjach pętli while. Efektor Bin wykorzystuje fakt, że przesunięcie liczby bez znaku w prawo wstawia zera na starsze bity. UKSW, return WMP. SNS, Warszawa os; ; 4
5 UWAGA! Tyle informacji wystarczy, żeby wykonać zadania dotyczące dostępu do plików za pomocą strumieni, jakie będą realizowane na ćwiczeniach. Strumienie Buforowanie danych 25 Buforowanie strumieni Dane znajdujące się w strumieniu należy interpretować zgodnie z ich znaczeniem, ale zawsze należy pamiętać, że są to po prostu sekwencje bajtów. Za obsługę bajtową danych strumieniowych odpowiedzialny jest obiekt typu streambuf (dokładny typ zależy od tego, czy jest to strumień reprezentujący standardowe we/wy, plik, itd.) Do tego obiektu można sięgać bezpośrednio: można np. przesunąć się o określoną liczbę bajtów bez ich formatowania przez strumień Buforowanie strumieni Aby umożliwić sięgnięcie do obiektu streambuf, każdy obiekt iostream zawiera metodę rdbuf(): basic_streambuf<elem, Traits> *rdbuf( ) const; zwraca wskaźnik do bufora strumieniowego. basic_streambuf<elem, Traits> *rdbuf( basic_streambuf<e, T> *_Sb); umieszcza bufor strumieniowy podany w argumencie w miejsce poprzedniego, a wskaźnik do poprzedniego zwraca jako rezultat Buforowanie strumieni przykład: int main( ) { ofstream file( "Test3.txt" ); streambuf *x = cout.rdbuf( file.rdbuf( ) ); // podmiana.. cout << "test1" << endl; // dane są zapisywane do pliku cout.rdbuf(x); cout << "test2" << endl; ifstream in( "Test3.txt" ); cout << in.rdbuf(); // jednym ruchem cały plik! Buforowanie strumieni przykład: Aby przekazać wszystkie znaki z jednego strumienia do drugiego napisaliśmy: cout << in.rdbuf(); Zastępuje to żmudne (i podatne na błędy) odczytywanie kolejnych znaków lub wierszy, jest też szybsze. Okno terminala: test2 test
6 Przypomnienie metoda get: int_type get( ); basic_istream& get( char_type& _Ch ); basic_istream& get(char_type *_Str, streamsize _Count); basic_istream& get( char_type *_Str, streamsize _Count, char_type _Delim ); Przerywa swoje działanie zaraz po znalezieniu ogranicznika, ale tego ogranicznika już nie pobiera ze strumienia. char c[10]; c[0] = cin.get( ); // pobiera jeden element cin.get( c[1] ); // pobiera jeden element cin.get( &c[2],3 );// pobiera do napotkania znaku \n, ale max. 3 cin.get( &c[4], 4, '7' );// pobiera do napotkania znaku 7, ale max. 4 cout << c << endl; Buforowanie strumieni Istnieje również wersja metody get, która potrafi pisać bezpośrednio do obiektu streambuf (a nie tylko do C-napisu): basic_istream& get( basic_streambuf<elem, Tr> *_Strbuf); basic_istream& get( basic_streambuf<elem, Tr> *_Strbuf, char_type _Delim); Zawartość pliku Test.txt: ifstream in( "Test.txt" ); streambuf &sb = *cout.rdbuf(); while(!in.get(sb).eof()) cout << char(in.get()); in.get(sb) pobiera wiersz znaków do napotkania \n, ale tego znaku już nie pobiera i wysyła do sb in.get() pobiera jeden znak Kiedy Kara Mustafa, wielki mistrz Krzyżaków, szedł z licznymi zastępy przez Alpy na Kraków, do obrony swych posad zawsze będąc skory pobił go pod Grunwaldem król Stefan Batory. Wada: Jeżeli w pliku trafi się pusta linia, in.get(sb) nic nie wypisze i zwróci błąd. 33 ifstream in( "Test3.txt" ); streambuf &sb = *cout.rdbuf(); while(!in.get(sb).eof()) { if (in.fail()) // znaleziono pusty wiersz in.clear(); // czyścimy flagę błędu cout << char(in.get()); in.get(sb) pobiera wiersz znaków do napotkania \n, ale tego znaku już nie pobiera i wysyła do sb in.get() pobiera jeden znak 34 Przeszukiwanie strumieni we/wy W każdym typie strumienia iostream istnieje pojęcie następnego znaku do odczytania lub zapisania. Możemy przesuwać się po znakach w strumieniu w przód i w tył, wskazując określone bezwzględne położenie albo przesunięcie względem położenia bieżącego. Określanie położenia: pos_type tellp( ); pos_type tellg( ); (do użycia z ostream) (do użycia z istream) ifstream file; char c; int i; file.open( "basic_istream_tellg.txt" ); i = file.tellg( ); file >> c; cout << c << " " << i << endl; // pojawi się znak i 0 i = file.tellg( ); file >> c; cout << c << " " << i << endl; // pojawi się znak i
7 Przesunięcie się w strumieniu: basic_ostream& seekp( pos_type _Pos ); basic_istream& seekg( pos_type _Pos ); (do użycia z ostream) (do użycia z istream) Przesunięcie się w strumieniu: basic_ostream& seekp( off_type _Off, ios_base::seekdir _Way ); basic_istream& seekg( off_type _Off, ios_base::seekdir _Way ); Metody jednoargumentowe pozwalają przesunąć się w określone miejsce: ofstream x( "iotest.txt" ); int i = x.tellp( ); // zwróci 0 cout << i << endl; x << " "; i = x.tellp( ); // zwróci 10 cout << i << endl; x.seekp( i-5 ); x << " "; // gdzie zostanie umieszczony znak spacji? Metody dwuargumentowe pozwalają przesunąć się o określony offset względem początku, końca lub bieżącego położenia: ios::beg od początku ios::cur od aktualnego położenia ios::end od końca strumienia Wartość przesunięcia jako liczba dodatnia przesuwa w prawo a ujemna w lewo Przesunięcie się w strumieniu przykład: ofstream x( "iotest.txt" ); int i = x.tellp( ); // pobieramy aktualne położenie w pliku cout << i << endl; x << " "; i = x.tellp( ); // pobieramy aktualne położenie w pliku cout << i << endl; x.seekp( i - 5 ); // zmieniamy aktualne położenie w pliku x << " "; ifstream file; char c, c1; file.open( test.txt" ); file.seekg(2); file >> c; cout << c << endl; file.seekg( 0, ios_base::beg); file >> c; cout << c << endl; Plik wejściowy test.txt: x.seekp( -2, ios::end ); // jeszcze raz zmieniamy.. x << "#"; // Po wykonaniu kodu plik zawiera: #0 file.seekg( -1, ios_base::end); file >> c1; cout << c1 << endl; W oknie konsoli: Tworzenie obiektu strumienia umożliwiającego pisanie i czytanie ifstream in2("test.txt", ios::in ios::out); ostream out2(in2.rdbuf()); cout << in2.rdbuf() << endl; out2 << "ile Roman ładny dyndał na moreli"; out2.seekp(0, ios::beg); out2 << "jeż leje lwa paw leje lżej"; in2.seekg(0, ios::beg); cout << in2.rdbuf() << endl; Strumienie powiązane z łańcuchami <sstream> Plik wejściowy test.txt:!!!!!@@@@@#####$$$$$%%%%%----- W oknie konsoli:!!!!!@@@@@#####$$$$$%%%%%----- jeż leje lwa, paw leje lżej---ile Roman ładny dyndał na moreli? Dlaczego tekst pierwszy dodawany jest na końcu pliku?
8 Łańcuchowe strumienie wejściowe #include <cassert> #include <cmath> // fabs() #include <limits> // epsilon() #include <sstream> #include <string> int main( ) { istringstream s(" To tylko taki test"); int i; double f; s >> i >> f; assert(i == 47); double relerr = (fabs(f) ) / 1.414; assert(relerr <= numeric_limits<double>::epsilon()); Łańcuchowe strumienie wejściowe int main( ) { istringstream s(" To tylko taki test"); int i; double f; s >> i >> f; assert(i == 47); double relerr = (fabs(f) ) / 1.414; assert(relerr <= numeric_limits<double>::epsilon()); string buf2; s >> buf2; assert(buf2 == "To"); cout << s.rdbuf() << endl; // " tylko taki test" Łańcuchowe strumienie wejściowe Pobieranie wartości do zmiennych odbywa się zgodnie z ich typem: istringstream s(" To tylko taki test"); int i; double f; s >> i >> f; // i=47 f = Gdyby zmienić kolejność liczb w ciągu: istringstream s(" To tylko taki test"); wtedy: s >> i >> f; // i=1 f = Łańcuchowe strumienie wyjściowe int main() { cout << "napisz wartości int, float i string: "; int i; float f; cin >> i >> f; cin >> ws; // odrzuć białe znaki string stuff; getline(cin, stuff); // pobierz do końca wiersza ostringstream os; os << "integer = " << i << endl; os << "float = " << f << endl; os << "string = " << stuff << endl; string result = os.str(); cout << result << endl; Użycie dwukierunkowego strumienia łańcuchowego int main() { string text = "W Moskwie na Placu Czerwonym"; stringstream ss(text); ss.seekp(0, ios::end); ss << " rozdają samochody."; assert(ss.str() == "W Moskwie na Placu Czerwonym rozdają samochody."); ss.seekg(18, ios::beg); string word; ss >> word; assert(word == "Czerwonym"); ss.seekp(2, ios::beg); ss << "Kijowie"; ss.seekg(29, ios::beg); ss >> word; assert(word == "rozdają"); ss.seekp(37, ios::beg); ss << "rowery.."; cout << ss.str() << endl; Strumienie Binarny dostęp do danych 47 8
9 Binarny dostęp do danych: Do odczytu danych ze strumienia w taki sposób, aby można je było interpretować jako ciąg binarny! służy: basic_istream& read( char_type *_Str, streamsize _Count ); Funkcja odczytuje określoną liczbę bajtów _Count i zapisuje ją pod wskazany adres wskaźnik _Str. Jeżeli wcześniej napotka koniec pliku, przerywa odczyt i kończy działanie ustawiając odpowiednią flagę błędu. Ciąg binarny ciąg bajtów (nie bitów!). Interpretacja danych dowolnych typów jako ciąg binarny polega na odczytaniu tych danych z pominięciem informacji o ich strukturze, tj. bajt po bajcie (nie bit po bicie!). Binarny dostęp do danych: Do zapisu danych do strumienia służy: basic_ostream& write( const char_type *_Str, streamsize _Count ); Aby zastosować tę funkcję do korzystania z pliku w trybie binarnym, należy obszary pamięci, do który dane mają trafić (lub skąd mają być pobrane), zrzutować na wskaźniki typu const char_type* (zapis do strumienia) lub char_type* (odczyt ze strumienia) Binarny dostęp do danych: struct Bloczek { int a; double b; char c; ; int main( ) { ofstream ofx( "test.txt", ios::binary); Bloczek s={3,3.14,'a'; const char *pom = (const char*)&s; ofx.write((char*)&s, sizeof(s)); ofx.write(pom, sizeof(s)); ofx.close(); ifstream ifx( "test.txt",ios::binary); Bloczek s2; char *pom2 = (char*)&s2; ifx.read((char*)&s2, sizeof(s2)); ifx.read(pom2, sizeof(s2)); cout << s2.a << s2.b << s2.c; C++ Podział kodu programu na pliki 51 Podział kodu programu na pliki Dzielenie kodu na kilka plików źródłowych Duży kod warto dzielić na fragmenty o wspólnej funkcjonalności (np. funkcje numeryczne, funkcje we/wy, funkcje dostępu do plików, itp.) Fragmenty należy umieszczać w oddzielnych plikach. Tworząc biblioteki, dla każdego fragmentu tworzymy dwa pliki: z deklaracjami i z definicjami. Np. biblioteka z funkcjami do sortowania mogłaby mieć pliki: sortowanie.h i sortowanie.cpp Pliki z deklaracjami dołączamy do naszego pliku za pomocą dyrektywy #include Podział kodu programu na pliki Dzielenie kodu na kilka plików źródłowych Preprocesor kodu Jest uruchamiany przed kompilatorem Przegląda kod i działa zgodnie z dyrektywami preprocesora znalezionymi w tekście (dyrektywa zaczyna się znaczkiem # (płotek, hasz) a kończy z końcem wiersza). Np. dokonuje interpretacji dyrektywy #include, tj. połączenia kilku plików w jedną postać. Są też inne dyrektywy
10 Podział kodu programu na pliki Dzielenie kodu na kilka plików źródłowych Preprocesor kodu #define makrodefinicja ciąg_znaków wystąpienie nazwy makrodefinicji jest automatycznie zastąpione ciągiem znaków. #if, #elif, #else, #endif: #define SYSTEM 1 #if (SYSTEM == 1) //moduł dla UNIX-a #elif (SYSTEM == 2) //moduł dla Solarisa #elif (SYSTEM == 3) //moduł dla Windows #else //moduł niezdefiniowany!: #endif 55 Podział kodu programu na pliki lib.h: #ifndef LIB_H #define LIB_H #include <cstdio> #include <cstring> using namespace std; class MojaKlasa { char ** ; int ile; public: MojaKlasa(int x); ~MojaKlasa(); MojaKlasa(MojaKlasa& mk); void set (char* adres, int idx); char* get (int idx); ; #endif lib.cpp: #include "lib.h" MojaKlasa:: MojaKlasa(int x) { = new char*[ile = x]; for (int i=0;i<ile;i++) { [i] = new char[100]; [i][0] = '\0'; MojaKlasa::~MojaKlasa() { printf("%s\n", [0]); for (int i=0;i<ile;i++) delete [] [i]; delete [] ; printf("!\n"); // pozostałe metody tej klasy 56 ISO/ANSI C - biblioteki Dzielenie kodu na kilka plików źródłowych ISO/ANSI C - biblioteki lib.h Preprocesor dołączy plik do plików cpp Proces kompilacji jest dwuetapowy: 1. Poszczególne pliki *.c kompilowane są kolejno; kody funkcji bibliotecznych nie są jeszcze konieczne (wystarczą same nagłówki). 2. Pliki wynikowe kompilacji są łączone (linkowane) w jeden plik *.exe lib.cpp #include "lib.h" main.cpp #include "lib.h" lib.obj POdemo.exe main.obj 57 1> Rebuild All started: Project: ZPOdemo2014, Configuration: Debug Win > main.cpp 1> lib.cpp 1> Generating Code... 1> ZPOdemo2014.vcxproj -> D:\ZPOdemo2014\Debug\ZPOdemo2014.exe ========== Rebuild All: 1 succeeded, 0 failed, 0 skipped ========== 58 ISO/ANSI C - biblioteki Klasa A Klasa B Klasa D Klasa E main.cpp ISO/ANSI C - biblioteki Alternatywą dla: #ifndef nazwapliku_h #define nazwapliku_h /* tutaj deklaracje funkcji */ #endif jest #pragma once Każdy z plików cpp zawiera dyrektywę #include swojego własnego pliku nagłówkowego. Co będą zawierały poszczególne pliki cpp po wykonaniu wszystkich dyrektyw kompilatora? zapobiega wielokrotnemu załączeniu treści całego pliku. Ale nie należy do standardu ANSI
Referencje. Zasady zaliczeń. Zasady zaliczeń. Zasady zaliczeń. Zasady zaliczeń. Zaawansowane Programowanie Obiektowe. Informacje organizacyjne:
Referencje Informacje organizacyjne: Wykład: środy, 15:00 16:30 Strona główna www z komunikatami dla ZPO: http://t roja.u ksw.ed u.pl/c ategor y/zpo2 018/ Zaawansowane Programowanie Obiektowe E-mail: k.trojanowski@uksw.edu.pl
Referencje. Zasady zaliczeń. Zasady zaliczeń. Zasady zaliczeń. Zasady zaliczeń. Zaawansowane Programowanie Obiektowe. Informacje organizacyjne:
Referencje Informacje organizacyjne: Wykład: środy, 13:15 14:45 Strona główna www z komunikatami dla ZPO: http://troja.uksw.edu.pl/category/zpo2017/ Zaawansowane Programowanie Obiektowe E-mail: k.trojanowski@uksw.edu.pl
Wykład II. Programowanie II - semestr II Kierunek Informatyka. dr inż. Janusz Słupik. Wydział Matematyki Stosowanej Politechniki Śląskiej
Wykład II - semestr II Kierunek Informatyka Wydział Matematyki Stosowanej Politechniki Śląskiej Gliwice, 2015 c Copyright 2015 Janusz Słupik Operacje dyskowe - zapis do pliku #include #include
Referencje. Zasady zaliczeń. Zasady zaliczeń. Zasady zaliczeń. Zasady zaliczeń. Zaawansowane Programowanie Obiektowe. Informacje organizacyjne:
Referencje Informacje organizacyjne: Wykład: wtorki, 15:00 16:30 Strona główna www z komunikatami dla ZPO: http://troja.uksw.edu.pl/category/zpo2016/ Zaawansowane Programowanie Obiektowe E-mail: k.trojanowski@uksw.edu.pl
Programowanie w językach
Programowanie w językach wysokiego poziomu Obsługa plików za pomocą strumieni Elektronika i Telekomunikacja, semestr III rok akademicki 2013/2014 dr inż. Paweł Myszkowski Plan zajęć a) otwieranie i zamykanie
Wejście wyjście strumieniowe
PARADYGMATY PROGRAMOWANIA Wykład 6 Wejście wyjście strumieniowe stdin standardowy strumień wejściowy stdout standardowy strumień wyjściowy stderr standardowy strumień komunikatów o błędach pliki - inne
C++ - [3-5] Pliki i strumienie w C++
Slajd 1 z 13 C++ - [3-5] Pliki i strumienie w C++ Nysa 2004-2013. Autor: Wojciech Galiński. wersja dnia 19 maja 2013 r. Slajd 2 z 13 Klasy i obiekty do obsługi plików Aby korzystać z obiektów do obsługi
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
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
Operacje wejścia/wyjścia (odsłona druga) - pliki
Operacje wejścia/wyjścia (odsłona druga) - pliki 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
Pliki wykład 2. Dorota Pylak
Pliki wykład 2 Dorota Pylak Struktura programu działającego na plikach 1) Dyrektywa preprocesora #include //zapewnia dostęp do strumieni ifstream i ofstream 2) deklaracja zmiennej (strumienia)
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
Wykład 9 2014-06-20 09:37 PP2_W9
Wykład 9 Przykłady programów z wykorzystaniem klas - przykład funkcji operatorowych - obiektowa implementacja listy jednokierunkowej kopiowanie obiektów - klasa "latający napis" Pozycjonowanie w plikach
Programowanie w C++ Wykład 11. Katarzyna Grzelak. 21 maja K.Grzelak (Wykład 11) Programowanie w C++ 1 / 24
Programowanie w C++ Wykład 11 Katarzyna Grzelak 21 maja 2018 K.Grzelak (Wykład 11) Programowanie w C++ 1 / 24 Strumienie Strumień bajtów płynacy od źródła do ujścia: 1 standardowe strumienie wejściowe
Wstęp do programowania obiektowego
Wstęp do programowania obiektowego KLASA ISTREAM KLASA OSTREAM MANIPULATORY STRUMIENIOWE STRUKTURY W C++ DOMYŚLNE WARTOŚCI PARAMETRÓW KONSTRUKTORY I DESTRUKTORY KLAS POCHODNYCH KONSTRUKTOR KOPIUJĄCY POLIMORFIZM
jest mocny, skoro da się w nim wyrazić nowe pojęcia; łatwiej przenieść go na nową platformę jest mniejszy.
Wejście-wyjście Nie jest elementem języka C++ Niezbyt istotne dla użytkownika, ważne dla języka: jest mocny, skoro da się w nim wyrazić nowe pojęcia; łatwiej przenieść go na nową platformę jest mniejszy.
Programowanie Obiektowe i C++
Programowanie Obiektowe i C++ Marcin Benke Instytut Informatyki UW 13.11.2006 Marcin Benke (IIUW) Programowanie Obiektowe i C++ 13.11.2006 157 / 201 Wejście-wyjście Nie jest elementem języka C++ Niezbyt
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ęść
Spis treści OBSŁUGA PLIKÓW W JĘZYKU C++ Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu. Numer ćwiczenia INF32
Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 2 Kod przedmiotu: ES1C300 016 (studia stacjonarne)
Programowanie obiektowe
Programowanie obiektowe 10.04.2017 W slajdach są materiały zapożyczone z https://www.ii.uni.wroc.pl/~prz/2012lato/cpp/slajdy/cpp5.ppt Przykład wykorzystania obiektu Obiekt X jest instancją klasy Y Obiekt
Programowanie w C++ Wykład 8. Katarzyna Grzelak. 15 kwietnia K.Grzelak (Wykład 8) Programowanie w C++ 1 / 33
Programowanie w C++ Wykład 8 Katarzyna Grzelak 15 kwietnia 2019 K.Grzelak (Wykład 8) Programowanie w C++ 1 / 33 Klasy - powtórzenie Klasy typy definiowane przez użytkownika Klasy zawieraja dane składowe
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
Wykład 2 Operacje wejściawyjścia. Ewa Gajda
Wykład 2 Operacje wejściawyjścia w C++ Ewa Gajda Strumienie Operacje wejścia-wyjścia w C++ realizowane są przy pomocy tak zwanych strumieni. Strumieo można sobie wyobrażad jako ciąg znaków bądź bajtów
Dziedziczenie & W slajdach są materiały zapożyczone z https://www.ii.uni.wroc.pl/~prz/2012lato/cpp/slajdy/cpp5.
Dziedziczenie 27.04.2016 & 04.05.2016 W slajdach są materiały zapożyczone z https://www.ii.uni.wroc.pl/~prz/2012lato/cpp/slajdy/cpp5.ppt class A{ private: int x, y; public: void setvaluex(); void setvaluey();
Programowanie Obiektowo Zorientowane w języku c++ Przestrzenie nazw
Programowanie Obiektowo Zorientowane w języku c++ Przestrzenie nazw Mirosław Głowacki 1 1 Akademia Górniczo-Hutnicza im. Stanisława Staszica w Ktrakowie Wydział Inżynierii Metali i Informatyki Stosowanej
Programowanie w C++ Wykład 12. Katarzyna Grzelak. 20 maja K.Grzelak (Wykład 12) Programowanie w C++ 1 / 32
Programowanie w C++ Wykład 12 Katarzyna Grzelak 20 maja 2019 K.Grzelak (Wykład 12) Programowanie w C++ 1 / 32 Klasy - powtórzenie Klasy typy definiowane przez użytkownika Klasy zawieraja dane składowe
PROE wykład 3 klasa string, przeciążanie funkcji, operatory. dr inż. Jacek Naruniec
PROE wykład 3 klasa string, przeciążanie funkcji, operatory dr inż. Jacek Naruniec Przypomnienie z ostatnich wykładów Konstruktory/destruktory i kolejność ich wywołania w złożonej klasie. Referencja Obiekty
Programowanie w C++ Wykład 9. Katarzyna Grzelak. 14 maja K.Grzelak (Wykład 9) Programowanie w C++ 1 / 30
Programowanie w C++ Wykład 9 Katarzyna Grzelak 14 maja 2018 K.Grzelak (Wykład 9) Programowanie w C++ 1 / 30 Klasy - powtórzenie Klasy typy definiowane przez użytkownika Klasy zawieraja dane składowe plus
Język C++ wykład VIII
Programowanie uzupełnienie notatek: dr Jerzy Białkowski 1 2 3 4 Obiektowość języka C++ ˆ Klasa (rozszerzenie struktury), obiekt instancją klasy, konstruktory i destruktory ˆ Enkapsulacja - kapsułkowanie,
C++ - strumienie. C++ - strumienie. C++ - strumienie. C++ - strumienie. C++ - strumienie. C++ - strumienie
Ustawianie szerokości, wypełnienia i dokładności: streamsize precision( ) const; streamsize precision( streamsize _Prec ); Metoda zwraca precyzję liczb zmiennoprzecinkowych lub ją ustawia. Precyzja określa,
Wstęp do programowania. Wykład 1
Wstęp do programowania Wykład 1 1 / 49 Literatura Larry Ullman, Andreas Signer. Programowanie w języku C++. Walter Savitch, Kenrick Mock. Absolute C++. Jerzy Grębosz. Symfonia C++. Standard. Stephen Prata.
C++ - strumienie. Strumienie. C++ - strumienie. C++ - strumienie. C++ - strumienie. C++ - strumienie. Formatowanie strumieni wyjściowych
Formatowanie strumieni wyjściowych Każda klasa reprezentująca strumień ma tzw. flagi, opisujące stan strumienia. W szczególności sposób działania operatorów we/wy określony jest aktualnym stanem flag stanu
Techniki programowania INP001002Wl rok akademicki 2018/19 semestr letni. Wykład 5. Karol Tarnowski A-1 p.
Techniki programowania INP001002Wl rok akademicki 2018/19 semestr letni Wykład 5 Karol Tarnowski karol.tarnowski@pwr.edu.pl A-1 p. 411B Plan prezentacji Przestrzenie nazw Standardowa biblioteka szablonów
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.
Pliki wykład 2 -przekazywanie strumieni do funkcji -funkcje get(char &) i getline(string)
Pliki wykład 2 -przekazywanie strumieni do funkcji -funkcje get(char &) i getline(string) Dorota Pylak Struktura programu działającego na plikach 2 1) Dyrektywa preprocesora #include //zapewnia
Klasa iostream... 1 Klasy ofstream, ifstream Struktura FILE... 8
12.1 12.2 Klasa iostream... 1 Klasy ofstream, ifstream... 3 12.3 Struktura FILE... 8 12.1 Klasa iostream Obiekty klasy stream tworzone automatycznie: istream& cin, standardowe wejście konsoli (klawiatura).
Operatory na rzecz typu TString
Operatory na rzecz typu TString Dopiszmy w definicji klasy operator[], dzięki któremu potraktujemy obiekt jak tablicę class TString { public: char& operator[]( size_t n ); const char& operator[]( size_t
Pliki wykład 2. Dorota Pylak
Pliki wykład 2 Dorota Pylak Struktura programu działającego na plikach 1) Dyrektywa preprocesora #include //zapewnia dostęp do strumieni ifstream i ofstream 2) deklaracja zmiennej (strumienia)
Referencje. Programowanie w C/C++ Zasady zaliczeń. Referencje. Zasady zaliczeń. Zasady zaliczeń. Informacje organizacyjne: Krzysztof Trojanowski
Referencje Informacje organizacyjne: Krzysztof Trojanowski Wykład: środy, 13:15 14:45 Programowanie w C/C++ Informacje organizacyjne Strona główna www z komunikatami: http://troja.uksw.edu.pl/category/pro2017/
Pliki wykład. Dorota Pylak
Pliki wykład Dorota Pylak Pliki 2 Większość programów komputerowych korzysta z plików, np. w edytorach tekstów tworzymy pliki dokumentów. Plik (ang. file) jest porcją danych zapisanych na jakimś nośniku.
Wstęp do programowania obiektowego. Przekazywanie parametrów do funkcji w C++ Metody i funkcje operatorowe Strumienie: standardowe, plikowe, napisowe
Wstęp do programowania obiektowego Przekazywanie parametrów do funkcji w C++ Metody i funkcje operatorowe Strumienie: standardowe, plikowe, napisowe 1 PRZEKAZYWANIE PARAMETRÓW DO FUNKCJI W C++ 2 W C++
Techniki programowania INP001002Wl rok akademicki 2017/18 semestr letni. Wykład 5. Karol Tarnowski A-1 p.
Techniki programowania INP001002Wl rok akademicki 2017/18 semestr letni Wykład 5 Karol Tarnowski karol.tarnowski@pwr.edu.pl A-1 p. 411B Plan prezentacji Standardowa biblioteka szablonów (Standard Template
1 Wskaźniki. 1.1 Główne zastosowania wskaźników
1 Wskaźniki Wskaźnik (ang. pointer) jest obiektem (zmienną) przechowującym adres pamięci. Definiowanie wskaźników: typ *nazwa wskaznika; np.: int *wsk na x;, double *xxx;, char *znak;. Aby można było pracować
Pliki wykład. Dorota Pylak
Pliki wykład Dorota Pylak Pliki 2 Większość programów komputerowych korzysta z plików, np. w edytorach tekstów tworzymy pliki dokumentów. Plik (ang. file) jest porcją danych zapisanych na jakimś nośniku.
C++ - szablony. C++ - szablony. C++ - szablony. C++ - szablony. C++ - szablony. C++ - szablony
Słowo kluczowe class w linii: template nie oznacza, że T1 i T2 mogą być tylko klasami (jak widać na przykładzie); mogą to być dowolne typy (wbudowane lub definiowane przez użytkownika)
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
Paostwowa Wyższa Szkoła Zawodowa w Płocku Dariusz Wardowski
Paostwowa Wyższa Szkoła Zawodowa w Płocku Dariusz Wardowski dr Dariusz Wardowski, Instytut Matematyki i Informatyki PWSZ w Płocku 1 O mnie prowadzący wykład i laboratoria: Dariusz Wardowski pokój: 102
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
public: // interfejs private: // implementacja // składowe klasy protected: // póki nie będziemy dziedziczyć, // to pole nas nie interesuje
Zbudujemy klasę Definicję klasy zapiszmy w pliku tstring.h #ifndef TSTRING_H #define TSTRING_H #include // w pliku nagłówkowym NIE // otwieramy przestrzeni std // interfejs private: // implementacja
Wstęp do informatyki- wykład 8 Pętla while, do while,for -pętla w pętli- przykłady Operator rzutowania Manipulatory
1 Wstęp do informatyki- wykład 8 Pętla while, do while,for -pętla w pętli- przykłady Operator rzutowania Manipulatory Treści prezentowane w wykładzie zostały oparte o: S. Prata, Język C++. Szkoła programowania.
Programowanie Procedurale. Pliki w języku C++
Programowanie Procedurale. Pliki w języku C++ Bożena Woźna-Szcześniak bwozna@gmail.com Jan Długosz University, Poland Wykład 10 Bożena Woźna-Szcześniak (AJD) Programowanie Procedurale. Pliki w języku C++
Operacje na plikach (niskiego poziomu) < IO.H >
OPERACJE WEJŚCIA WYJŚCIA (część b) Operacje wejścia / wyjścia odczyt i zapis danych do róŝnych zewnętrznych urządzeń lub nośników pamięciowych komputera: np. klawiatury, ekranu monitora, dyskietki, czytnika
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
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,
1 P roste e t ypy p d a d n a ych c - c ąg ą g d a d l a szy 2 T y T py p z ł z o ł żo ż ne e d a d n a ych c : T BLICE
1. Proste typy danych- ciąg dalszy 2. Typy złożone danych : TABLICE Wykład 3 ZMIENNE PROSTE: TYPY WBUDOWANE Typy zmiennoprzecinkowe: float double long double Różne rozmiary bajtowe. W konsekwencji różne
Programowanie - wykład 4
Programowanie - wykład 4 Filip Sośnicki Wydział Fizyki Uniwersytet Warszawski 20.03.2019 Przypomnienie Prosty program liczący i wyświeltający wartość silni dla wprowadzonej z klawiatury liczby: 1 # include
1 Pierwsze kroki w C++ cz.3 2 Obsługa plików
1 Pierwsze kroki w C++ cz.3 2 Obsługa plików Do pracy z plikami zewnętrznymi niezbędna będzie biblioteka fstream. Udostępnia ona programiście narzędzia do zapisu i odczytu plików. 2.1 Typ zmiennej fstream.
IMIĘ i NAZWISKO: Pytania i (przykładowe) Odpowiedzi
IMIĘ i NAZWISKO: Pytania i (przykładowe) Odpowiedzi EGZAMIN PIERWSZY (25 CZERWCA 2013) JĘZYK C++ poprawiam ocenę pozytywną z egzaminu 0 (zakreśl poniżej x) 1. Wśród poniższych wskaż poprawną formę definicji
Programowanie w C++ Wykład 1. Katarzyna Grzelak. 26 luty K.Grzelak (Wykład 1) Programowanie w C++ 1 / 28
Programowanie w C++ Wykład 1 Katarzyna Grzelak 26 luty 2018 K.Grzelak (Wykład 1) Programowanie w C++ 1 / 28 Dlaczego programowanie? K.Grzelak (Wykład 1) Programowanie w C++ 2 / 28 Umiejętność, która otwiera
4. Wyrzuć wyjątek jeśli zmienna ist nie istnieje bloki: try, catch i wyrzucanie wyjątku
Lista 7 Zad. 1 Pierwsza wersja programu 1. Przygotuj plik do w: plik tekstowy z pojedynczą liczbą. Umieść go w tym samym folderze, co projekt (*.cpp). 2. Nazwa pliku name nazwa zmiennej może być dowolna
Programowanie C++ Wykład 2 - podstawy języka C++ dr inż. Jakub Możaryn. Warszawa, Instytut Automatyki i Robotyki
Wykład 2 - podstawy języka C++ Instytut Automatyki i Robotyki Warszawa, 2014 Wstęp Plan wykładu Struktura programu. Zmienne i ich nazwy, podstawowe typy: całkowite, rzeczywiste, znakowe i napisowe. Instrukcje:
Cwiczenie nr 1 Pierwszy program w języku C na mikrokontroler AVR
Cwiczenie nr 1 Pierwszy program w języku C na mikrokontroler AVR Zadanie polega na napisaniu pierwszego programu w języku C, jego poprawnej kompilacji i wgraniu na mikrokontroler. W tym celu należy zapoznać
Wykład. Materiały bazują częściowo na slajdach Marata Dukhana
Wykład Materiały bazują częściowo na slajdach Marata Dukhana Języki programowania Kompilowane np. C, C++, Pascal Interpretowane np. JavaScript, PHP, Python, VBA Pośrednie np. Java, C# Znane kompilatory
Programowanie i struktury danych
Programowanie i struktury danych Wykªad 3 1 / 37 tekstowe binarne Wyró»niamy dwa rodzaje plików: pliki binarne pliki tekstowe 2 / 37 binarne tekstowe binarne Plik binarny to ci g bajtów zapami tanych w
Język C++ Różnice między C a C++
Język C++ Różnice między C a C++ Plan wykładu C a C++ Różnice ogólne Typy Deklaracje zmiennych C++ jako rozszerzenie C Domyślne argumenty funkcji Przeciążanie funkcji Referencje Dynamiczny przydział pamięci
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
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.
Programowanie w C++ Wykład 11. Katarzyna Grzelak. 13 maja K.Grzelak (Wykład 11) Programowanie w C++ 1 / 30
Programowanie w C++ Wykład 11 Katarzyna Grzelak 13 maja 2019 K.Grzelak (Wykład 11) Programowanie w C++ 1 / 30 Klasy cd K.Grzelak (Wykład 11) Programowanie w C++ 2 / 30 Klasy - powtórzenie Klasy typy definiowane
Programowanie w C++ Wykład 12. Katarzyna Grzelak. 28 maja K.Grzelak (Wykład 12) Programowanie w C++ 1 / 27
Programowanie w C++ Wykład 12 Katarzyna Grzelak 28 maja 2018 K.Grzelak (Wykład 12) Programowanie w C++ 1 / 27 Klasy cd K.Grzelak (Wykład 12) Programowanie w C++ 2 / 27 Klasy - powtórzenie Klasy typy definiowane
Laboratorium 1 Temat: Przygotowanie środowiska programistycznego. Poznanie edytora. Kompilacja i uruchomienie prostych programów przykładowych.
Laboratorium 1 Temat: Przygotowanie środowiska programistycznego. Poznanie edytora. Kompilacja i uruchomienie prostych programów przykładowych. 1. Przygotowanie środowiska programistycznego. Zajęcia będą
Pytania sprawdzające wiedzę z programowania C++
Pytania sprawdzające wiedzę z programowania C++ Wstęp 1. Zaprezentuj mechanikę tworzenia programu napisanego w języku C++. 2. Co to jest kompilacja? 3. Co to jest konsolidacja? 4. Co to jest kod wykonywalny?
Wykład I. Programowanie II - semestr II Kierunek Informatyka. dr inż. Janusz Słupik. Wydział Matematyki Stosowanej Politechniki Śląskiej
Wykład I - semestr II Kierunek Informatyka Wydział Matematyki Stosowanej Politechniki Śląskiej Gliwice, 2015 c Copyright 2015 Janusz Słupik Zaliczenie przedmiotu Do zaliczenia przedmiotu niezbędne jest
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()
Podstawy języka C++ Maciej Trzebiński. Instytut Fizyki Jądrowej Polskiej Akademii Nauk. Praktyki studenckie na LHC IVedycja,2016r.
M. Trzebiński C++ 1/14 Podstawy języka C++ Maciej Trzebiński Instytut Fizyki Jądrowej Polskiej Akademii Nauk Praktyki studenckie na LHC IVedycja,2016r. IFJ PAN Przygotowanie środowiska pracy Niniejsza
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
Programowanie w C++ Wykład 1. Katarzyna Grzelak. 25 luty K.Grzelak (Wykład 1) Programowanie w C++ 1 / 38
Programowanie w C++ Wykład 1 Katarzyna Grzelak 25 luty 2019 K.Grzelak (Wykład 1) Programowanie w C++ 1 / 38 Dlaczego programowanie? K.Grzelak (Wykład 1) Programowanie w C++ 2 / 38 Umiejętność, która otwiera
C++ - szablony. C++ - szablony. C++ - strumienie. C++ - strumienie. C++ - strumienie STRUMIENIE
C++ - szablony C++ - szablony class Pierwsza { public: void f() {} }; class Druga { public: void g() {} }; template class Trzecia { T t; public: void a() { t.f(); } void b() { t.g(); } }; int
Zajęcia nr 5 Algorytmy i wskaźniki. dr inż. Łukasz Graczykowski mgr inż. Leszek Kosarzewski Wydział Fizyki Politechniki Warszawskiej
Zajęcia nr 5 Algorytmy i wskaźniki dr inż. Łukasz Graczykowski mgr inż. Leszek Kosarzewski Wydział Fizyki Politechniki Warszawskiej Plan Zapis i odczyt z plików tekstowych O tablicach ciąg dalszy Referencje
Laboratorium 1. Programowanie II - Kierunek Informatyka. dr inż. Janusz Słupik. Gliwice, 2015. Wydział Matematyki Stosowanej Politechniki Śląskiej
Laboratorium 1 - Kierunek Informatyka Wydział Matematyki Stosowanej Politechniki Śląskiej Gliwice, 2015 c Copyright 2015 Janusz Słupik Punkty Na laboratorium można zdobyć 60 punktów. Ocena ogólna z zajęć:
Podstawy Informatyki. Kompilacja. Historia. Metalurgia, I rok. Kompilatory C++ Pierwszy program. Dyrektywy preprocesora. Darmowe:
Podstawy Informatyki Metalurgia, I rok Historia Lata 0-te XX w język C (do pisania systemów operacyjnych) "The C programming language" B. Kernighan, D. Ritchie pierwszy standard Koniec lat 80 standard
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ę
Podstawy programowania. Wykład: 9. Łańcuchy znaków. dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD
Podstawy programowania Wykład: 9 Łańcuchy znaków 1 dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD Rodzaje plików Dane przechowywane w pliku mogą mieć reprezentację binarną (taką samą, jak
Podstawy Informatyki. Metalurgia, I rok. Wykład 6 Krótki kurs C++
Podstawy Informatyki Metalurgia, I rok Wykład 6 Krótki 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
Składnia C++ Programowanie Obiektowe Mateusz Cicheński
Składnia C++ Programowanie Obiektowe Mateusz Cicheński Klasy i modyfikatory dostępu Przesłanianie metod Polimorfizm Wskaźniki Metody wirtualne Metody abstrakcyjne i interfejsy Konstruktory i destruktory
Wyjątki (exceptions)
Instrukcja laboratoryjna nr 6 Programowanie w języku C 2 (C++ poziom zaawansowany) Wyjątki (exceptions) dr inż. Jacek Wilk-Jakubowski mgr inż. Maciej Lasota dr inż. Tomasz Kaczmarek Wstęp Wyjątki (ang.
Podstawy Programowania
Podstawy Programowania Monika Wrzosek Instytut Matematyki Uniwersytet Gdański Matematyka 2017/18 Monika Wrzosek (IM UG) Podstawy Programowania 1 / 119 Sprawy organizacyjne E-mail: mwrzosek@mat.ug.edu.pl
Kurs programowania. Wykład 1. Wojciech Macyna. 3 marca 2016
Wykład 1 3 marca 2016 Słowa kluczowe języka Java abstract, break, case, catch, class, const, continue, default, do, else, enum, extends, final, finally, for, goto, if, implements, import, instanceof, interface,
KLASA UCZEN Uczen imię, nazwisko, średnia konstruktor konstruktor Ustaw Wyswietl Lepszy Promowany
KLASA UCZEN Napisz deklarację klasy Uczen, w której przechowujemy następujące informacje o uczniu: imię, nazwisko, średnia (pola prywatne), poza tym klasa zawiera metody: konstruktor bezparametrowy (nie
Programowanie w C++ Wykład 2. Katarzyna Grzelak. 5 marca K.Grzelak (Wykład 1) Programowanie w C++ 1 / 41
Programowanie w C++ Wykład 2 Katarzyna Grzelak 5 marca 2018 K.Grzelak (Wykład 1) Programowanie w C++ 1 / 41 Reprezentacje liczb w komputerze K.Grzelak (Wykład 1) Programowanie w C++ 2 / 41 Reprezentacje
Programowanie obiektowe w języku C++ dr inż. Jarosław Forenc
Rok akademicki 2016/2017, Wykład nr 4 2/45 Plan wykładu nr 4 Informatyka 2 Politechnika Białostocka - Wydział Elektryczny Elektrotechnika, semestr III, studia stacjonarne I stopnia Rok akademicki 2016/2017
Zasady programowania Dokumentacja
Marcin Kędzierski gr. 14 Zasady programowania Dokumentacja Wstęp 1) Temat: Przeszukiwanie pliku za pomocą drzewa. 2) Założenia projektu: a) Program ma pobierać dane z pliku wskazanego przez użytkownika
> C++ typy wyliczeniowe, struktury, unie, konwersje napis <-> liczba, formatowanie wyjścia
> C++ typy wyliczeniowe, struktury, unie, konwersje napis liczba, formatowanie wyjścia Dane: Iwona Polak iwona.polak@us.edu.pl Uniwersytet Śląski Instytut Informatyki 1426512600 > Typy wyliczeniowe
C++ - strumienie. C++ - strumienie. C++ - strumienie. C++ - strumienie. C++ - strumienie STRUMIENIE
STRUMIENIE Motywacja wprowadzenia nowej biblioteki strumieni: W języku C istnieje intepreter odpowiedzialny za analizę łańcucha formatującego podczas wykonywania programu oraz pobierający zmienną liczbę
Informacje wstępne #include <nazwa> - derektywa procesora umożliwiająca włączenie do programu pliku o podanej nazwie. Typy danych: char, signed char
Programowanie C++ Informacje wstępne #include - derektywa procesora umożliwiająca włączenie do programu pliku o podanej nazwie. Typy danych: char, signed char = -128 do 127, unsigned char = od
Podstawy informatyki. Informatyka stosowana - studia niestacjonarne. Grzegorz Smyk. Wydział Inżynierii Metali i Informatyki Przemysłowej
Podstawy informatyki Informatyka stosowana - studia niestacjonarne Grzegorz Smyk Wydział Inżynierii Metali i Informatyki Przemysłowej Akademia Górniczo Hutnicza im. Stanisława Staszica w Krakowie, rok
Podstawy programowania. Wykład: 9. Łańcuchy znaków. dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD
Podstawy programowania Wykład: 9 Łańcuchy znaków 1 dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD Tablica znaków w językach C i C++ (oraz pochodnych) łańcuch znaków przechowywany jest jako
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
Spis treści WSTĘP CZĘŚĆ I. PASCAL WPROWADZENIE DO PROGRAMOWANIA STRUKTURALNEGO. Rozdział 1. Wybór i instalacja kompilatora języka Pascal
Spis treści WSTĘP CZĘŚĆ I. PASCAL WPROWADZENIE DO PROGRAMOWANIA STRUKTURALNEGO Rozdział 1. Wybór i instalacja kompilatora języka Pascal 1.1. Współczesne wersje kompilatorów Pascala 1.2. Jak zainstalować
W2 Wprowadzenie do klas C++ Klasa najważniejsze pojęcie C++. To jest mechanizm do tworzenia obiektów. Deklaracje klasy :
Wprowadzenie do klas C++ Klasa najważniejsze pojęcie C++. To jest mechanizm do tworzenia obiektów. Deklaracje klasy : class nazwa_klasy prywatne dane i funkcje public: publiczne dane i funkcje lista_obiektów;
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