-
X-Received: by 2002:a05:620a:992:: with SMTP id x18mr12332425qkx.273.1592897585761;
Tue, 23 Jun 2020 00:33:05 -0700 (PDT)
X-Received: by 2002:a05:620a:992:: with SMTP id x18mr12332425qkx.273.1592897585761;
Tue, 23 Jun 2020 00:33:05 -0700 (PDT)
Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed.pionier.net.pl!3.eu.feeder.erj
e.net!feeder.erje.net!news.uzoreto.com!feeder1.cambriumusenet.nl!feed.tweak.nl!
209.85.160.216.MISMATCH!news-out.google.com!nntp.google.com!postnews.google.com
!google-groups.googlegroups.com!not-for-mail
Newsgroups: pl.comp.programming
Date: Tue, 23 Jun 2020 00:33:05 -0700 (PDT)
In-Reply-To: <d...@g...com>
Complaints-To: g...@g...com
Injection-Info: google-groups.googlegroups.com; posting-host=131.228.2.21;
posting-account=VFwkXwoAAADdT4-lLKRZrMYkTjizGoyn
NNTP-Posting-Host: 131.228.2.21
References: <d...@g...com>
<3...@g...com>
<7...@g...com>
<a...@g...com>
<d...@g...com>
User-Agent: G2/1.0
MIME-Version: 1.0
Message-ID: <7...@g...com>
Subject: Re: Embedded HTTP Server
From: Wojciech Muła <w...@g...com>
Injection-Date: Tue, 23 Jun 2020 07:33:05 +0000
Content-Type: text/plain; charset="UTF-8"
Content-Transfer-Encoding: quoted-printable
Xref: news-archive.icm.edu.pl pl.comp.programming:215004
[ ukryj nagłówki ]On Monday, June 8, 2020 at 9:20:39 PM UTC+2, Maciej Sobczak wrote:
> > int main() {
> > auto server = std::make_unique<http::Server>(8008, ".");
> >
> > server->start();
>
> Czyli też jedna dodatkowa linijka kodu, w dodatku zawsze, nawet w najprostszym
programie.
> Więc na czym polega postęp?
Na braku konieczności ręcznego tworzenia i zarządzania wątkiem.
> Się tak łatwo nie zamyka, jeśli ma callbacki.
Co mnie jako twórcę biblioteki obchodzi, że ktoś ma burdel w callbackach. Ja
gwarantuję, że moje wątki się skończą jeśli skończą się callbacki.
> > Stoi, bo masz współdzieloną mapę routingu.
>
> Przyłapałeś mnie. Skupiłem się na portach - faktycznie mapa jest wspólna.
> Czyli twierdzisz, że ktoś będzie koniecznie chciał zrobić w jednym programie 5
serwerów na różnych portach, ale tak, żeby takie same linki robiły w nich różne
rzeczy?
> To brzmi jak ostra perwersja. Tylko dlaczego ja mam w tym uczestniczyć?
Bo np. na jednym porcie masz dane dla userów, na drugim możesz dawać output z
debuggera, profilera, co tam sobie robisz. Wiesz, to że Twój serwer jest prosty, nie
znaczy, że aplikacja która go użyje też jest prosta. Gdyby była prosta, pewnie nikt
by jej nie pisał w C++.
> > A, że masz ją współdzieloną, to też masz radosnego mutexa w głównej pętli.
>
> I w czym ten mutex przeszkadza, skoro go nawet nie widać?
Bo mutexy są kosztowne czasowo. I akurat tego jednego mogłoby nie być.
> > No i to jest defekt. Ja chcę, żeby mój program się zamykał w cywilizowany sposób.
> > Callbacki są wołane w wątkach, robisz sobie na nie barierę (czyli np. latch) po
zakończeniu głównej pętli i po kłopocie.
>
> O ile wszystkie wrócą. Zobacz przykład 6. Można go przepisać tak, że to funkcja
get_updates() będzie robić to, co activity(). Czyli nigdy nie wróci.
>
> Ale owszem, jest to możliwe rozwiązanie, tylko wymaga zmiany koncepcji komunikacji.
Teraz, w prostej implementacji, jest to komunikacja blokująca. Wątek obsługujący
połączenie nie wróci, jeśli utknął na odczycie z gniazda (a w tym stanie spędza
większość czasu), dopóki *klient* tego połączenia nie zamknie. Nie wystarczy sobie
ustawić flagę.
Ale w końcu wróci, choćby przez timeout. I o to chodzi.
> > To jest koślawe, sorry. W HTTP masz nie tylko akcje GET i POST, ale i chyba ze 20
innych.
>
> Ale ja nie obiecuję obsługi tych 20 innych.
Super, więc jak będę chciał mieć operację DELETE albo PUT, to muszę sobie szukać
innego rozwiązania.
> > Poza tym założenie, że ktoś będzie argumenty POST przesyłał w URL-u jest zdziebko
przestarzałe, o wiele wygodniej jest słać parametry w JSONie.
>
> Przecież właśnie tak jest. Dlatego funkcje dla POST mają dodatkowy argument istream
- tam są te dane, które normalni ludzie przekazują.
>
> I właśnie dlatego funkcje dla GET i POST *różnią się* sygnaturami.
No fajnie, tylko to sztuczne rozróżnienie. W protokole HTTP nie ma znaczenia typ
akcji, zawsze masz ten same input, w akcji GET też możesz wysłać dane, np. JSONa.
> > Pamiętanie o kilku wariantach funkcji nie jest prostsze. Już lepiej byłoby mieć
jedną przeciążoną metodę register i kilka pomocniczych funkcji w stylu
"make_get_action".
>
> Czyli że:
>
> register(make_get_action(my_action));
>
> jest lepsze od:
>
> register_get_action(my_action);
>
> Sorry - ani trochę.
Jest bardziej elastyczne i tyle. Ja wolę mieć jedną metodę i zrobić sobie odpowiednie
konstruktory.
Zresztą, najlepiej byłby mieć register(my_action) i wybierać wariant za pomocą
typetraits.
> > Np. testy jednostkowe parserów, których jest co najmniej ze 2. Jak widzę
> > 5-krotnie zagnieżdżony kod, to nie wiem, czego się spodziewać.
>
> Uwaga, szpan: pokrycie strukturalne zapewniłem testami systemowymi.
>
> Bez przesady z tymi testami.
Chciałeś review, to masz. Ja wiem, że parsery klepane ręcznie nie mające testów to
proszenie się o kłopoty, będą wcześniej, czy później.
w.
Następne wpisy z tego wątku
- 23.06.20 23:13 Maciej Sobczak
Najnowsze wątki z tej grupy
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
Najnowsze wątki
- 2025-01-22 Gdańsk => System Architect (Java background) <=
- 2025-01-22 Katowice => Senior Field Sales (system ERP) <=
- 2025-01-22 Warszawa => Java Developer <=
- 2025-01-22 pokolenie Z
- 2025-01-22 Wyświtlacz ramki cyfrowej
- 2025-01-22 Białystok => Architekt rozwiązań (doświadczenie w obszarze Java, A
- 2025-01-22 Chrzanów => Team Lead / Tribe Lead FrontEnd <=
- 2025-01-22 Ostrów Wielkopolski => Konsultant Wdrożeniowy Comarch XL/Optima (Ksi
- 2025-01-22 oferta na ubezpieczenie OC życie prywatne
- 2025-01-22 Bieruń => Spedytor Międzynarodowy (handel ładunkami/prowadzenie flo
- 2025-01-22 Warszawa => International Freight Forwarder <=
- 2025-01-22 Gdańsk => Specjalista ds. Sprzedaży <=
- 2025-01-21 Zgromadzenie użytkowników pojazdów :-)
- 2025-01-21 bateria na żądanie
- 2025-01-21 Warszawa => IT Business Analyst <=