Transcript Język C
PLATFORMY
TECHNOLOGICZNE
ELEMENTY JĘZYKA C#
mgr inż. Tomasz Gawron
Czym jest C#
2
Stworzony specjalnie dla .NET
Zbliżony składniowo do C++ i Javy
Posiada IDE (Visual Studio)
Obiektowy, obsługuje zdarzenia (event-driven)
Może współpracować z komponentami stworzonymi
w innych językach
Język zarządzany (obsługiwany przez garbage
collector)
Platformy Technologiczne 2014
Struktura programu
3
Platformy Technologiczne 2014
Typy zmiennych
4
Typ
Możliwe wartości
Typ wartościwy
Wartość zdefiniowanego typu
Typ wartościowy „nullable”
Wartość zdefiniowanego typu lub null
Obiekt
Null, referencja do obiektu dowolnego typu, referencja do boxowanej wartości dowolnego typu
Klasa
Null, referencja do instancji klasy, referencja do instancji klasy dziedziczącej
Interfejs
Null, referencja do instancji klasy implementującej interfejs, referencja do boxowanej wartości typu
implementującego interfejs
Tablica
Null, referencja do instancji tablicy danego lub kompatybilnego typu
Delegat
Null, referencja do instancji typu delegatu
Platformy Technologiczne 2014
Typy wartościowe
5
Typy całkowite
(8 bit)
(16 bit)
(32 bit)
(64 bit)
byte
short
int
long
(0, 28-1),
(-215, 215-1),
(-231, 231-1),
(-263, 263-1),
sbyte (-27, 27-1)
ushort
uint
ulong
Typy zmiennoprzecinkowe
(32 bit) float (±1,5*10-45 ,±3,4*1038)
(64 bit) double (±5,0*10-324 ,±1,7*10308)
Typy binarne
bool
Platformy Technologiczne 2014
float x = 0.5f;
double x = 0.5;
Typy wartościowe „nullowalne”
6
Oprócz standardowych wartości mogą przyjmować również null
Definicja ze znakiem zapytania:
int? i = null;
Dodatkowe właściwości:
HasValue (wartość binarna sprawdzająca czy zmienna nie jest null)
Value
Operator „??”
Gdy pierwsza wartość jest null, przekaż wartość drugą
int x = a ?? b;
Platformy Technologiczne 2014
Boxing i unboxing
7
Wykorzystywane przy przejściach pomiędzy typami
wartościowymi a referencyjnymi
Boxing:
Unboxing:
Alokacja „pudełka” na stercie, skopiowanie wartości do
„pudełka”
Sprawdzenie typu „pudełka”, skopiowanie wartości z
„pudełka” na stos
Korzyści:
Nie są potrzebne klasy – wrappery
Kolekcje są uniwersalne – współpracują z każdym typem
Platformy Technologiczne 2014
Boxing i unboxing
8
i
123
int i = 123;
object o = i;
int j = (int)o;
o
System.Int32
123
j
123
Platformy Technologiczne 2014
Co się stanie?
9
F a = new F(5); //konstruktor przypisuje przekazaną wartość zmiennej a
F b = a;
b.X= 10;
Console.WriteLine(a.X); //wynik?
int a = 1;
int b = a;
b = 2;
Console.WriteLine(a); //wynik?
Platformy Technologiczne 2014
Klasy
10
Dziedziczenie po jednej klasie
Implementacja wielu interfejsów
Modyfikatory dostępu:
Public
Private
Protected
Internal
Elementy klasy:
Stałe, pola, metody, właściwości, indeksery, zdarzenia, operatory,
konstruktory, destruktory
Elementy statyczne / instancji
Typy zagnieżdżone
Platformy Technologiczne 2014
Konstruktory klas
11
Konstruktor jest metodą wywoływaną podczas tworzenia
nowej instancji klasy
Posiada taką samą nazwę jak klasa
Nie zwraca żadnych wartości
Nie ma potrzeby jawnej deklaracji
Może być przeciążony
Platformy Technologiczne 2014
Klasy wieloplikowe
12
W C# definicję klasy można podzielić pomiędzy
wiele plików (np. WinForms)
Wszystkie pliki muszą być dostępne w czasie
kompilacji
//Plik1.cs
partial class Klasa1
{ //częściowa definicja klasy }
//Plik2.cs
partial class Klasa1
{ //częściowa definicja klasy }
Platformy Technologiczne 2014
Struktury
13
Struktury są zawsze wartościami
Mogą zawierać pola, interfejsy, funkcje składowe i
konstruktory z argumentami
Przypisanie kopiuje dane nie referencję
Brak możliwości dziedziczenia (tylko implementacja
interfejsów)
Platformy Technologiczne 2014
Struktury vs. klasy
14
Struktury są
wydajniejsze przy
lekkich obiektach (np.
punkt) – nie wymagana
obsługa przez GC
Wydajniejsze zużycie
pamięci (zajmują „mniej
miejsca” niż analogiczne
klasy)
Większe zużycie
zasobów przy
niektórych operacjach
(kopiowanie)
Kiedy korzystać ze
struktur zamiast klas:
Tworzony obiekt jest mały
Będziemy tworzyć wiele
obiektów (setki, tysiące)
Wartości pól nie zmieniają się
w cyklu życia obiektu
Platformy Technologiczne 2014
Interfejsy
15
Zbiór funkcji pod wspólną nazwą
Same deklaracje - brak implementacji
Wszystkie składowe publiczne
Wielokrotne dziedziczenie
Elementy:
metody,
właściwości, indeksery, Zdarzenia
Platformy Technologiczne 2014
Interfejsy
16
Klasę implementującą jeden lub wiele interfejsów można traktować jako klasę
należącą do wielu typów. Może być postrzegana jak instancja typu każdego z
implementowanych interfejsów
Możliwość traktowania odmiennych klas w podobny sposób, jeśli implementują ten
sam interfejs
interface INazwa{
void f();
String Wlasciwosc{
get;
set;
}
event EventHandler
//int i; - błąd
zdarzenie;
class Klasa : INazwa {
String s;
public virtual void f(){...}
public virtual String Wlasciwosc {
get {return s;}
set {s = value;}
}
public virtual event
EventHandler zdarzenie;
}
//Słowo virtual jest opcjonalne
}
Platformy Technologiczne 2014
Implementacja interfejsu
17
Niejawna
interface Interfejs1 {
void f();
}
interface Interfejs2 {
void f();
}
class Klasa : Interfejs1, Interfejs2 {
public void f() { Console.WriteLine("Implementacja w sposób niejawny"); }
}
Jawna
interface Interfejs1 {
void f();
}
interface Interfejs2 {
void f();
}
class Klasa : Interfejs1, Interfejs2 {
void Interfejs2.f() {
Console.WriteLine("Implementacja w sposób jawny");
}
}
Platformy Technologiczne 2014
Enum
18
Silnie typowane typy wyliczeniowe
Brak jawnej konwersji na int
Zawierające zbiór nazwanych stałych
Nie mogą być deklarowane wewnątrz metody
Można jawnie zadeklarować typ
Kod staje się czytelniejszy
Platformy Technologiczne 2014
Kompilacja warunkowa
19
#define, #undef
#if, #elif, #else, #endif
Logika
bool - owska
Można implementować metody warunkowe
Wykonanie
zależne od trybu wywołania programu
Platformy Technologiczne 2014
Generyczność
20
Tworzenie kodu, dla którego typ parametrów zostanie określony później
Korzyści
Kod jest bardziej uniwersalny
Unikamy problemów z rzutowaniem/odpowiednim doborem typów
Z mechanizmów generyczności mogą korzystać
Klasy
Metody
Interfejsy
Delegaty
Jednowymiarowe tabele
Najczęstsze wykorzystanie – kolekcje
System.Collections.Generic
Platformy Technologiczne 2014
Generyczność - przykłady
21
Generyczne metody
Ograniczenia dla generycznych parametrów
Platformy Technologiczne 2014
Tablice
22
Deklaracja:
int[] tab = new int[4];
float[, ,] tab2 = new float[3, 3, 3];
Cechy tablic:
Jednorodność
Swobodny
dostęp
Stała liczba elementów
Ciągłość pamięciowa
Platformy Technologiczne 2014
Kolekcje
23
System.Collections oraz System.Collections.Generic
Nazwa
Porządek
Bezpośredni dostęp
Opis / Zastosowanie
Dictionary
Brak
Klucz
Kolekcja typu klucz – wartość. Klucze muszą być unikalne. Umożliwia bardzo
szybkie wyszukiwanie i wstawianie elementów – O(1)
SortedDictionary
Posortowany
Klucz
Posortowana kolekcja Dictionary oparta na drzewach binarnych.
List
Brak
Indeks
Korzystna przy małych kolekcjach bez konieczniści sortowania.
LinkedList
Brak
Indeks
Korzystna przy strukturze często wstawiajacej wartości w środkowe
elementy
SortedList
Posortowany
Indeks
Posortowana lista – drzewo binarne przechowywane w tablicy umożliwia
szybsze wyszukiwanie
HashSet
Brak
Klucz
Kolekcja klucz – wartość z identycznym typem klucza i wartości
SortedSet
Posortowany
Klucz
Posortowany HashSet
Stack
LIFO
Tylko góra
Lista przetwarzana w strategii dostępu LIFO
Queue
FIFO
Tylko początek
Lista przetwarzana w strategii dostępu FIFO
Platformy Technologiczne 2014
Kolekcje - przykłady
24
Dictionary
List
Platformy Technologiczne 2014
Porównywanie obiektów
25
IComparable (interfejs dla typów posiadających porządek)
public interface IComparable {
int CompareTo(object obj); // <0 if this < obj, 0 if this == obj, >0 if this > obj
}
public interface IComparable<T> {
int CompareTo(T obj); // <0 if this < obj, 0 if this == obj, >0 if this > obj
}
IComparer (interfejs realizujący porównanie i porządkowanie
obiektów)
public interface IComparer {
int Compare(object x, object y); // <0 if x < y, 0 if x == y, >0 if x > y
}
public interface IComparer<T> {
int Compare(T x, T y); // <0 if x < y, 0 if x == y, >0 if x > y
}
Platformy Technologiczne 2014
Porównywanie obiektów - przykład
26
Definicja klasy
Sortowanie
A może inaczej?
Platformy Technologiczne 2014
Pętle
27
For
int number = 5;
for(int i = 0; i < number; i++)
{ Console.WriteLine(i); }
Foreach
int number = 0;
while(number < 5)
{number = number + 1;}
Kolekcja musi implementować interfejs
IEnumerable
ArrayList list = new ArrayList();
list.Add(„Jan Kowalski");
list.Add(„Adam Nowak");
foreach(string name in list)
{ Console.WriteLine(name); }
While
Do… while
int number = 0;
do
{ number = number + 1; }
while(number < 5);
Platformy Technologiczne 2014
Atrybuty
28
Służą dołączaniu metadanych do kodu
Platformy Technologiczne 2014
Atrybuty
29
Mogą być dołączane do klas, typów oraz metod
Dostęp uzyskujemy za pomocą refleksji
W pełni „konfigurowalne”
Klasy dziedziczące po System.Attribute
Bezpieczne (typ sprawdzany jest podczas
kompilacji)
Przykłady użycia:
Web
Services, XML, serializacja, konfiguracja kodu
Platformy Technologiczne 2014
Delegaty
30
Zorientowane obiektowo wskaźniki na metody
Zastępuje wskaźniki do funkcji
Sygnatura i typ wartości zwracanej delegacji musi
być identyczny jak funkcji którą reprezentuje
Pozwala wywołać dowolną metodę z dowolnego
obiektu
Dwa typy:
System.Delegate
System.MulticastDelegate
Platformy Technologiczne 2014
Definiowanie i używanie delegatów
31
Deklaracja delegatu
delegate void Notifier (string sender);
// ordinary method signature
// with the keyword delegate
Deklaracja zmiennej delegatu
Notifier greetings;
Przypisanie metody
void SayHello(string sender) {
Console.WriteLine("Hello from " + sender);
}
greetings = new Notifier(SayHello);
// or just:
greetings = SayHello;
Wywołanie delegacji
greetings("John");
// invokes SayHello("John") => "Hello from John"
Platformy Technologiczne 2014
System.MulticastDelegate
32
Delegat zawierający referencję do kilku metod
Notifier greetings;
greetings = SayHello;
greetings += SayGoodBye;
greetings("John");
// "Hello from John"
// "Good bye from John"
greetings -= SayHello;
greetings("John");
// "Good bye from John"
Platformy Technologiczne 2014
Metody anonimowe
33
Metoda jest tworzona dynamicznie
Ma wszystkie funkcjonalności metod „jawnych”
Przykład:
„f” jest delegatem
int a = 12;
f += delegate(int b) {return a * b; }
Platformy Technologiczne 2014
Wyrażenia lambda
34
Mogą zastępować anonimowe delegaty
Składnia:
(parametry
wejściowe) => (operacje)
IEnumerable<string> allJohns = allNames.Where(x => x.Equals("John"));
Platformy Technologiczne 2014
Func
35
Składnia:
Func<T1, T2, ..., TResult> Delegate
Pozwala na enkapsulację metody przyjmującej parametry
wejściowe T i zwracającej parametr typu TResult
Platformy Technologiczne 2014
Action
36
Składnia:
Action<T1,
T2, ...> Delegate
Action nie zwraca wyniku
Platformy Technologiczne 2014
Zdarzenia
37
Zdarzenia (event) w C# są specjalnym typem
delegatów
Dwóch uczestników:
Źródło
zdarzeń - ten który publikuje
Odbiorca – subskrybent (może być wielu
subskrybentów)
Deklarowane wewnątrz klas
Platformy Technologiczne 2014
Zdarzenia - źródło
38
Zdefiniowanie delegatu
public delegate void EventHandler(object sender, EventArgs e);
Zdefiniowanie logiki
public class Button {
public event EventHandler Click;
protected void OnClick(EventArgs e) {
// This is called when button is clicked
if (Click != null) Click(this, e);
}
}
Platformy Technologiczne 2014
Zdarzenia - subskrybent
39
Definicja i zarejestrowanie obsługi
public class MyForm : Form {
Button okButton;
static void OkClicked(object sender, EventArgs e) {
ShowMessage("You pressed the OK button");
}
public MyForm() {
okButton = new Button(...);
okButton.Caption = "OK";
okButton.Click += new EventHandler(OkClicked);
}
}
Platformy Technologiczne 2014
Przesyłanie argumentów do metod
40
Wartość
static void Nazwa(int x){...}
int a = 5;
Nazwa(a);
Referencja
static void Nazwa(ref int x){...}
int a = 5;
Nazwa(ref a);
Parametr wyjściowy
static void Nazwa(out int x){...}
int a;
Nazwa(out a);
Platformy Technologiczne 2014
Właściwości
41
Definicja wirtualnego atrybutu
Dostęp definiowany przez „get” oraz „set”
[modyfikator dostępu] typ Nazwa
{
get{...}
set{...}
}
Korzyści:
Pojęcie reprezentuje pewien atrybut klasy, ale w celu jego implementacji trzeba
wywołać pewne funkcje
Jedną wartość można w prosty sposób obliczyć na podstawie drugiej
Dostęp do pola klasy musi być kontrolowany w celu zapewnienia spójności
(poprawności) obiektu
Ukrycie implementacji (typu)
Platformy Technologiczne 2014
Automatyczne właściwości
42
Wprowadzone w C# 3.0
Uproszczenie kodowania
//C# 2.0
private int age;
public int Age
{
get { return age; }
set { age = value; }
}
//C# 3.0
public int MyAge { get; set; }
Platformy Technologiczne 2014
Indekser
43
Oferuje sposób dostępu do kolekcji wartości utrzymywanych w
ramach pojedynczego obiektu klasy – parametry jak indeks kolekcji
public class SkyScraper {
Story[] stories;
public Story this [int index] {
get { return stories[index]; }
set { if (value!=null) {
stories[index] = value;
}
}
}
SkyScraper searsTower = new SkyScraper();
searsTower[155] = new Story(“Observation Deck”);
searsTower[0] = new Story(“Entrance”);
Platformy Technologiczne 2014
Inicjalizatory
44
Pozwalają na uproszczone przypisywanie wartości
do publicznych pól klasy
public class Human
{
public int Age { get; set; }
public int Height { get; set; }
}
Human h1 = new Human();
h1.Age = 24;
h1.Height = 175;
Human h2 = new Human() { Age = 18, Height = 168 };
Można z nich korzystać przy inicjalizacji struktur
Platformy Technologiczne 2014
Zmienne niejawnie typowane
45
Zmienna typu var
var f = 3.0f;
Kompilator zawsze generuje statyczną, silnie typowaną
referencję na podstawie aktualnej wartości
Ograniczenia:
Wartość musi być zainicjalizowana przy deklaracji
Nie może być zainicjalizowana jako null
Typ musi być dostępnu dla kompilatora
Nie mogą być polami klas
Nie mogą być parametrami metody
Platformy Technologiczne 2014
Zmienne niejawnie typowane
46
Zmienna typu dynamic
Nowy
typ wprowadzony w C# 4.0
Traktowany jak System.Object
Zgodność typów sprawdzana w runtime
Może być polem klasy
Może przyjmować wartości różnego typu
Może być parametrem metody
Platformy Technologiczne 2014
var vs. dynamic
47
Mniejsze ograniczenia
Dynamiczna zmiana typów
Platformy Technologiczne 2014
Typy anonimowe
48
Tworzone dynamicznie przy użyciu zmiennych niejawnych
var v = new { Price = 200, Quantity = 5 };
Dobra metoda enkapsulacji właściwości tylko do odczytu
Typy są generowane dynamicznie na poziomie kompilatora
Wykorzystanie w LINQ
Platformy Technologiczne 2014
Metody rozszerzające
49
Umożliwiają rozszerzanie istniejących klas o nowe
metody
Metoda
musi być zdefiniowana jako statyczna
public static class Extensions
{
public static int Increment(this int i)
{
return ++i;
}
}
//wywołanie
int i = 0;
int j = i.Increment();
Platformy Technologiczne 2014
Przekazywanie parametrów
50
Istnieje możliwość wywoływania metod bez podania wszystkich
parametrów
Metody mogą posiadać nazwy parametrów w swich wywołaniach
Platformy Technologiczne 2014
Wyjątki
51
Wyjątek jest sytuacją, która nie może być rozwiązana
w danym kontekście aplikacji (dzielenie przez 0, błąd
połączenia z bazą danych)
Zgłoszenie wyjątku oznacza, że wystąpiła błędna
sytuacja, której aplikacja nie potrafi sama rozwiązać
Wyjątek powinien być przechwycony w kodzie oraz
odpowiednio obsłużony poprzez przekazanie
sterowania do właściwego bloku
Standardowym procesem obsługi wyjątków jest
zgłoszenie i zalogowanie błędu oraz zakończenie
błędnego procesu
Platformy Technologiczne 2014
Wyjątki
52
Wyjątki mogą pojawiać się na różnych poziomach abstrakcji
Sprzętu / systemu operacyjnego
Dzielenie przez 0
Stack overflow
Języka
Niepoprawna konwersja
Null pointer exception
Błędy rzutowania
Programu
Wyjątki zdefiniowane przez użytkownika
Platformy Technologiczne 2014
Typy wyjątków
53
Typ
Opis
Exception
Najbardziej ogólna klasa, może reprezentować wszystkie wyjątki, dziedziczą po
niej wszystkie klasy wyjątków. Dzieli się na 2 podgrupy (ApplicationException,
SystemException )
ApplicationException
Wyjątki specyficzne dla danej aplikacji
SystemException
Klasa ogólna dla predefiniowanych wyjątków
ArithmeticException
Zgłaszany w razie wystąpienia błędu podczas operacji arytmetycznych lub
konwersji
FormatException
Zgłaszany np. przez metody klasy Convert, gdy podany napis nie reprezentuje
wartości, do której chcemy go przekonwertować
NullReferenceException
Zgłaszany, kiedy używana jest zmienna referencyjna, która ma wartość null
OutOfMemoryException
Zgłaszany, kiedy występuje niewystarczająca ilość pamięci
IndexOutOfRangeException
Zgłaszany, gdy następuje odwołanie do nieistniejącego elementu tablicy
ArgumentException
Zgłaszany w przypadku, kiedy jeden z argumentów dostarczanych do metody
jest nieprawidłowy
Platformy Technologiczne 2014
Obsługa wyjątków
54
Platformy Technologiczne 2014
Obsługa wyjątków
55
Powinniśmy zawsze starać się złapać jak
najbardziej szczegółowy wyjątek, np
ArithmeticException a nie Exception
Mechanizm wyjatków nie może służyc do
maskowania błedów – przechwycony wyjątek musi
być obsłużony
Platformy Technologiczne 2014
Antywzorce w obsłudze wyjątków
56
Log and throw
Catch and Ignore
Log and return null
Destructive wrapping
Rzucanie wyjątków w bloku
finally
Platformy Technologiczne 2014
System.IO - Strumienie
57
TextReader
StreamReader
TextWriter
BinaryReader
BinaryWriter
Stream
StreamWriter
…
FileStream
StringReader
MemoryStream
NetworkStream
Platformy Technologiczne 2014
StringWriter
System.IO.Stream
58
public abstract class Stream : MarshalByRefObject, IDisposable {
public abstract bool CanRead { get; }
• Bazowe właściwości strumienia
public abstract bool CanSeek { get; }
public abstract bool CanWrite { get; }
public abstract int Read(out byte[] buff, int offset, int count);
public abstract void Write(byte[] buff, int offset, int count);
public virtual int ReadByte();
public virtual void WriteByte(byte value);
public virtual IAsyncResult BeginRead(…);
public virtual IAsyncResult BeginWrite(…);
public virtual int EndRead(…);
public virtual int EndWrite(…);
public abstract long Length { get; }
public abstract long Position { get; set; }
public abstract long Seek(long offset, SeekOrigin origin);
public abstract void Flush();
public virtual void Close();
...
}
• Synchroniczny odczyt i zapis
• Asynchroniczny odczyt i zapis
• Długość i aktualna pozycja
• Pozycjonowanie
• Wysłanie danych i zamknięcie
strumienia
Platformy Technologiczne 2014
Strumienie - operacje
59
FileStream
MemoryStream
Operacje na strukturze plików
60
Wszystkie klasy znajdują się w System.IO
Directory, DirectoryInfo
File, FileInfo
Operacje na plikach
Path
Operacje na katalogach
Operacje na tekście zawierającym informacje o ścieżce
dostępu do pliku lub katalogu
FileSystemWatcher
Monitoring systemu plików
Platformy Technologiczne 2014
Operacje na strukturze plików
61
Platformy Technologiczne 2014
System.String
62
Służy do obsługi ciągów znaków
Porównywane wg wartości
Zmodyfikowane zapisywane są pod innym adresem
Metody
Opis
Compare()
porównanie dwóch łańcuchów
Concat()
utworzenie nowego łańcucha z jednego lub większej liczby
Copy()
utworzenie nowego łańcucha przez przekopiowanie zawartości
Chars[]
indekser łańcucha
Insert()
zwraca nowy łańcuch z dostawionym nowym łańcuchem
Remove()
usunięcie z łańcucha określonej liczby znaków
Split()
rozbicie łańcucha na podłańcuchy przy założonym zbiorze ograniczników
StartsWith()
wskazuje czy łańcuch rozpoczyna się od określonych znaków
Substring()
wyłuskanie podłańcucha
ToLower()
zwraca kopię łańcucha składającego się z małych liter
Trim()
wyrzucenie określonego zbioru znaków z początku i końca łańcucha
Platformy Technologiczne 2014
System.String
63
Obsługa znaków specjalnych w ciągach (zastosowanie „@”)
string rst1 = "Hi there!";
string vst1 = @"Hi there!";
string rst2 = "It started, \"Four score and seven...\"";
string vst2 = @"It started, ""Four score and seven...""";
string rst3 = "Value 1 \t 5, Val2 \t 10";
string vst3 = @"Value 1 \t 5, Val2 \t 10";
// Interprets tab esc sequence
// Does not interpret tab
string rst4 = "C:\\Program Files\\Microsoft\\";
string vst4 = @"C:\Program Files\Microsoft\";
string rst5 = " Print \x000A Multiple \u000A Lines";
string vst5 = @" Print
Multiple
Lines";
Platformy Technologiczne 2014
StringBuilder
64
Zastosowanie do tworzenia i przetwarzania ciągów znaków
Ciągi są przechowywane w buforze – operacje zazwyczaj są szybsze i
zużywają mniej zasobów
Zaleca się korzystanie ze StringBuilder przy przetwarzaniu stringów w
dużych pętlach
Namespace System.Text
Platformy Technologiczne 2014
StringBuilder - wydajność
65
Źródło: http://www.dotnetperls.com/stringbuilder.png
Platformy Technologiczne 2014
Wyrażenia regularne
66
Wzorce opisujące łańcuchy / ciągi znaków
Funkcjonalności dostępne w System.Text.RegularExpressions
Przykładowe wyrażenia regularne
Platformy Technologiczne 2014
Wyrażenia regularne
67
Przydatne symbole
Symbol
Działanie
\
Następny znak jako znak specjalny (\n = nowa linia, \\ = ‘\’)
^
Wzorzec musi wystąpić na początku ciągu
$
Wzorzec musi wystąpić na końcu ciągu
*
Poprzedzający wzorzec występuje 0-n razy
+
Poprzedzający wzorzec występuje 1-n razy
!
Poprzedzający wzorzec występuje 0 lub 1 razy
{n, m}
Poprzedzający wzorzec występuje od n do m razy
Platformy Technologiczne 2014
Konwersja typów
68
Do konwersji z ciagów znaków na liczby mogą służyć dwie metody
Parse
TryParse
W przypadku błędnej konwersji działanie kończy się wyjątkiem
W przypadku błednej konwersji zwraca status operacji
Inne rodzaje konwersji typów udostępnia klasa Convert
Platformy Technologiczne 2014
Konwersja klas
69
Dwa sposoby na rzutowanie obiektów na inne typy
()
Rzutowanie jednego typu na drugi
W przypadku niepowodzenia generuje wyjątek
as
Konwersja jednego typu na drugi
W przypadku niepowodzenia otrzymujemy null
Nie wspiera konwersji definiowanych przez użytkownika
Platformy Technologiczne 2014
Wątki
70
Zapewnienie równoległego wykonania
Prawdziwe
zrównoleglanie tylko w instancjach
wieloprocesorowych
Wątki a procesy
„tańsza”
komunikacja w ramach wątków jednego
procesu
wspólna pula adresowa dla wątków
Platformy Technologiczne 2014
System.Threading.Thread
71
Instancję nowego wątku tworzymy za pomcą delegata ThreadStart
Alpha oAlpha = new Alpha();
Thread oThread = new Thread(new ThreadStart(oAlpha.Beta));
Lista metod
Metoda
Działanie
Start
Startuje wątek
Abort
Kończy wątek, generuje wyjątek ThreadAbortException
Sleep
Blokuje wątek na przekazaną ilość milisekund
Join
Blokuje wątek tworzący do czasu zakończenia operacji/wątku
Priority
(Property)Pozwala na zdefiniowanie ważności wątku (ThreadPriority)
Finalize
Zwalnia wszystkie zasoby wykorzystywane przez wątek
Platformy Technologiczne 2014
Synchronizacja wątków
72
Sekcja krytyczna – fragment kodu, który może być
wykonywany przez jeden wątek
Tworzenie sekcji krytycznych
Lock
Monitory
Przerwania
Platformy Technologiczne 2014
Lock
73
Blokuje wielowątkowe wykonanie kodu
Zapewnia sekwencyjny dostęp
Wykorzystywany przy dostępie do współdzielonej
pamięci
public int Increment(ref int x)
{
lock (this)
{
return ++x;
}
}
Platformy Technologiczne 2014
Pula wątków
74
Umożliwia zarządzanie grupą wątków
Wykorzystywana podczas tworzenia wielowątkowych
zadań wykonujących zbliżone operacje
Wielowątkowe obliczanie ciągu Fibonacciego
Wątek po zakończeniu wraca do puli
Dodanie wątku do puli:
Platformy Technologiczne 2014
Wielowątkowość w aplikacjach
75
Thread / ThreadPool
Może być zastosowany
w każdego typu
aplikacjach
Do stosowania gdy GUI
nie wymaga informacji o
stanie wątków
BackgroundWorker
Do stosowania w
aplikacjach z GUI
Udostępnia zdarzenia
pozwalające
monitorować wątek z
poziomu GUI
Umożliwia interakcję
wątku z GUI
Platformy Technologiczne 2014
Task Parallel Library
76
„Wielowątkowość dla mas” Scott Hanselmann©
Prostsze API ułatwiające wytwarzanie aplikacji
wielowątkowych
Dzieli się na trzy grupy
Data Parallelism
Task Parallelism
Parallel LINQ
Platformy Technologiczne 2014
Zrównoleglanie pętli
77
Możemy zrównoleglić for lub foreach
Przydatne przy przetwarzaniu niezależnych od siebie
zestawów danych
Dane przetwarzane w aktualnym kroku nie mogą być zależne od
wyników działania poprzedniej iteracji
Struktura:
Operacje w pętli nie są wykonywane sekwencyjnie
Platformy Technologiczne 2014
Zrównoleglanie pętli - przykłady
78
Parallel.For
Parallel.ForEach
Platformy Technologiczne 2014
Zrównoleglanie pętli - wyjątki
79
Po wystąpieniu wyjątku stare iteracje kończą swoją
pracę, nowe nie rozpoczynają się
Wyjątki mogą nawarstwiać się
AggregateException
Wyjątki mają wyższy priorytet niż operacje kończące
pętlę
Platformy Technologiczne 2014
Zrównoleglanie pętli - wyjście
80
Parallel.Break
Parallel.Stop
Wykorzystuje ParallelLoopState
Nie zatrzymuje działających
iteracji
Nie może być użyty razem z
Parallel.Break
Szybszy niż Parallel.Break
Nie wykonują się iteracje z
mniejszym indeksem
Wykonają się iteracje z
mniejszym indeksem
Platformy Technologiczne 2014
Zrównoleglanie operacji
81
Task zamiast Thread
Bardziej rozbudowane API umożliwiające łatwiejsze
zarządzanie
Przechwytywanie wyniku
Platformy Technologiczne 2014
Zrównoleglanie operacji
82
Szeregowanie zadań
Oczekiwanie na ukończenie grupy zadań
Platformy Technologiczne 2014
Asynchroniczność
83
async i await wprowadzone w C# 5.0
Oparte na metodach
Kod przypomina „zwykły”, ciężar przerzucony na
kompilator
Dlaczego warto korzystać:
Lepsze
wrażenia użytkownika (zwłaszcza podczas
operacji na GUI)
Wydajniejsze przetwarzanie
Platformy Technologiczne 2014
async / await
84
Sygnatura metody
Przepływ sterowania
Platformy Technologiczne 2014
Async / await
85
Jak to działa?
Żródło: http://i.msdn.microsoft.com/dynimg/IC612215.png
Platformy Technologiczne 2014
Wskaźniki i kod niezarządzany
86
W C# możemy w szczególnych przypadkach
korzystać z kodu niezarządzanego (komunikacja z
systemem, elementy wymagające zwiększonej
wydajności, …)
Słowo kluczowe „unsafe”
Wymaga zmieny ustawienia kompilatora
Platformy Technologiczne 2014
P/Invoke
87
Platform Invoke pozwala na wywoływanie z
poziomu kodu .NET obiektów niezarządzanych
biblioteki
dll, obiekty COM, dostęp do WIN32 API, …
Użycie atrubutu [DllImport]
Kroki:
Zlokalizowanie
implementowanej biblioteki
Załadowanie biblioteki do pamieci
Znalezienie adresu funkcji i przesłanie argumentów na
stos
Przekazanie kontroli do kodu niezarządzanego
Platformy Technologiczne 2014
P/Invoke
88
using System;
using System.Runtime.InteropServices;
class Class1
{
[DllImport("user32.dll", CharSet=CharSet.Auto)]
static extern int MessageBox(IntPtr hWnd, String text, String caption, int options);
[STAThread]
static void Main(string[] args)
{
MessageBox(IntPtr.Zero, "Text", "Caption", 0);
}
}
Platformy Technologiczne 2014
Refleksja
89
Umożliwia odnoszenie się do systemu typów podczas wykonania programu
Tworzenie typów z przekazanych nazw (stringów)
Dynamiczne pobieranie właściwości klas oraz wywoływanie metod
Namespace System.Reflection
Przykład działania:
Platformy Technologiczne 2014
Przetwarzanie XML
90
System.XML
XSLT Stylesheet
XslTransform
XPathNavigator
XPath
XmlWriter
XmlReader
XmlDocument
XmlPathDocument
XmlDataDocument
XmlDocument
Platformy Technologiczne 2014
Odczyt XML w C#
91
XmlTextReader xtr = new XmlTextReader("Sample1.xml");
while (xtr.Read())
{
Console.WriteLine(xtr.NodeType.ToString() + ":" + xtr.Name + ":" + xtr.Value);
if (xtr.HasAttributes)
{
for (int i = 0; i < xtr.AttributeCount; i++)
{
xtr.MoveToAttribute(i);
Console.WriteLine(xtr.NodeType.ToString() + ":" + xtr.Name + ":" + xtr.Value);
}
xtr.MoveToElement();
}
}
Platformy Technologiczne 2014
Zapis XML w C#
92
XmlTextWriter xtw = new XmlTextWriter("Sample2.xml", null);
xtw.Formatting = Formatting.Indented;
xtw.WriteStartDocument();
xtw.WriteComment("to plik utworzony poprzez obiekt XmlTextWriter");
xtw.WriteStartElement("Książki");
xtw.WriteStartElement("Ksiązka");
xtw.WriteAttributeString("wydawnictwoId", "3");
xtw.WriteStartElement("ISBN");
xtw.WriteString("777-7777-777");
xtw.WriteEndElement();
xtw.WriteEndElement();
xtw.WriteEndElement();
xtw.WriteEndDocument();
xtw.Close();
Platformy Technologiczne 2014
Struktura dokumentu DOM
93
DocumentElement – wierzchołek drzewa dokumentu
Node – każdy z węzłów (w tym elementy)
Rodzaje węzłów:
Węzły elementowe: zwykle zawierają węzły potomne: elementowe, tekstowe
lub obu rodzajów
Węzły atrybutowe: informacja podległa konkretnemu węzłowi elementowemu.
Nie są określane jako potomkowie
Węzeł dokumentu: rodzic dla wszystkich pozostałych węzłów
CData: odpowiada sekcji znakowej, zawierającej zawartość nie przeznaczoną
do przetwarzania
Comment: (komentarz); ProcessingInstruction (instr. przetwarzania)
DocumentFragment: stosowany jako węzeł roboczy przy budowaniu lub
rekonstruowaniu dokumentu XML
Entity, EntityReference, Notation
Platformy Technologiczne 2014
XPath
94
Ułatwia wyszukiwanie w XML pozwalając iterować po kolekcji węzłów
Podstawowe elementy (namespace System.Xml.XPath)
XPathDocument – dokument XML
XPathNavigator – przetwarzanie i parsowanie zapytań XPath
XPathNodeIterator – iterator po liście wynikowej
XPathDocument doc = new XPathDocument("test.xml");
XPathNavigator nav = doc.CreateNavigator();
XPathNodeIterator iterator = nav.Select("/items/compact-disc[1]/artist | /items/compact-disc[1]/title");
iterator.MoveNext();
Console.WriteLine("Artysta={0}", iterator.Current);
iterator.MoveNext();
Console.WriteLine("Tytuł={0}", iterator.Current);
Platformy Technologiczne 2014
Serializacja
95
Serializacja – proces zamiany obiektów na strumień danych
Deserializacja – zamiana strumienia danych na obiekt
Bazowo dostępne rodzaje serializacji:
Binarna – tworzy binarną reprezentację danych za pomocą klasy
BinaryFormatter
SOAP – serializowanie do strumienia XML zgodnego ze standardami
SOAP (SoapFormatter)
XML – serializowanie do strumienia XML (XmlSerializer)
Platformy Technologiczne 2014
Serializacja binarna
96
// Załadowanie obiektu Chair do Hashtable
Hashtable ht = new Hashtable();
// Chair i Upholstery muszą mieć atrybut [Serializable]
Chair ch = new Chair(100.00D, "Broyhill", "10-09");
ch.myUpholstery = new Upholstery("Cotton");
ht.Add("10-09", ch);
// (1) Serializacja // Stworzenie pliku docelowego
FileStream fs= new FileStream("c:\\chairs.dat", FileMode.Create);
BinaryFormatter bf= new BinaryFormatter();
bf.Serialize(fs,ht);
fs.Close();
// (2) Deserializacja pliku do Hashtable
ht.Clear();
fs = new FileStream("c:\\chairs.dat", FileMode.Open);
ht = (Hashtable) bf.Deserialize(fs);
fs.Close();
Platformy Technologiczne 2014
Serializacja binarna - zdarzenia
97
Zdarzenie
Atrybut
Opis
OnSerializing
[Serializing]
Wywoływany przed serializacją; Dla każdego
obiektu oddzielne wywołanie
OnSerialized
[Serialized]
Wywołanie po serializacji; Dla każdego obiektu
oddzielne wywołanie
OnDeserializing [Deserializing] Wywoływany przed deserializacją; Dla każdego
obiektu oddzielne wywołanie
OnDeserialized
[Deserialized]
Wywołanie po deserializacji; Dla każdego obiektu
oddzielne wywołanie
public class Chair
{
[OnDeserialized]
void OnDeserialized(StreamingContext context)
{ /* some logic */ }
}
Platformy Technologiczne 2014
Serializacja XML
98
Elementy tworzone na podstawie serializowanych obiektów klasy domyślnie
otrzymują nazwy zgodne z nazwami reprezentowanych właściwości.
Istnieją Atrybuty serializacji, za pomocą których możemy przykrywać
domyślne nazwy elementów.
XmlElement
Zmienna lub właściwość zostanie podczas serializacji zapisana jako węzeł
XmlAttribute
Dołączony do pola klasy powoduje wygenerowanie jako atrybutu w elemencie.
XmlIgnore
Pole jest omijane podczas serializacji.
XmlText
Atrybut dołączony do pola powoduje serializację jako tekstu.
Nazwa pola zostaje ominięta.
Platformy Technologiczne 2014
Serializacja XML - przykład
99
public class movies
{
public int movieID
{}
public string movie_Title
{}
public int movie_Year
{}
public string movie_Director
{}
public string bestPicture
{}
[XmlElement("AFIRank")]
public int rank
{}
<?xml version="1.0" standalone="yes"?>
<movies>
<movie_ID>5</movie_ID>
<movie_Title>Citizen Kane </movie_Title>
<movie_Year>1941</movie_Year>
<movie_DirectorID>Orson Welles</movie_DirectorID>
<bestPicture>Y</bestPicture>
<AFIRank>1</AFIRank>
</movies>
}
Platformy Technologiczne 2014
Garbage Collector
100
Służy do zarządzania pamięcią
Różne cele na różnych maszynach (serwer / stacja
robocza)
Namespace System.GC
Podstawowe techniki:
Zliczanie
referencji
Graf osiągalności (reachabiliy graph)
Nie zaleca się manualnego wywoływania
Platformy Technologiczne 2014
Finalizatory
101
Uruchamiane przez GarbageCollector przed
zwolnieniem zasobu
Wywoływane niedeterministycznie
Można wymusić automatyczne wywołanie
GC.SuppressFinalize
Finalizacja wymaga 2 cykli GarbageCollectora
1
– przesuniecie obiektu do kolejki finalizacji,
wywołanei finalizatora
2 – zwolnienie zaalokowanej pamięci
Platformy Technologiczne 2014
Destruktory
102
Wołane, gdy obiekt „ulega zniszczeniu”
Wykorzystywane do zwolnienia zasobów
alokowanych przez obiekt
Wykonywane strategią bottom-up
Platformy Technologiczne 2014
Automatyczne zwalnianie zasobów
103
Interfejs IDisposable
using
Wykorzystywany do zwalniania
zasobów niezarządzanych (np.
pliki)
Automatyczne wywołanie metody
Dispose() po zakończeniu cyklu
życia obiektu
Dostęp przez medotę Dispose()
Można wywoływać z własnego
kodu
Pozwala na deklarowanie wielu
obiektów
SqlConnection connection;
try
{
connection = new SqlConnection();
}
catch (SqlException se)
{
//obsługa wyjatku
}
finally
{
connection.Close();
connection.Dispose();
}
using (SqlConnection connection = new SqlConnection())
{
//kod programu
}
Platformy Technologiczne 2014