Literatura. J. Nilsson: Applying Domain-Driven Design and Patterns,With Examples in C# and.net, Addison-Wesley Professional, 2006
|
|
- Tadeusz Kruk
- 7 lat temu
- Przeglądów:
Transkrypt
1 Literatura Booch G., Rumbaugh J., Jacobson I., Język UML. Przewodnik użytkownika, Seria: Inżynieria oprogramowania, Warszawa, WNT, Erich Gamma, Richard Helm, Ralph Johnson, John Vlissides, Wzorce projektowe. Elementy oprogramowania obiektowego wielokrotnego użytku. Seria: Inżynieria oprogramowania, Warszawa, WNT, Shalloway A.,Trott James R.,Projektowanie zorientowane obiektowo. Wzorce projektowe. Gliwice, Helion, Martin Robert C., Martin Micah, Agile, Programowanie zwinne. Zasady, wzorce i praktyki zwinnego wytwarzania oprogramowania w C#. Gliwice, Helion, J. Nilsson: Applying Domain-Driven Design and Patterns,With Examples in C# and.net, Addison-Wesley Professional, 2006
2 Modelowanie i analiza warstwy biznesowej aplikacji 1. Wielowarstwowa budowa systemu informatycznego
3 1.1. Definicja systemu informatycznego Nieformalny systeminformacyjny: zasoby osobowe - ludzie Formalny systeminformacyjny: procedury zarządzania, bazy wiedzy Techniczny system informacyjny: Sprzęt Oprogramowanie Bazy danych, bazy wiedzy System informatyczny jest to zbiór powiązanych ze sobą elementów nieformalnych, formalnych i technicznych, którego funkcją jest przetwarzanie danych przy użyciu techniki komputerowej Techniczny system informacyjny zorganizowany zespół środków technicznych (komputerów, oprogramowania, urządzeń teletransmisyjnych itp.) służący do gromadzenia, przetwarzania i przesyłania informacji
4 1.2. Pięciowarstwowy model logicznego rozdzielania zadań (wg. D.Alur, J.Crupi, D. Malks, Core J2EE. Wzorce projektowe.) Warstwa klienta Klienci aplikacji, aplety, aplikacje i inne elementy z graficznyminterfejsemużytkownika Interakcja z użytkownikiem, urządzenia i prezentacja interfejsu użytkownika Warstwa prezentacji Strony JSP, serwlety i inne elementy interfejsu użytkownika Warstwa biznesowa Komponenty EJB i inne obiekty biznesowe Logowanie, zarządzanie sesją, tworzenie zawartości, formatowania i dostarczanie Logika biznesowa, transakcje, dane i usługi Warstwa integracji JMS, JDBC, konektory i połączenia z systemami zewnetrznymi Warstwa zasobów Bazy danych, systemy zewnętrzne i pozostałe zasoby Adaptery zasobów, systemy zewnętrzne, mechanizmy zasobów, przepływsterowania Zasoby, dane i usługi zewnętrzne
5 1.3. Refaktoryzacja Refaktoryzacja polega ona na modyfikacji oprogramowania w celu poprawy jego struktury zachowując podstawowe funkcje oprogramowania. W praktyce poprawę struktury oprogramowania uzyskuje się za pomocą: podziału oprogramowania na warstwy wzorców oprogramowania, zastosowanych do budowy każdej warstwy na wybranym poziomie abstrakcji Rodzaje wzorców: Wzorce projektowe Wzorce architektury Wzorce analizy Wzorce konstrukcyjne Wzorce strukturalne Wzorce czynnościowe
6 1.4. Refaktoryzacja architektury wielowarstwowej 1 Należy przenieść kod dostępu do danych logicznie lub fizycznie bliżej rzeczywistego źródła danych, a logikę przetwarzania z klienta i warstwy prezentacji do warstwy biznesowej zawierającej fasadowe komponenty sesyjne typu Control. Komponenty Business Delegate typu Control hermetyzują dostęp do warstwy biznesowej z warstwy prezentacji stanowią przedłużenie warstwy biznesowej. Servlety lub JSP zawierają logikę biznesową i prezentacyjną Klient Servlety lub JSP Kod dostępu do danych Baza danych Warstwa klienta Warstwa prezentacji Warstwa zasobów Servlety lub JSP zawierają logikę prezentacyjną oraz fasadę rozdzielającą warstwy Komponent sesyjny zawiera logikę biznesową Logika dostępu do danych Klient Servlety, JSP Business Delegate 1 Komponent sesyjny typu fasada Kod dostępu do danych Baza danych Warstwa klienta Warstwa prezentacji Warstwa biznesowa Warstwa integracji Warstwa zasobów
7 Refaktoryzacja architektury wielowarstwowej 2 Należy złożoną logikę przetwarzania umieścić w warstwie biznesowej opartą na przetwarzaniu obiektów typu Entity. Fasadowe komponenty sesyjne hermetyzują dostęp do tych obiektów. Servlety lub JSP zawierają logikę prezentacyjną oraz fasadę rozdzielającą warstwy Komponent sesyjny zawiera logikę biznesową Logika dostępu do danych Klient Servlety, JSP Business Delegate 1 Komponent sesyjny typu fasada Kod dostępu do danych Baza danych Warstwa klienta Warstwa prezentacji Warstwa biznesowa Warstwa integracji Warstwa zasobów Servlety lub JSP zawierają logikę prezentacyjną oraz fasadę rozdzielającą warstwy Komponent sesyjny zawiera logikę biznesową, komponenty Entity stanowią model trwałych danych Logika dostępu do danych Klient Servlety, JSP Business Delegate 1 Komponent sesyjny typu fasada Obiekty Entity Kod dostępu do danych Baza danych Warstwa klienta Warstwa prezentacji Warstwa biznesowa Warstwa integracji Warstwa zasobów
8 Architektura aplikacji pięciowarstwowej Java EE 5.0 Visual Web Java Server Faces (linie przerywane oznaczają powiązania nie wykorzystane w aplikacji Baza danych katalog Warstwa integrująca (EntityManager, ) Technologia TopLink Wzorce: DomainStore Transfer Object fasady (XXXController) fabryki obiektów Warstwa integrująca (EntityManager, ) Technologia TopLink Wzorce: DomainStore Transfer Object fasady (XXXController) fabryki obiektów Warstwa integrująca (EntityManager, ) Technologia TopLink Wzorce: DomainStore Transfer Object fasady (XXXController) fabryki obiektów Warstwa zasobów Warstwa integracji Obiektowy model danych Wzorce: fasady TAplikacja fabryki obiektów strategii Obiektowy model danych Wzorce: fasady TAplikacja fabryki obiektów strategii Obiektowy model danych Wzorce: fasady TAplikacja fabryki obiektów strategii Warstwa biznesowa ApplicationBean1 Wzorzec fasady usług SessionBean1 Wzorzec fasady sesji SessionBean1 Wzorzec fasady sesji SessionBean1 Wzorzec fasady sesji Strony JSF Strony JSF Strony JSF Warstwa prezentacji Klient1 Klient2 Klient3 Warstwa klienta
9 Architektura aplikacji pięciowarstwowej Java EE 5.0 Visual Web Java Server Faces - linie przerywane oznaczają powiązania nie wykorzystane w aplikacji Baza danych katalog Warstwa integrująca (EntityManager, ) Technologia TopLink Wzorce: Domain Store Transfer Object fasady (XXXController) fabryki obiektów Warstwa zasobów Warstwa integracji ApplicationBean1 Wzorzec fasady usług Obiektowy model danych Wzorce: fasady TAplikacja fabryki obiektów strategii Warstwa biznesowa SessionBean1 Wzorzec fasady sesji SessionBean1 Wzorzec fasady sesji SessionBean1 Wzorzec fasady sesji Strony JSF Strony JSF Strony JSF Warstwa prezentacji Klient1 Klient2 Klient3 Warstwa klienta
10 Modelowanie i analiza warstwy biznesowej aplikacji 1. Wielowarstwowa budowa systemu informatycznego 1. Przykład tworzenia warstwy biznesowej systemu informatycznego
11 2. Przykład tworzenia warstwy biznesowej systemu informatycznego System sporządzania rachunków 2.1. Opis biznesowy firmy 2.2. Sformułowanie wymagań funkcjonalnych i niefunkcjonalnych systemu informatycznego 2.3. Model analizy całego systemu informatycznego oparty na diagramie przypadków użycia 2.4. Model projektowy warstwy biznesowej oparty na diagramie klas i diagramach sekwencji tworzony metodą iteracyjno-rozwojową sterowany realizacją przypadków użycia 12
12 2. Przykład tworzenia warstwy biznesowej systemu informatycznego System sporządzania rachunków 2.1. Opis biznesowy firmy
13 2.1. Opis biznesowy firmy Opis podstawowych procesów uwzględniający udział zasobów ludzkich Opis przepisów, strategii firmy Opis techniczny
14 2.1. Opis biznesowy firmy Opis podstawowych procesów uwzględniający udział zasobów ludzkich
15 (1) Diagram czynności UML jako model biznesowy systemu sprzedaży towarów w firmie. Przedstawiono wybrany proces firmy proces sprzedaży
16 (2) Obliczanie wartości rachunku w firmie Sklep Spożywczo Przemysłowy ABC Jan Kowalski ul. Leśna 1, xx-xxx Jakieś miasto NIP xxx-xxx-xx-xx Dn. 07r nr wydr.8212 PARAGON FISKALNY xxxxxxxxxxxxx Nazwa produktu1 xxxxx To jest ilość 1*6.79 A xxxxxxxxxxxxx Nazwa produktu2 xxxx zakupioneg o towaru 4*0.59 B Nazwa produktu3 xxx 0.6*4.59 D xxxxxxxxxxxxx Nazwa produktu4 xxxxx 2*2.49 A Sp.op.A PTU A = 22.00% 2.12 Sp.op.B 2.36 PTU B = 7.00% 0.15 Sp.op.D 2.75 PTU D = 3.00% 0.08 To jest cena brutto towarów z danej kategorii podatku RAZEM ZŁ Razem PTU 2.35 To jest cena jednostkowa brutto To są kategorie podatków To są kwoty tara wynikające z istniejących kategorii podatków
17 (3) Algorytm obliczania wartości rachunku obiektowe modelowanie śwata rzeczywistego (uwaga: algorytm z p.3 przedstawiono za pomocą diagramu czynności UML) 1. Start programu 2. Utworzenie instancji klasy TRachunek 3. Utworzenie w instancji klasy TRachunek instancji klasy TKolekcja zawierającej wiele instancji klasy TZakup; każda instancja klasy TZakup zawiera instancję klasy TProdukt oraz liczbę zakupionego produktu 4. Wywołanie operacji obliczwartoscrachunku instancji klasy TRachunek, w której: 4.1. instancja klasy TRachunek pobiera instancję klasy TZakup i wywołuje jej operację obliczwartosczakupu w operacji obliczwartosczakupu instancja klasy TZakup wywołuje operację obliczcenebrutto instancji klasy TProdukt w operacji obliczcenebrutto instancja klasy TProdukt oblicza cenę brutto na podstawie własnych atrybutów i zwraca wartość do operacji obliczwartosczakupu instancji klasy TZakup Operacja obliczwartosczakupu oblicza wartość zakupu (mnoży otrzymaną ceną brutto od instancji TProdukt razy liczbę produktów) i zwraca wartość operacji obliczwartoscrachunku 4.2. Operacja obliczwartoscrachunku dodaje otrzymaną wartość do wartości rachunku 4.3. Operacja obliczwartoscrachunku powtarza krok 4.1 tak długo, aż wyczerpie instancje klasy TZakup w instancji kolekcji. Po jej wyczerpaniu przechodzi do p Operacja obliczwartoscrachunku, jeśli zostaną wyczerpane te instancje, zwraca wartość bieżącego rachunku
18 (4) Schemat blokowy algorytm obliczania wartości rachunku w firmie nie tak 5
19 (5) Diagram sekwencji UML obiektowy sposób przedstawienia scenariusza obliczania rachunku w firmie :Dzial sprzedazy :Lista rachunkow Wybierz_rachunek_i_pobierz_jego_wartosc obliczwartoscrachunk u pętla obliczwartosczakupu Obliczcenebrutto
20 (6) Diagram stanów UML obiektowy sposób przedstawienia scenariuszy realizowanych przez rachunek w firmie: dodawanie nowego zakupu oraz obliczanie wartości rachunku
21 2.1. Opis biznesowy firmy Opis podstawowych procesów uwzględniajacy udział zasobów ludzkich Opis przepisów, strategii firmy
22 Opis przepisów, strategii firmy Określają m.in. warunki bezpieczeństwa i niezawodności, ograniczenia prawne dla funkcji systemu ważne podczas całego procesu tworzenia oprogramowania System sporządzania rachunków Pracownik firmy ponosi odpowiedzialność za poprawność danych odpowiada materialnie za niezgodność danych ze stanem magazynu
23 2.1. Opis biznesowy firmy Opis podstawowych procesów uwzględniający udział zasobów ludzkich Opis przepisów, strategii firmy Opis techniczny
24 Dane techniczne Określają typ aplikacji (internetowa lub/i desktopowa), warunki skalowalności, warunki rozproszenia danych oraz usług, zalecane technologie itp ważne podczas projektowania i implementacji System sporządzania rachunków Klient może przeglądać dane produktów do zakupu za pośrednictwem strony internetowej lub bezpośrednio za pomocą specjalnego programu. Pracownik sklepu może dodatkowo wstawiać, modyfikować i usuwać dane o produktach. Zakłada się, że klientów jednocześnie przeglądajądających dane produktów może być ponad tysiąc oraz liczba przeglądanych produktów oraz rachunków może być równa kilkadziesiąt tysięcy Firma składa się z kilku ośrodków w różnych miastach na terenie kraju (lista miast jest dołączona do umowy). Zaleca się stosowanie technologii Java.
25 2. Przykład tworzenia warstwy biznesowej systemu informatycznego System sporządzania rachunków 2.1. Opis biznesowy firmy 2.2. Sformułowanie wymagań funkcjonalnych i niefunkcjonalnych systemu informatycznego
26 Sformułowanie wymagań funkcjonalnych i niefunkcjonalnych systemu informatycznego Lista wymagań funkcjonalnych 1. System zawiera katalog produktów 2. Można zakupić cztery typy produktów różniące się sposobem obliczania ceny detalicznej: netto, z podatkiem, z promocją, 3. Można wprowadzić wiele rachunków 4. Pozycje rachunku muszą zawierać produkty zróżnicowane w zależności od nazwy, ceny, podatku i promocji 5. Każda pozycja rachunku powinna podać swoją wartość brutto oraz dane produktu oraz ilość zakupionego produktu. 6. Na rachunku powinna znajdować się wartość łączna wszystkich zakupów oraz wartości zakupów należących do wybranych kategorii Lista wymagań niefunkcjonalnych 1. Wstawianie produktów może odbywać się tylko przez uprawnione osoby 2. Wstawianie nowych rachunków oraz wstawianie nowych zakupów jest dokonywane przez klientów 3. Zakupy mogą być dokonane przez Internet przez aplikację uruchamianą przez przeglądarkę lub bez jej pośrednictwa
27 2. Przykład tworzenia warstwy biznesowej systemu informatycznego System sporządzania rachunków 2.1. Opis biznesowy firmy 2.2. Sformułowanie wymagań funkcjonalnych i niefunkcjonalnych systemu informatycznego 2.3. Model analizy całego systemu informatycznego oparty na diagramie przypadków użycia
28 Specyfikacja wymagań funkcjonalnych za pomocą diagramu przypadków użycia <<include>>
29 AKTOR OPIS PRZYPADKI UŻYCIA Klient Sprzedawca Klient może dokonywać zakupów wybranych produktów przez Internet korzystając z przeglądarki lub z aplikacji Sprzedawca może dodatkowo dodawać nowe produkty PU Wstawianie nowego rachunku powiązane przez <<include>> z PU Szukanie rachunku PU Obliczanie wartosci rachunku powiązane przez <<include>> z PU Szukanie rachunku PU Wstawianie nowego zakupu powiązane przez <<include>> z PU Szukanie rachunku oraz powiązane przez <<include>> z PU Szukanie produktu PU Wstawianie nowego rachunku powiązane przez <<include>> z PU Szukanie rachunku PU Obliczanie wartosci rachunku powiązane przez <<include>> z PU Szukanie rachunku PU Wstawianie nowego zakupu powiązane przez <<include>> z PU Szukanie rachunku oraz powiązane przez <<include>> z PU Szukanie produktu PU Wstawianie nowego produktu powiązane przez <<include>> z PU Szukanie produktu
30 PU Szukanie produktu OPIS CEL: Poszukiwanie produktu WS (warunki wstępne): uruchomienie z PU Wstawianie nowego produktu lub PU Wstawianie nowego zakupu WK (warunki końcowe): podanie produktu o podanych atrybutach obowiązkowych: nazwa i cena oraz jeśli jest to wymagane: z podatkiem i promocją lub komunikat o braku produktu PRZEBIEG: 1. Szukanie produktu przebiega wedlug atrybutow: nazwy i ceny (obowiazkowo) oraz podatku i promocji (jeśli jest to wymagane) zgodnie z danymi podanymi do przypadku uzycia 2. Jesli istnieje produkt o podanych atrybutach, zwracany jest produkt, w przeciwnym wypadku zwracana jest informacja o braku produktu. PU Wstawianie nowego produktu OPIS CEL: Wstawienie nowego produktu WS (warunki wstępne): inicjalizacja przez uruchomienie programu (np. otwarcie strony WWW, start aplikacji) WK (warunki końcowe): dodanie produktu o podanych atrybutach obowiązkowych: nazwa i cena oraz jeśli jest to wymagane: z podatkiem i promocją, jeśli nie było takiego produktu PRZEBIEG: 1. Nalezy podac atrybuty produktu: nazwe, cene jako obowiazkowe dane oraz podatek i cene detaliczna, jeśli jest to wymagane 2. Należy wywolać PU Szukanie produktu. Należy sprawdzić, czy produkt o podanych atrybutach już istnieje. Jeśli tak, należy zakończyć PU, w przeciwnym wypadku należy wstawić nowy produkt.
31 PU Szukanie rachunku OPIS CEL: Poszukiwanie rachunku WS (warunki wstępne): uruchomienie z PU Wstawianie nowego rachunku lub PU Obliczanie wartosci rachunku WK (warunki końcowe): podanie rachunku o podanym numerze lub komunikat o braku rachunku PRZEBIEG: 1. Szukanie rachunku przebiega wedlug numeru podanego do przypadku uzycia 2. Jesli istnieje rachunek o podanym numerze, zwracany jest rachunek, w przeciwnym wypadku zwracana jest informacja o braku rachunku. PU Wstawianie nowego rachunku OPIS CEL: Wstawienie nowego rachunku WS (warunki wstępne): inicjalizacja przez uruchomienie programu (np. otwarcie strony WWW, start aplikacji) WK (warunki końcowe): dodanie rachunku o podanym numerze, jeśli jest to unikatowy numer PRZEBIEG: 1. Nalezy podac numer rachunku, ktory powinien byc niepowtarzalny, poniewaz sluzy do identyfikacji rachunku 2. Nalezy wywolac PU Szukanie rachunku w celu sprawdzenia, czy numer rachunku sie powtarza. 3. Jesli zwrocony wynik oznacza brak rachunku o podanym numerze, mozna wstawic nowy rachunek i zakonczyc PU, w przeciwnym wypadku nalezy zakonczyc PU bez wstawiania nowego rachunku.
32 PU Obliczanie wartosci rachunku OPIS CEL: Obliczanie wartosci rachunku wg podanego podatku WS (warunki wstępne): inicjalizacja przez uruchomienie programu (np. otwarcie strony WWW, start aplikacji) WK (warunki końcowe): podanie wartości całego rachunku o podanym numerze i parametrze wejściowym równym -2 lub wartości zakupionych towarów wg podanej kategorii podatku lub komunikat o braku rachunku PRZEBIEG: 1. Nalezy podac numer rachunku, ktory powinien byc niepowtarzalny, poniewaz sluzy do identyfikacji rachunku oraz wartość podatku lub wartosc Nalezy wywolac PU Szukanie rachunku w celu sprawdzenia, czy rachunek o podanym numerze istnieje. 3. Jesli zwrocony wynik oznacza brak rachunku o podanym numerze, nie mozna obliczyc wartosci wybranego rachunku i nalezy zakonczyc PU, w przeciwnym wypadku nalezy obliczyc wartosc rachunku 4. Nalezy uruchomic petle, w ktorej sumowane sa wartosci zakupu obliczane jako iloczyn ceny jednostkowej zakupionego produktu i ilosci zakupu. Jesli zachodzi potrzeba sumowania wartosci zakupu zalezna od wysokosci podatku, nalezy podac wartosc podatku i sumowac jedynie zakupy o podanym podatku, w przeciwnym wypadku sumowane sa wszystkie zakupy (gdy zamiast podatku zostanie przekazana wartosc -2).
33 PU Wstawianie nowego zakupu OPIS CEL: Wstawianie nowego zakupu WS (warunki wstępne): inicjalizacja przez uruchomienie programu (np. otwarcie strony WWW, start aplikacji) WK (warunki końcowe): podanie nowego zakupu o podanych atrybutach lub zwiekszenie ilosci zakupionego produktu, jeśli już taki produkt zakupiono lub komunikat o braku rachunku PRZEBIEG: 1. Nalezy podac numer rachunku, ktory powinien byc niepowtarzalny, poniewaz sluzy do identyfikacji rachunku 2. Nalezy wywolac PU Szukanie rachunku w celu sprawdzenia, czy istnieje rachunek o podanym numerze. 3. Jesli zwrocony wynik oznacza brak rachunku o podanym numerze, nie mozna wstawic nowego zakupu do rachunku i nalezy zakonczyc PU, w przeciwnym wypadku nalezy wstawic nowy zakup 4. Nalezy wybrac produkt oraz ilosc zakupionego produktu. 5. Należy wywolac PU Szukanie produktu. Jeśli wybrany produkt nie istnieje, należy zakonczyc PU. W przeciwnym przypadku nalezy wstawic nowy zakup do rachunku, przegladajac, czy istnieje juz zakup z takim samym produktem. Jesli istnieje, nie tworzy sie nowego zakupu, tylko powieksza się ilosc zakupu istniejacego o ilosc nowego zakupu, w przeciwnym przypadku wstawia sie nowy zakup.
34 Identyfikacja klas Wykryto trzy główne klasy typu Entity ze względu na odpowiedzialność: TRachunek (PU: Wstawianie nowego rachunku, Wstawianie nowego zakupu, Obliczanie wartosci rachunku), TZakup (PU: Wstawianie nowego zakupu, Obliczanie wartosci rachunku) oraz TProdukt1 (PU: Wstawianie nowego produktu, Wstawianie nowego rachunku, Wstawianie nowego zakupu, Obliczanie wartosci rachunku)
35 Identyfikacja klas (c.d) Wykryto dziedziczenie w właściwościach produktów, które podają cenę jednostkową podawaną jako cenę netto, jeśli produkt nie posiada atrybutu podatek lub cenę brutto, jeśli posiada atrybut podatek klasa TProdukt2 typu Entity, która dziedziczy od klasy TProdukt1
36 Identyfikacja klas (c.d) Wykryto strategię zmniejszania ceny jednostkowej wynikającej z promocji powiązaną z produktem zarówno z podatkiem, jak bez podatku. Ponieważ jednak promocja nie musi dotyczyć każdego produktu, jest w związku powiązania z bazowym (głównym) produktem typu 0..* do 1. Klasa TPromocja typu Entity jest dziedziczona przez pozostałe typy produktu. Dzięki temu klasa TProdukt1 i TProdukt2 produkt powinien podawać uogólnioną cenę detaliczną: bez podatku, z podatkiem oraz w razie potrzeby z uwzględnieniem scenariusza dodawania promocji do ceny detalicznej produktu dla dwóch pierwszych przypadków (cztery typy ceny detalicznej) - PU: Wstawianie nowego produktu, Wstawianie nowego rachunku, Wstawianie nowego zakupu, Obliczanie wartosci rachunku.
37 Wykryto związki silnej agregacji między rachunkiem TRachunek i zakupami TZakup (rachunek posiada kolekcję zakupów) oraz słabej agregacji między zakupem TZakup a produktem TProdukt1 (zakup składa się z produktu bazowego lub jego następców), oraz związek typu powiązanie między promocją a produktem bazowym dziedziczony przez produkty potomne - PU: Wstawianie nowego zakupu, Obliczanie wartosci rachunku. Zastosowano Identyfikacja klas (c.d) klasę fasadową TAplikacja typu Control do oddzielenia obiektów typu Entity od pozostałej części systemu oraz klasę typu Control jako fabrykę obiektów (TFabryka) do tworzenia różnych typów produktów
38 Diagram klas koncepcja klas typu Entity oraz Controller
39 public TZakup( ) public TProdukt1 gettprodukt( ) public void settprodukt1(tprodukt1 val) public TProdukt1( ) public TPromocja gettpromocja( ) public void settpromocja(tpromocja val)
40 2. Przykład tworzenia warstwy biznesowej systemu informatycznego System sporządzania rachunków 2.1. Opis biznesowy firmy 2.2. Sformułowanie wymagań funkcjonalnych i niefunkcjonalnych systemu informatycznego 2.3. Model analizy całego systemu informatycznego oparty na diagramie przypadków użycia 2.4. Model projektowy warstwy biznesowej oparty na diagramie klas i diagramach sekwencji tworzony metodą iteracyjnorozwojową sterowany realizacją przypadków użycia
41 Wzorzec fasady Wzorzec fabryki obiektów Wzorzec strategii * public TPromocja gettpromocja( ) public public TPromocja void settpromocja(tpromocja gettpromocja( ) val) public void settpromocja(tpromocja val) Metody przypadków użycia Implementacja powiązań Decyzja projektowa Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 42
42 Iteracja 1 Projekt przypadku użycia Szukanie produktu za pomocą diagramu sekwencji i diagramu klas. Diagram klas jest uzupełniany metodami zidentyfikowanymi podczas projektowania scenariusza przypadku użycia za pomocą diagramu sekwencji. 43
43 (1) Szukanie produktu (TProdukt1 TAplikacja::Szukaj_produkt(TProdukt1 produkt)) 7
44 (7) boolean TProdukt1::equals(Object atprodukt) 8 oraz 9 lub 10 Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 45
45 * public TPromocja gettpromocja( ) public void settpromocja(tpromocja val) Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 46
46 (8) float TProdukt1::Podaj_cene() (9) float TProdukt1::Czesc_brutto() 9 lub 10 (10) float TProdukt2::Czesc_brutto() Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 47
47 * public TPromocja gettpromocja( ) public void settpromocja(tpromocja val) Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 48
48 Iteracja 2 Projekt przypadku użycia Wstawianie nowego produktu za pomocą diagramu sekwencji i diagramu klas. Diagram klas jest uzupełniany metodami zidentyfikowanymi podczas projektowania scenariusza przypadku użycia za pomocą diagramu sekwencji. 49
49 (2) Wstawianie nowego produktu (void TAplikacja::Dodaj_produkt(String [] dane)) 17 1 Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 50
50 (17) TProdukt1 TFabryka::Podaj_produkt(String dane[]) Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 51
51 Iteracja 3 Projekt przypadku użycia Szukanie rachunku za pomocą diagramu sekwencji i diagramu klas. Diagram klas jest uzupełniany metodami zidentyfikowanymi podczas projektowania scenariusza przypadku użycia za pomocą diagramu sekwencji. 52
52 (3) Szukanie rachunku (TRachunek TAplikacja::Szukaj_rachunek(int nr)) 11
53 (11) boolean TRachunek::equals(Object rachunek) Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 54
54 1..* 0..1 public TPromocja gettpromocja( ) public void settpromocja(tpromocja val) Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 55
55 Iteracja 4 Projekt przypadku użycia Wstawianie nowego rachunku za pomocą diagramu sekwencji i diagramu klas. Diagram klas jest uzupełniany metodami zidentyfikowanymi podczas projektowania scenariusza przypadku użycia za pomocą diagramu sekwencji. 56
56 (4) Wstawianie nowego rachunku (void TAplikacja::Wstaw_rachunek(int nr)) 3
57 Iteracja 5 Projekt przypadku użycia Wstawianie nowego zakupu za pomocą diagramu sekwencji i diagramu klas. Diagram klas jest uzupełniany metodami zidentyfikowanymi podczas projektowania scenariusza przypadku użycia za pomocą diagramu sekwencji. 58
58 (5) Wstawianie nowego zakupu (void TAplikacja::Wstaw_zakup (int nr, int ailosc, String dane[])) 3 1 Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych
59 1..* 0..1 public TPromocja gettpromocja( ) public void settpromocja(tpromocja val) Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 60
60 (12) void TRachunek::Dodaj zakup(tzakup atzakup) 13
61 1..* 0..1 public TPromocja gettpromocja( ) public void settpromocja(tpromocja val) Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 62
62 (13) TZakup TRachunek::Szukaj_zakup(TZakup atzakup) 14
63 (14) boolean TZakup::equals(Object zakup) 7 Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 64
64 1..* 0..1 public TPromocja gettpromocja( ) public void settpromocja(tpromocja val) Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 65
65 * public TPromocja gettpromocja( ) public void settpromocja(tpromocja val) Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 66
66 Iteracja 6 Projekt przypadku użycia Obliczanie wartości rachunku za pomocą diagramu sekwencji i diagramu klas. Diagram klas jest uzupełniany metodami zidentyfikowanymi podczas projektowania scenariusza przypadku użycia za pomocą diagramu sekwencji. 67
67 (6) Obliczanie wartosci rachunku (float TAplikacja::Podaj_wartosc(int nr, int podatek_)) 3 15
68 1..* 0..1 public TPromocja gettpromocja( ) public void settpromocja(tpromocja val) Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 69
69 (15) float TRachunek::Podaj_wartosc(int podatek_) 16
70 (16) float TZakup::Podaj_wartosc(int podatek_) 8 oraz 9 lub 10
71 1..* 0..1 public TPromocja gettpromocja( ) public void settpromocja(tpromocja val) Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych 4 72
Modelowanie i analiza. warstwy biznesowej aplikacji
Modelowanie i analiza warstwy biznesowej aplikacji 1. Warstwa biznesowa aplikacji, refaktoryzacja warstwy biznesowej, refaktoryzacja systemu informatycznego 2. Przykład tworzenia warstwy biznesowej systemu
Diagramy czynności tworzenie modelu przypadków użycia Wykład 2
Diagramy czynności tworzenie modelu przypadków użycia Wykład 2 Zofia Kruczkiewicz Zofia Kruczkiewicz - Projektowanie oprogramowania 2.2 1 Diagramy czynności- tworzenie modelu przypadków 1. Diagramy czynności
Model przypadków użycia - rola diagramów aktywności Część 2 Wykładowca Dr inż. Zofia Kruczkiewicz
Model przypadków użycia - rola diagramów aktywności Część 2 Wykładowca Dr inż. Zofia Kruczkiewicz Zofia Kruczkiewicz Wyklad_INP002017_4 1 Diagramy czynności I. Diagramy czynności UML II. Przykład diagramów
Wykład 1 Inżynieria Oprogramowania
Wykład 1 Inżynieria Oprogramowania Wstęp do inżynierii oprogramowania. Cykle rozwoju oprogramowaniaiteracyjno-rozwojowy cykl oprogramowania Autor: Zofia Kruczkiewicz System Informacyjny =Techniczny SI
Zofia Kruczkiewicz - Modelowanie i analiza systemów informatycznych 1
Charakterystyka oprogramowania obiektowego 1. Definicja systemu informatycznego 2. Model procesu wytwarzania oprogramowania - model cyklu życia oprogramowania 3. Wymagania 4. Problemy z podejściem nieobiektowym
Instrukcja 3 Laboratoria 3, 4 Specyfikacja wymagań funkcjonalnych za pomocą diagramu przypadków użycia
Instrukcja 3 Laboratoria 3, 4 Specyfikacja wymagań funkcjonalnych za pomocą diagramu przypadków użycia 1 Cel laboratoriów: Specyfikacja wymagań, zdefiniowanych w ramach laboratorium 2 (wg instrukcji 2),
Instrukcja 3 Laboratoria 3, 4 Specyfikacja wymagań funkcjonalnych za pomocą diagramu przypadków użycia
Instrukcja 3 Laboratoria 3, 4 Specyfikacja wymagań funkcjonalnych za pomocą diagramu przypadków użycia 1 Cel laboratoriów: Specyfikacja wymagań, zdefiniowanych w ramach laboratorium 2 (wg instrukcji 2),
Instrukcja 3 Laboratoria 3, 4 Specyfikacja wymagań funkcjonalnych za pomocą diagramu przypadków użycia
Instrukcja 3 Laboratoria 3, 4 Specyfikacja wymagań funkcjonalnych za pomocą diagramu przypadków użycia 1 Cel laboratoriów: Specyfikacja wymagań, zdefiniowanych w ramach laboratorium 2 (wg instrukcji 2),
Charakterystyka oprogramowania obiektowego
Charakterystyka oprogramowania obiektowego 1. Definicja systemu informatycznego 2. Model procesu wytwarzania oprogramowania - model cyklu Ŝycia oprogramowania 3. Wymagania 4. Problemy z podejściem nieobiektowym
Warstwa integracji. wg. D.Alur, J.Crupi, D. Malks, Core J2EE. Wzorce projektowe.
Warstwa integracji wg. D.Alur, J.Crupi, D. Malks, Core J2EE. Wzorce projektowe. 1. Ukrycie logiki dostępu do danych w osobnej warstwie 2. Oddzielenie mechanizmów trwałości od modelu obiektowego Pięciowarstwowy
Projekt sytemu informatycznego podejście obiektowe
Projekt sytemu informatycznego podejście obiektowe Przykład tworzenia warstwy biznesowej systemu informatycznego 1 Przykład tworzenia warstwy biznesowej systemu informatycznego System sporządzania rachunków
Diagramy przypadków użycia Wykład2
Diagramy przypadków użycia Wykład2 Zofia Kruczkiewicz Zofia Kruczkiewicz Inżynieria oprogramowania INEK011 1 Tworzenie diagramów przypadków użycia 1. Elementy diagramów przypadków użycia (use-cases) 2.
Implementacja modelu obiektowego
Implementacja modelu obiektowego 1. Wstęp 2. Refaktoryzacja architektury wielowarstwowej 3. Przykład implementacji warstwy biznesowej Zofia Kruczkiewicz, Modelowanie i analiza systemów informatycznych
Tworzenie modelu przypadków użycia część 1 Diagramy przypadków użycia Wykład2
Tworzenie modelu przypadków użycia część 1 Diagramy przypadków użycia Wykład2 Zofia Kruczkiewicz Zofia Kruczkiewicz Projektowanie oprogramowania 2 1 Tworzenie modelu przypadków użycia oprogramowania część
Model przypadków użycia - rola diagramów przypadków użycia Część 1 Wykładowca Dr inż. Zofia Kruczkiewicz
Model przypadków użycia - rola diagramów przypadków użycia Część 1 Wykładowca Dr inż. Zofia Kruczkiewicz Zofia Kruczkiewicz Wyklad_INP002017_4 1 Struktura wykładu I. Wprowadzenie (wykład 1, wykład3) II.
Laboratorium z przedmiotu: Inżynieria Oprogramowania INEK Instrukcja 6
Instrukcja 6 Laboratorium 8 Opracowanie diagramów sekwencji dla wybranych przypadków użycia reprezentujących usługi oprogramowania wynikających również z wykonanych diagramów czynności; definicja operacji
Zofia Kruczkiewicz - Modelowanie i analiza systemów informatycznych 2
Modelowanie i analiza systemów informatycznych 1. Warstwowa budowa systemów informatycznych 2. Model procesu wytwarzania oprogramowania - model cyklu życia oprogramowania 3. Wstęp do modelowania systemów
Diagramy maszyn stanowych, wzorce projektowe Wykład 5 część 1
Diagramy maszyn stanowych, wzorce projektowe Wykład 5 część 1 Zofia Kruczkiewicz Zofia Kruczkiewicz Inżynieria oprogramowania INEK011 1 Diagramy maszyn stanowych, wzorce projektowe 1. Modelowanie zachowania
Diagramy stanów tworzenie modeli analizy i projektowania Na podstawie UML 2.0 Tutorial
Diagramy stanów tworzenie modeli analizy i projektowania Na podstawie UML 2.0 Tutorial http://sparxsystems.com.au/resources/uml2_tutorial/ Zofia Kruczkiewicz Zofia Kruczkiewicz Projektowanie oprogramowania
Tworzenie warstwy prezentacji w wielowarstwowej aplikacji Przykład w środowisku Visual Web JSP
Tworzenie warstwy prezentacji w wielowarstwowej aplikacji Przykład w środowisku Visual Web JSP Autor Zofia Kruczkiewicz Programowanie i wdrażanie systemów informatycznych 1. Wykonanie formularzy typy JSP
Wybrane aspekty projektowania - budowa wielowarstwowego modelu implementacji, zastosowanie wzorców projektowych Wykład 7 część 2
Wybrane aspekty projektowania - budowa wielowarstwowego modelu implementacji, zastosowanie wzorców projektowych Wykład 7 część 2 Zofia Kruczkiewicz Zofia Kruczkiewicz Wyklad_INP002017_7, część 2 1 Literatura
Wzorce oprogramowania zastosowane w modelu obiektowym (wg Alan Shalloway, James R.Trott)
Wzorce oprogramowania zastosowane w modelu obiektowym (wg Alan Shalloway, James R.Trott) 1. Wstęp 2. Refaktoryzacja architektury wielowarstwowej 3. Wzorce projektowe 4. Przykład warstwy biznesowej stosującej
Programowanie komponentowe 5
Budowa warstwy klienta w architekturze typu klient-serwer zbudowanych z komponentów typu EE - klient desktopowy i internetowy. Zastosowanie komponentów opartych na technologii EJB 3.2. na podstawie https://docs.oracle.com/javaee/7/jeett.pdf
Diagramy czynności Na podstawie UML 2.0 Tutorial
Diagramy czynności Na podstawie UML 2.0 Tutorial http://sparxsystems.com.au/resources/uml2_tutorial/ Zofia Kruczkiewicz 1 Diagramy czynności 1. Diagramy czyności UML http://sparxsystems.com.au/resources/uml2_tutorial/
Diagramy klas, diagramy sekwencji Wykład 4
Diagramy klas, diagramy sekwencji Wykład 4 Zofia Kruczkiewicz Zofia Kruczkiewicz Inżynieria oprogramowania INEK011 1 Diagramy klas, diagramy sekwencji 1. Identyfikacja elementów diagramów klas część 2
Laboratorium z przedmiotu: Inżynieria Oprogramowania INEK Instrukcja 7
Instrukcja 7 Laboratoria 9, 10 Opracowanie diagramów sekwencji dla wybranych przypadków użycia reprezentujących usługi oprogramowania wynikających również z wykonanych diagramów czynności; definicja operacji
Podstawowe informacje o technologii Java EE 7
Podstawowe informacje o technologii Java EE 7 na podstawie https://docs.oracle.com/javaee/7/jeett.pdf Programowanie komponentowe 2 Programowanie komponentowe 2, Zofia Kruczkiewicz 1 I. Wielowarstwowa architektura
Tworzenie systemów informatycznych. Inżynieria oprogramowania Zofia Kruczkiewicz
Tworzenie systemów informatycznych Inżynieria oprogramowania Zofia Kruczkiewicz 1 Zagadnienia 1. Wielowarstwowa architektura systemu informatycznego 2. Refaktoryzacja architektury wielowarstwowej systemu
Wzorce oprogramowania zastosowane w modelu obiektowym (wg Alan Shalloway, James R.Trott)
Wzorce oprogramowania zastosowane w modelu obiektowym (wg Alan Shalloway, James R.Trott) 1. Wzorce 1.1. Wzorzec fasady 1.2. Wzorzec fabryki obiektów 1.3. Wzorzec strategii 2. Przykład warstwy biznesowej
Wzorce projektowe i refaktoryzacja
Wzorce projektowe i refaktoryzacja Paweł Kozioł p.koziol@students.mimuw.edu.pl 18.01.2005 Moja praca magisterska Narzędzie dla środowiska Eclipse wspierające stosowanie wzorców projektowych J2EE Prowadzący:
Modele cyklu życia systemu cd Zasady programowania zwinnego Wykład 3
Modele cyklu życia systemu cd Zasady programowania zwinnego Wykład 3 Zofia Kruczkiewicz 1 Literatura 1. Roger S. Pressman, Praktyczne podejście do oprogramowania, WNT, 2004 2. Stephen H. Kan, Metryki i
Wprowadzenie, podstawowe pojęcia, projekt a produkt Wykład1
Wprowadzenie, podstawowe pojęcia, projekt a produkt Wykład1 Zofia Kruczkiewicz 1 Literatura 1. Roger S. Pressman, Praktyczne podejście do oprogramowania, WNT, 2004 2. Stephen H. Kan, Metryki i modele w
Przykład 1 Iteracja 1 tworzenia oprogramowania
Przykład 1 Iteracja 1 tworzenia oprogramowania Opis biznesowy świata rzeczywistego Wymagania funkcjonalne i niefunkcjonalne aplikacji Diagram przypadków życia Diagramy klas i sekwencji: Relacja 1 do 0..*
Projekt INP Instrukcja 1. Autor Dr inż. Zofia Kruczkiewicz
Projekt INP002017 Instrukcja 1 Autor Dr inż. Zofia Kruczkiewicz I. Czynności wykonane zgodnie z harmonogramem grupy w tygodniach 1-6 1. Czynności (str. 3-12) wg instrukcji do lab3: http://zofia.kruczkiewicz.staff.iiar.pwr.wroc.pl/wyklady/inp002017/lab_inp002017_3.pdf
Laboratorium z przedmiotu: Inżynieria Oprogramowania INEK Instrukcja 2
Instrukcja 2 Laboratorium 2 Wykonanie opisu biznesowego świata rzeczywistego projektowanego oprogramowania, definicja wymagań funkcjonalnych i niefunkcjonalnych projektowanego oprogramowania 1 Cel laboratorium:
Tworzenie warstwy prezentacji drugi etap Przykład z laboratorium5_6. Autor Zofia Kruczkiewicz Wzorce oprogramowania laboratorium7_8
Tworzenie warstwy prezentacji drugi etap Przykład z laboratorium5_6 Autor Zofia Kruczkiewicz Wzorce oprogramowania laboratorium7_8 1. Wykonanie formularzy typy JSP zawierających wieloużywalne formularze
Podstawy programowania III WYKŁAD 4
Podstawy programowania III WYKŁAD 4 Jan Kazimirski 1 Podstawy UML-a 2 UML UML Unified Modeling Language formalny język modelowania systemu informatycznego. Aktualna wersja 2.3 Stosuje paradygmat obiektowy.
PRZEWODNIK PO PRZEDMIOCIE
Nazwa przedmiotu: Kierunek: Inżynieria Biomedyczna Rodzaj przedmiotu: obowiązkowy moduł specjalności informatyka medyczna Rodzaj zajęć: wykład, laboratorium PROGRAMOWANIE OBIEKTOWE Object-Oriented Programming
Wprowadzenie, podstawowe pojęcia, projekt a produkt Wykład1
Wprowadzenie, podstawowe pojęcia, projekt a produkt Wykład1 Zofia Kruczkiewicz 1 Literatura 1. Roger S. Pressman, Praktyczne podejście do oprogramowania, WNT, 2004 2. Stephen H. Kan, Metryki i modele w
Informacje wstępne Autor Zofia Kruczkiewicz Wzorce oprogramowania 4
Utrwalanie danych zastosowanie obiektowego modelu danych warstwy biznesowej do generowania schematu relacyjnej bazy danych Informacje wstępne Autor Zofia Kruczkiewicz Wzorce oprogramowania 4 1. Relacyjne
Laboratorium z przedmiotu: Inżynieria Oprogramowania INP
Laboratoria 5-7- część 1 Identyfikacja klas reprezentujących logikę biznesową projektowanego oprogramowania, definicja atrybutów i operacji klas oraz związków między klasami - na podstawie analizy scenariuszy
Diagramy klas, diagramy sekwencji tworzenie modeli analizy i projektu
Diagramy klas, diagramy sekwencji tworzenie modeli analizy i projektu Zofia Kruczkiewicz Zofia Kruczkiewicz Projektowanie oprogramowania 3.2 1 Diagramy klas, diagramy sekwencji tworzenie modeli analizy
Diagramy maszyn stanowych, wzorce projektowe Wykład 5 część 1
Diagramy maszyn stanowych, wzorce projektowe Wykład 5 część 1 Zofia Kruczkiewicz Zofia Kruczkiewicz Inżynieria oprogramowania INEK011 1 Składnia elementów na diagramach UML 1. W prezentacji składni diagramów
Laboratorium z przedmiotu: Inżynieria Oprogramowania INEK Instrukcja 5
Instrukcja 5 Laboratorium 7 Identyfikacja klas reprezentujących logikę biznesową projektowanego oprogramowania, definicja atrybutów i operacji klas oraz związków między klasami - na podstawie analizy scenariuszy
Instrukcja 10 Laboratorium 13 Testy akceptacyjne z wykorzystaniem narzędzia FitNesse
Instrukcja 10 Laboratorium 13 Testy akceptacyjne z wykorzystaniem narzędzia FitNesse 1 Cel laboratorium: Nabycie umiejętności przygotowywania testów akceptacyjnych za pomocą narzędzia FitNesse 1. Wg wskazówek
problem w określonym kontekście siły istotę jego rozwiązania
Wzorzec projektowy Christopher Alexander: Wzorzec to sprawdzona koncepcja, która opisuje problem powtarzający się wielokrotnie w określonym kontekście, działające na niego siły, oraz podaje istotę jego
Diagramy czynności i syntaktyka diagramów klas Wykład3
Diagramy czynności i syntaktyka diagramów klas Wykład3 Zofia Kruczkiewicz Zofia Kruczkiewicz Inżynieria oprogramowania INEK011 1 Składnia elementów na diagramach UML 1. W prezentacji składni diagramów
Koncepcja, projekt i implementacja wielowarstwowego systemu informatycznego Inżynieria oprogramowania Zofia Kruczkiewicz
Koncepcja, projekt i implementacja wielowarstwowego systemu informatycznego Inżynieria oprogramowania Zofia Kruczkiewicz 1 Literatura 1. Roger S. Pressman, Praktyczne podejście do oprogramowania, WNT,
E-1IZ3-06-s6. Inżynieria Programowania. Informatyka. I stopień (I stopień / II stopień) ogólnoakademicki (ogólno akademicki / praktyczny)
KARTA MODUŁU / KARTA PRZEDMIOTU Kod modułu E-1IZ3-06-s6 Nazwa modułu Inżynieria Programowania Nazwa modułu w języku angielskim Software Engineering Obowiązuje od roku akademickiego 2012/2013 (aktualizacja
Iteracyjno-rozwojowy proces tworzenia oprogramowania Wykład 3 część 1
Iteracyjno-rozwojowy proces tworzenia oprogramowania Wykład 3 część 1 Zofia Kruczkiewicz 1 Zunifikowany iteracyjno- przyrostowy proces tworzenia oprogramowania kiedy? Przepływ działań Modelowanie przedsiębiorstwa
Instrukcja 2 Laboratorium z Podstaw Inżynierii Oprogramowania
Instrukcja 2 Laboratorium z Podstaw Inżynierii Oprogramowania Opis biznesowy świata rzeczywistego Wymagania funkcjonalne i niefunkcjonalne aplikacji Diagram przypadków życia Diagramy klas i sekwencji:
Modelowanie przypadków użycia. Jarosław Kuchta Projektowanie Aplikacji Internetowych
Modelowanie przypadków użycia Jarosław Kuchta Podstawowe pojęcia Przypadek użycia jest formalnym środkiem dla przedstawienia funkcjonalności systemu informatycznego z punktu widzenia jego użytkowników.
Laboratorium z przedmiotu: Inżynieria Oprogramowania INEK Instrukcja 5
Instrukcja 5 Laboratorium 7 Identyfikacja klas reprezentujących logikę biznesową projektowanego oprogramowania, definicja atrybutów i operacji klas oraz związków między klasami - na podstawie analizy scenariuszy
Warstwa prezentacji. wg. D.Alur, J.Crupi, D. Malks, Core J2EE. Wzorce projektowe.
Warstwa prezentacji wg. D.Alur, J.Crupi, D. Malks, Core J2EE. Wzorce projektowe. 1. Definicja warstwy prezentacji - pięciowarstwowy model logicznego rozdzielania zadań 2. Podstawowe przypadki - analiza
Wstęp - Prosta aplikacja internetowa w technologii Java EE 5. Programowanie komponentowe 1
Wstęp - Prosta aplikacja internetowa w technologii Java EE 5 Programowanie komponentowe 1 Przykład 1- Wykonanie prostej aplikacji internetowej w technologii JavaEE w środowisku Netbeans 5.5 z wykorzystaniem
Grupy pytań na egzamin magisterski na kierunku Informatyka (dla studentów niestacjonarnych studiów II stopnia)
Grupy pytań na egzamin magisterski na kierunku Informatyka (dla studentów niestacjonarnych studiów II stopnia) WERSJA WSTĘPNA, BRAK PRZYKŁADOWYCH PYTAŃ DLA NIEKTÓRYCH PRZEDMIOTÓW Należy wybrać trzy dowolne
Inżynieria oprogramowania Jarosław Kuchta. Modelowanie interakcji
Inżynieria oprogramowania Jarosław Kuchta Modelowanie interakcji Podstawowe pojęcia Interakcja (interaction) Przepływ komunikatów pomiędzy obiektami konieczny dla wykonania określonego zadania. Interakcja
Tworzenie warstwy zasobów projektowanie metodą strukturalną
Tworzenie warstwy zasobów projektowanie metodą strukturalną Autor Zofia Kruczkiewicz Programowanie i wdrażanie systemów informatycznych 2011-03-27 1 1. Zasady modelowania wymagań funkcjonalnych systemu
Zagadnienia projektowania aplikacji J2EE
211 Zagadnienia projektowania aplikacji J2EE Maciej Zakrzewicz Maciej.Zakrzewicz@cs.put.poznan.pl http://www.cs.put.poznan.pl/mzakrzewicz/ Plan rozdziału 212 Wstęp Techniki projektowe: Wprowadzenie modułu
Tworzenie modelu konceptualnego systemu informatycznego część 1
Tworzenie modelu konceptualnego systemu informatycznego część 1 1. Elementy diagramów przypadków użycia (usecases) 2. Wytyczne tworzenia diagramów przypadków użycia (use-cases) (wg Booch G., Rumbaugh J.,
Analiza i projektowanie aplikacji Java
Analiza i projektowanie aplikacji Java Modele analityczne a projektowe Modele analityczne (konceptualne) pokazują dziedzinę problemu. Modele projektowe (fizyczne) pokazują system informatyczny. Utrzymanie
Laboratorium 2_3_4 Wzorce oprogramowania zastosowane w modelu obiektowym (wg Alan Shalloway, James R.Trott)
Laboratorium Wzorce oprogramowania zastosowane w modelu obiektowym (wg Alan Shalloway, James R.Trott) Implementacja warstwy biznesowej stosującej wzorce obiektowe oprogramowania laboratorium2_ 3_4 1 Identyfikacja
Komputerowe Systemy Przemysłowe: Modelowanie - UML. Arkadiusz Banasik arkadiusz.banasik@polsl.pl
Komputerowe Systemy Przemysłowe: Modelowanie - UML Arkadiusz Banasik arkadiusz.banasik@polsl.pl Plan prezentacji Wprowadzenie UML Diagram przypadków użycia Diagram klas Podsumowanie Wprowadzenie Języki
Laboratorium 8 Diagramy aktywności
Laboratorium 8 Diagramy aktywności Zofia Kruczkiewicz Zofia Kruczkiewicz Lab_INP002017_8 1 Modelowanie zachowania obiektów za pomocą diagramów aktywności. Modelowanie zachowania obiektów za pomocą diagramów
Diagramy klas, diagramy sekwencji
Diagramy klas, diagramy sekwencji Zofia Kruczkiewicz Zofia Kruczkiewicz Inżynieria oprogramowania INEK011 1 Składnia elementów na diagramach UML 1. W prezentacji składni diagramów sekwencji (str. 25-35)
Projektowanie oprogramowania cd. Projektowanie oprogramowania cd. 1/34
Projektowanie oprogramowania cd. Projektowanie oprogramowania cd. 1/34 Projektowanie oprogramowania cd. 2/34 Modelowanie CRC Modelowanie CRC (class-responsibility-collaborator) Metoda identyfikowania poszczególnych
Uniwersytet Łódzki Wydział Matematyki i Informatyki, Katedra Analizy Nieliniowej. Wstęp. Programowanie w Javie 2. mgr inż.
Uniwersytet Łódzki Wydział Matematyki i Informatyki, Katedra Analizy Nieliniowej Wstęp Programowanie w Javie 2 mgr inż. Michał Misiak Agenda Założenia do wykładu Zasady zaliczeń Ramowy program wykładu
Wprowadzenie, konsekwencje stosowania modelowania w projektach programistycznych Wykład1
Wprowadzenie, konsekwencje stosowania modelowania w projektach programistycznych Wykład1 Zofia Kruczkiewicz Zofia Kruczkiewicz Inżynieria oprogramowania INEK011 1 Strony internetowe Strona główna: http://zio.iiar.pwr.wroc.pl/io.html
Dokument Detaliczny Projektu Temat: Księgarnia On-line Bukstor
Koszalin, 15.06.2012 r. Dokument Detaliczny Projektu Temat: Księgarnia On-line Bukstor Zespół projektowy: Daniel Czyczyn-Egird Wojciech Gołuchowski Michał Durkowski Kamil Gawroński Prowadzący: Dr inż.
12) Wadą modelu kaskadowego jest: Zagadnienia obowiązujące na egzaminie z inżynierii oprogramowania: 13) Wadą modelu opartego na prototypowaniu jest:
Zagadnienia obowiązujące na egzaminie z inżynierii oprogramowania: 1) Oprogramowanie to: 2) Produkty oprogramowania w inżynierii oprogramowania można podzielić na: 3) W procesie wytwarzania oprogramowania
Projektowanie logiki aplikacji
Jarosław Kuchta Projektowanie Aplikacji Internetowych Projektowanie logiki aplikacji Zagadnienia Rozproszone przetwarzanie obiektowe (DOC) Model klas w projektowaniu logiki aplikacji Klasy encyjne a klasy
E-ID1S-08-s5. Informatyka. I stopień (I stopień / II stopień) ogólnoakademicki (ogólno akademicki / praktyczny)
KARTA MODUŁU / KARTA PRZEDMIOTU Kod modułu E-ID1S-08-s5 Nazwa modułu Nazwa modułu w języku angielskim Załącznik nr 7 do Zarządzenia Rektora nr 10/12 z dnia 21 lutego 2012r. Podstawy Inżynierii Programowania
EJB 3.0 (Enterprise JavaBeans 3.0)
EJB 3.0 (Enterprise JavaBeans 3.0) Adrian Dudek Wirtualne Przedsiębiorstwo 2 Wrocław, 1 czerwca 2010 Plan prezentacji 1 Wprowadzenie Cel prezentacji Czym jest EJB 3.0? Historia 2 3 Cel prezentacji Wprowadzenie
Wprowadzenie do technologii JavaServer Faces 2.1 na podstawie http://docs.oracle.com/javaee/6/tutorial/doc/
Wprowadzenie do technologii JavaServer Faces 2.1 na podstawie http://docs.oracle.com/javaee/6/tutorial/doc/ Aplikacja internetowa tworzona na podstawie bazy danych. Programowanie komponentowe 2, Zofia
Szczególne problemy projektowania aplikacji internetowych. Jarosław Kuchta Projektowanie Aplikacji Internetowych
Szczególne problemy projektowania aplikacji Jarosław Kuchta Miejsce projektowania w cyklu wytwarzania aplikacji SWS Analiza systemowa Analiza statyczna Analiza funkcjonalna Analiza dynamiczna Analiza behawioralna
Diagramy interakcji. Jarosław Kuchta Dokumentacja i Jakość Oprogramowania
Diagramy interakcji Jarosław Kuchta Dokumentacja i Jakość Oprogramowania Podstawowe pojęcia Interakcja (interaction) Przepływ komunikatów pomiędzy obiektami konieczny dla wykonania określonego zadania.
Dziedziczenie wielobazoweuzupełnienie
Dziedziczenie wielobazoweuzupełnienie 1. Dziedziczenie wielobazowe z powtórzeniami z klasą wirtualną, listy konstruktorów listy argumentów konstruktorów 2. Dziedziczenie wielobazowe z powtórzeniami bez
Tworzenie systemów informatycznych. Inżynieria oprogramowania Zofia Kruczkiewicz
Tworzenie systemów informatycznych Inżynieria oprogramowania Zofia Kruczkiewicz 1 Literatura 1. Roger S. Pressman, Praktyczne podejście do oprogramowania, WNT, 2004 2. Stephen H. Kan, Metryki i modele
Modelowanie klas i obiektów. Jarosław Kuchta Projektowanie Aplikacji Internetowych
Modelowanie klas i obiektów Jarosław Kuchta Podstawowe pojęcia (1) Byt, encja (entity) coś co istnieje, posiada własne cechy i wyodrębnioną tożsamość (identity); bytem może być rzecz, osoba, organizacja,
Wprowadzenie, konsekwencje stosowania modelowania w projektach programistycznych Wykład1
Wprowadzenie, konsekwencje stosowania modelowania w projektach programistycznych Wykład1 Zofia Kruczkiewicz Zofia Kruczkiewicz Inżynieria oprogramowania INEK011 1 Strony internetowe Strona główna: http://zio.iiar.pwr.wroc.pl/io.html
Grupy pytań na egzamin magisterski na kierunku Informatyka (dla studentów dziennych studiów II stopnia)
Grupy pytań na egzamin magisterski na kierunku Informatyka (dla studentów dziennych studiów II stopnia) WERSJA WSTĘPNA, BRAK PRZYKŁADOWYCH PYTAŃ DLA NIEKTÓRYCH PRZEDMIOTÓW Należy wybrać trzy dowolne przedmioty.
Podstawy modelowania programów Kod przedmiotu
Podstawy modelowania programów - opis przedmiotu Informacje ogólne Nazwa przedmiotu Podstawy modelowania programów Kod przedmiotu 11.3-WI-INFP-PMP Wydział Kierunek Wydział Informatyki, Elektrotechniki
Technologia programowania
Wykład 1 2 październik 2018 Cel kursu Znacie język programowania oraz umiecie tworzyć proste aplikacje. Nie macie doświadczenia w tworzeniu dużych i złożonych systemów. Aby stworzyć duży system należy:
Specyfikowanie wymagań przypadki użycia
Specyfikowanie wymagań przypadki użycia Prowadzący Dr inż. Zofia 1 La1 La2 Forma zajęć - laboratorium Wprowadzenie do laboratorium. Zasady obowiązujące na zajęciach. Wprowadzenie do narzędzi wykorzystywanych
1 Wprowadzenie do J2EE
Wprowadzenie do J2EE 1 Plan prezentacji 2 Wprowadzenie do Java 2 Enterprise Edition Aplikacje J2EE Serwer aplikacji J2EE Główne cele V Szkoły PLOUG - nowe podejścia do konstrukcji aplikacji J2EE Java 2
Analiza i projektowanie obiektowe w UML Kod przedmiotu
Analiza i owanie obiektowe w UML - opis przedmiotu Informacje ogólne Nazwa przedmiotu Analiza i owanie obiektowe w UML Kod przedmiotu 11.3-WK-MATP-UML-W-S14_pNadGen5M44E Wydział Kierunek Wydział Matematyki,
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
Projektowanie oprogramowania. Warstwa integracji z bazą danych oparta na technologii ORM Platforma Java EE Autor: Zofia Kruczkiewicz
Projektowanie oprogramowania Warstwa integracji z bazą danych oparta na technologii ORM Platforma Java EE Autor: Zofia Kruczkiewicz 1 Wykonanie czterowarstwowej aplikacji EE z dostępem do bazy danych,
Wprowadzenie do technologii JavaServer Faces 2.1 na podstawie http://docs.oracle.com/javaee/6/tutorial/doc/
Wprowadzenie do technologii JavaServer Faces 2.1 na podstawie http://docs.oracle.com/javaee/6/tutorial/doc/ Aplikacja internetowa tworzona na podstawie bazy danych. Programowanie komponentowe 2, Zofia
Wzorce projektowe. dr inż. Marcin Pietroo
Wzorce projektowe dr inż. Marcin Pietroo Wzorce projektowe Wzorzec projektowy (ang. design pattern) w inżynierii oprogramowania, rozwiązanie często pojawiających się, powtarzalnych problemów projektowych.
Dziedziczenie jednobazowe, poliformizm, tablice wskaźników na obiekty
Dziedziczenie jednobazowe, poliformizm, tablice wskaźników na obiekty 1. Polimorfizm (1) tablice wskaźników na obiekty 2. Polimorfizm (2) tablice wskaźników na obiekty 3. Polimorfizm (3) tablice wskaźników
Inżynieria oprogramowania. Jan Magott
Inżynieria oprogramowania Jan Magott Literatura do języka UML G. Booch, J. Rumbaugh, I. Jacobson, UML przewodnik użytkownika, Seria Inżynieria oprogramowania, WNT, 2001, 2002. M. Fowler, UML w kropelce,
Analiza i projektowanie obiektowe 2016/2017. Wykład 11: Zaawansowane wzorce projektowe (1)
Analiza i projektowanie obiektowe 2016/2017 Wykład 11: Zaawansowane wzorce projektowe (1) Jacek Marciniak Wydział Matematyki i Informatyki Uniwersytet im. Adama Mickiewicza 1 Plan wykładu 1. Wzorce projektowe
Modelowanie i analiza systemów informatycznych
Katolicki Uniwersytet Lubelski Jana Pawła II Wydział Matematyki, Informatyki i Architektury Krajobrazu Modelowanie i analiza systemów informatycznych ćwiczenia informacja wstępna dr Viktor Melnyk, prof.
Programowanie obiektowe
Programowanie obiektowe Laboratorium 11 - przegląd wybranych wzorców mgr inż. Krzysztof Szwarc krzysztof@szwarc.net.pl Sosnowiec, 24 maja 2017 1 / 38 mgr inż. Krzysztof Szwarc Programowanie obiektowe Wzorce
Zasady generowania kluczy głównych Język Java Persistence Podstawowa architektura wielowarstwowych aplikacji w oparciu o wzorce oprogramowania
Zasady generowania kluczy głównych Język Java Persistence Podstawowa architektura wielowarstwowych aplikacji w oparciu o wzorce oprogramowania Autor Zofia Kruczkiewicz Wzorce oprogramowania 6 1. Różne
Technologie obiektowe. Plan. Ewolucja technik wytwarzania oprogramowania
Literatura Marek Kisiel-Dorohinicki doroh@agh.edu.pl Brett D. McLaughlin, Gary Pollice, David West Head First Object-Oriented Analysis and Design Martin Fowler UML Distilled ( UML w kropelce ) Grady Booch,
INŻYNIERIA OPROGRAMOWANIA. laboratorium
INŻYNIERIA OPROGRAMOWANIA laboratorium UML 1/4 UML (Unified Modeling Language) - język modelowania obiektowego systemów i procesów [Wikipedia] Spojrzenie na system z różnych perspektyw dzięki zastosowaniu
Technologie obiektowe Object-oriented technologies. Informatyka II stopień (I stopień / II stopień) Ogólnoakademicki (ogólno akademicki / praktyczny)
Załącznik nr 7 do Zarządzenia Rektora nr 10/12 z dnia 21 lutego 2012r. KARTA MODUŁU / KARTA PRZEDMIOTU Kod modułu Nazwa modułu Nazwa modułu w języku angielskim Obowiązuje od roku akademickiego 2012/13