abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 18:55 | IT novinky

    Společnost Valve publikovala přehled To nej roku 2025 ve službě Steam aneb ohlédnutí za nejprodávanějšími, nejhranějšími a dalšími nej hrami roku 2025.

    Ladislav Hagara | Komentářů: 0
    dnes 16:11 | Komunita

    Byly publikovány výsledky průzkumu mezi uživateli Blenderu uskutečněného v říjnu a listopadu 2025. Zúčastnilo se více než 5000 uživatelů.

    Ladislav Hagara | Komentářů: 0
    dnes 03:33 | Bezpečnostní upozornění

    V dokumentově orientované databázi MongoDB byla nalezena a v upstreamu již opravena kritická bezpečností chyba CVE-2025-14847 aneb MongoBleed.

    Ladislav Hagara | Komentářů: 0
    včera 23:11 | IT novinky

    Při úklidu na Utažské univerzitě se ve skladovacích prostorách náhodou podařilo nalézt magnetickou pásku s kopií Unixu V4. Páska byla zaslána do počítačového muzea, kde se z pásky úspěšně podařilo extrahovat data a Unix spustit. Je to patrně jediný známý dochovaný exemplář tohoto 52 let starého Unixu, prvního vůbec programovaného v jazyce C.

    🇨🇽 | Komentářů: 1
    včera 15:55 | Komunita

    FFmpeg nechal kvůli porušení autorských práv odstranit z GitHubu jeden z repozitářů patřících čínské technologické firmě Rockchip. Důvodem bylo porušení LGPL ze strany Rockchipu. Rockchip byl FFmpegem na porušování LGPL upozorněn již téměř před dvěma roky.

    🇨🇽 | Komentářů: 7
    včera 15:44 | Zajímavý software

    K dispozici je nový CLI nástroj witr sloužící k analýze běžících procesů. Název je zkratkou slov why-is-this-running, 'proč tohle běží'. Klade si za cíl v 'jediném, lidsky čitelném, výstupu vysvětlit odkud daný spuštěný proces pochází, jak byl spuštěn a jaký řetězec systémů je zodpovědný za to, že tento proces právě teď běží'. Witr je napsán v jazyce Go.

    🇨🇽 | Komentářů: 1
    včera 15:33 | Zajímavý software

    Yazi je správce souborů běžící v terminálu. Napsán je v programovacím jazyce Rust. Podporuje asynchronní I/O operace. Vydán byl v nové verzi 25.12.29. Instalovat jej lze také ze Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    26.12. 18:44 | Komunita

    Od soboty do úterý probíhá v Hamburku konference 39C3 (Chaos Communication Congress) věnovaná také počítačové bezpečnosti nebo hardwaru. Program (jiná verze) slibuje řadu zajímavých přednášek. Streamy a záznamy budou k dispozici na media.ccc.de.

    Ladislav Hagara | Komentářů: 0
    26.12. 13:22 | Zajímavý software

    Byl představen nový Xserver Phoenix, kompletně od nuly vyvíjený v programovacím jazyce Zig. Projekt Phoenix si klade za cíl být moderní alternativou k X.Org serveru.

    🇨🇽 | Komentářů: 7
    26.12. 13:11 | Nová verze

    XLibre Xserver byl 21. prosince vydán ve verzi 25.1.0, 'winter solstice release'. Od založení tohoto forku X.Org serveru se jedná o vůbec první novou minor verzi (inkrementovalo se to druhé číslo v číselném kódu verze).

    🇨🇽 | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (34%)
     (1%)
     (24%)
     (1%)
     (2%)
     (1%)
     (10%)
     (11%)
     (17%)
    Celkem 191 hlasů
     Komentářů: 21, poslední dnes 18:58
    Rozcestník

    Dotaz: Manuálna alokácia pointeru

    2.4.2021 13:44 Otazka
    Manuálna alokácia pointeru
    Přečteno: 2322×
    Dobrý deň, viete mi poradiť, kde môžem mať chybu? V C++ som doteraz nepoužíval manuálnu alokáciu - takže s tým moc nemám skúsenosti, ale na tento účel by som ju chcel použiť. Metóda má čítať dáta zo sériového portu (ale pracuje s ním ako z normálnym súborom).

    Metóda číta dáta do ručne alokovaného bufferu. Pokiaľ je riadok menší ako BUFF_SIZE tak všetko funguje správne. Pokiaľ je riadok väčší ako buffer, tak sa buffer pridá do std::stringu a potom sa nastaví pointer na začiatok bufferu a length na 0. BUFF_SIZE je 1024, ale pri testovaní som ho nastavil na 10. A mám pocit že niekde pri delete[] mi to asi blbne.
    std::string ReadLine() const
    {
    	constexpr size_t BUFF_SIZE = 1024;
    	char* buffer = new char[BUFF_SIZE];
    	char* pointer = buffer;
    	DWORD readedBytes, length = 0;
    	auto line = std::string();
    	while (true) {
    		if (ReadFile(handle, pointer, static_cast<DWORD>(1), &readedBytes, nullptr))
    		{
    			if (*pointer == '\r' || *pointer == '\n' || readedBytes == 0)
    			{
    				line.append(buffer, length);
    				pointer = nullptr;
    				delete[] buffer;
    				return line;
    			}
    			else
    			{
    				if (length == BUFF_SIZE) {
    					line.append(buffer, length);
    					length = 0;
    					pointer = buffer;
    				}
    				else {
    					pointer++;
    					length++;
    				}
    			}
    		}
    		else {
    			delete[] buffer;
    			throw SomeException();
    		}
    	}
    }
    

    Řešení dotazu:


    Odpovědi

    2.4.2021 15:43 rastos | skóre: 63 | blog: rastos
    Rozbalit Rozbalit vše Re: Manuálna alokácia pointeru
    Nie že by som si bol totálne istý, ale skúsme takto:

    Keď začína prvá iterácia tak length je 0 a pointer ukazuje na buffer[0]. Časom príde iterácia, kde sa na riadku 26 pointer nasmeruje na buffer[9] a length sa na riadku 27 inkrementuje na hodnotu 9.

    buffer[9] je posledný alokovaný bajt v poli buffer. A ten bajt sme ešte nenaplnili volaním ReadFile(). Začne ďalšia iterácia, zavolá sa ReadFile(), naplní sa buffer[9], length sa porovná na BUFF_SIZE 10 a zistí sa, že sa nerovná. Takže sa znova inkrementuje pointer, namieri sa na buffer[10] - to už je mimo alokovaného priestoru - a length sa inkrementuje na 10 a znova sa zavolá ReadFile(). Ten zapíše tam kam ukazuje pointer, teda do buffer[10], a prepíše niečo, z čoho je následne nejaké delete[] nešťastné.

    Mám pravdu?

    Btw, keď už robíš ReadFile() po jednom znaku, tak sa na nejaký buffer môžeš vykašľať a rovno urobiť
    char c;
    ...
    ReadFile(handle, &c, 1, &readedBytes, nullptr)
    ...
    line.append(c);
    2.4.2021 15:52 Otazka
    Rozbalit Rozbalit vše Re: Manuálna alokácia pointeru
    Hej dík za tip, predchvíľkou som na to prišiel, že som sa dostal mimo rozsahu.
    2.4.2021 15:49 Otazka
    Rozbalit Rozbalit vše Re: Manuálna alokácia pointeru
    Tak problém vyriešený, mal som tam dve chyby:
    std::string ReadLine(const size_t bufferSize = 1024) const
    {
    	char* buffer = new char[bufferSize + 1];
    	char* pointer = buffer;
    	DWORD readedBytes, length = 0;
    	auto line = std::string();
    	while (true) {
    		if (ReadFile(handle, pointer, static_cast<DWORD>(1), &readedBytes, nullptr))
    		{
    			if (*pointer == 'r' || *pointer == 'n' || readedBytes == 0)
    			{
    				line.append(buffer, length);
    				pointer = nullptr;
    				delete[] buffer;
    				return line;
    			}
    			else
    			{
    				if (length == bufferSize) {
    					line.append(buffer, length + 1);
    					length = 0;
    					pointer = buffer;
    				}
    				else {
    					pointer++;
    					length++;
    				}
    			}
    		}
    	}
    }
    
    🇨🇽 avatar 2.4.2021 16:13 🇨🇽 | skóre: 37 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Manuálna alokácia pointeru
    6.4.2021 00:53 Jardík
    Rozbalit Rozbalit vše Re: Manuálna alokácia pointeru
    ReadFile může vrátit TRUE a zároveň nastavit počet přečtených bytů na 0 (EOF, nebo u roury, pokud se na ní zavolá WriteFile s 0B). Tento případ nemáš ošetřený.

    Když vám ReadFile vrátí FALSE, myslíte, že když ho zavoláte znovu (uživatel odpojil třeba flashku se souborem), že vám vrátí TRUE? Program zbytečně zacyklíte, měl byste nejspíše vrátit z funkce.

    Proč parametr funkce "lže"? Má parametr bufferSize, ale přitom funkce alokuje buffer o velikosti (bufferSize+1). K čemu je tam +1? Jś to samozřejmě vidím ... kvůli špatně navrženému cyklu. Kdybyste length zvýšil hned po zápisu, nemusel by být potřeba +1. Snad, jestli špatně nečučim.

    Pokud nejprve přijde \n a potom \r, tak bude jeden řádek prázdný?

    Pozor na mixování size_t a DWORD. Typy mohou mít jinou velikost (a na amd64 mají). Váš kód se asi rozpadne, pokud zavolám funkci s bufferSize = std::numeric_limits<DWORD>::max().

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.