-
Data: 2011-02-01 22:45:29
Temat: Re: które języki 'historyczne' s? ważne
Od: Jędrzej Dudkiewicz <j...@n...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On 02/01/2011 11:05 PM, R. P. wrote:
> W dniu 2011-02-01 23:00, Jędrzej Dudkiewicz pisze:
>> Awk jest specjalizowanym narzędziem do przetwarzania tekstu, nic
>> dziwnego, że będzie działał szybciej niż napisany naprędce program w
>> C++. Fakt, że jest interpretowany, specjalnie nie przeszkadza, bo część
>> międląca napisy to kod cyzelowany pewnie od późnych lat
>> siedemdziesiątych. XIX wieku. W sensie - od dawna.
>
> Jasne, ale zaznaczam, że to był ten sam algorytm (dość trywialny
> O(n))... w C++ pomimo zastosowania resize'ów i używania referencji gdzie
> się da nie udało mi się uzyskać takiej wydajności jak w naprędce
> napisanym programie w awk, od którego nie jestem żadnym specjalistą i
> znam go co nieco tylko!
Skoro algorytm był trywialny, to znaczy, że znaczenie miało tylko
wycyzelowanie kodu go wykonującego. Gdyby cyzelowanie oznaczało tylko
referencje i resize, to programowanie byłoby proste.
>>> Tak mierzyłem. Miałem zestaw funkcji wczytujący pliki do pamięci (pliki
>>> 2-3 Gb) - stream okazał się 3x wolniejszy od chamskiego C-owego fgets'a.
>>> To są fakty.
>>
>> Bo stream może zrobić 3 razy więcej od chamskiego C-owego fgets. Poza
>> tym fgets czyta do stałego bufora. W świetle tego trzykrotna różnica nie
>> jest taka powalająca.
>
> Może zrobić 3x więcej. Ale jeśli mnie interesuje tylko wczytanie pliku
> linia po linii do wektora, to wolę użyć fgets.
No to po co używasz streamów? Jak chcesz znaleźć pierwsze wystąpienie
litery 'a' w stringu to używasz wyrażeń regularnych?
> 3x szybciej to nie jest
> duża różnica? Tzn. że task skończy się 3x szybciej, a trwa kilka dni (bo
> plików jest setki tysięcy)...
Ale przecież ja mówiłem o osiągach w porównaniu z możliwościami. To Twój
problem, że ich nie używasz.
JD
Następne wpisy z tego wątku
- 01.02.11 23:31 Andrzej Jarzabek
- 02.02.11 00:06 Andrzej Jarzabek
- 02.02.11 01:01 Jędrzej Dudkiewicz
- 02.02.11 01:25 Michoo
- 02.02.11 02:22 Michoo
- 02.02.11 02:23 Michoo
- 02.02.11 06:30 Adam Przybyla
- 02.02.11 06:32 Grzegorz Krukowski
- 02.02.11 07:46 Andrzej Jarzabek
- 02.02.11 08:04 Tomasz Kaczanowski
- 02.02.11 08:05 Tomasz Kaczanowski
- 02.02.11 08:08 Krzysiek Kowaliczek
- 02.02.11 08:22 Krzysiek Kowaliczek
- 02.02.11 08:28 Krzysiek Kowaliczek
- 02.02.11 09:08 Stachu 'Dozzie' K.
Najnowsze wątki z tej grupy
- 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
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
- Ada 2022 Language Reference Manual to be Published by Springer
Najnowsze wątki
- 2024-10-18 Gdańsk => Technical Lead ( (Java Background)) <=
- 2024-10-18 Warszawa => Head of International Freight Forwarding Department <=
- 2024-10-18 uwazajmy na haczyki w umowach
- 2024-10-18 Warszawa => Account Manager - Usługi rekrutacyjne <=
- 2024-10-18 Białystok => Full Stack web developer (obszar .Net Core, Angular6+) <
- 2024-10-18 Gdańsk => Software .Net Developer <=
- 2024-10-18 Warszawa => Junior Rekruter <=
- 2024-10-18 Warszawa => Key Account Manager <=
- 2024-10-18 Przeróbka na zgrzewarkę "równoległą"
- 2024-10-18 Ostrów Wielkopolski => Laravel PHP Developer <=
- 2024-10-18 Warszawa => Data Scientist / Data Engineer (modele predykcyjne) <=
- 2024-10-18 doładowania 5zł
- 2024-10-17 Prośba o identyfikację komponentu
- 2024-10-17 Warszawa => Expert Recruiter 360 <=
- 2024-10-17 Warszawa => Account Manager - Sprzedaż Usług Rekrutacyjnych <=