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 17:22 | Komunita

Včera vydanou hru Rise of the Tomb Raider pro Linux lze do pondělí 23. dubna koupit na Steamu s 67% slevou. Místo 49,99 € za 16,49 €.

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

Na Humble Bundle lze získat počítačovou hru Satellite Reign (Wikipedie, YouTube) běžící také v Linuxu zdarma. Speciální akce končí v sobotu v 19:00.

Ladislav Hagara | Komentářů: 0
dnes 15:44 | Zajímavý software

Společnost Apple koupila před třemi lety společnost FoundationDB vyvíjející stejnojmenný NoSQL databázový systém FoundationDB (Wikipedie). Včera byl tento systém uvolněn jako open source pod licencí Apache 2.0. Zdrojové kódy jsou k dispozici na GitHubu.

Ladislav Hagara | Komentářů: 0
dnes 15:00 | Nová verze

Po dva a půl roce od vydání verze 5.7 oznámila společnost Oracle vydání nové major verze 8.0 (8.0.11) databázového systému MySQL (Wikipedie). Přehled novinek v poznámkách k vydání. Zdrojové kódy komunitní verze MySQL jsou k dispozici na GitHubu.

Ladislav Hagara | Komentářů: 1
včera 14:44 | Pozvánky

Spolek OpenAlt zve příznivce otevřených technologií a otevřeného přístupu na 151. brněnský sraz, který proběhne v pátek 20. 4. od 18:00 hodin v restauraci Benjamin na Drobného 46.

Ladislav Hagara | Komentářů: 0
včera 13:33 | Nová verze

Byla vydána verze 18.04.0 KDE Aplikací (KDE Applications). Přehled novinek v kompletním seznamu změn a na stránce s dalšími informacemi.

Ladislav Hagara | Komentářů: 0
včera 13:11 | Nová verze

Bylo oznámeno vydání nové stabilní verze 1.26 a beta verze 1.27 open source textového editoru Atom (Wikipedie). Přehled novinek i s náhledy v příspěvku na blogu. Podrobnosti v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
včera 12:55 | Komunita

Dle plánu byla dnes vydána hra Rise of the Tomb Raider (Wikipedie) pro Linux. Koupit ji lze za 49,99 €.

Ladislav Hagara | Komentářů: 3
včera 09:55 | Bezpečnostní upozornění

Společnost Oracle vydala čtvrtletní bezpečnostní aktualizaci svých softwarových produktů (CPU, Critical Patch Update). Opraveno bylo celkově 254 bezpečnostních chyb. V Oracle Java SE je například opraveno 14 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 12 z nich. V Oracle MySQL je opraveno 33 bezpečnostních chyb. Vzdáleně zneužitelné bez autentizace jsou 2 z nich.

Ladislav Hagara | Komentářů: 3
18.4. 23:11 | Nová verze

Byla vydána verze 8.0 linuxové distribuce Trisquel GNU/Linux. Nejnovější verze Trisquel nese kódové jméno Flidas a bude podporována do roku 2021. Výchozím prostředím je nově MATE 1.12. Trisquel patří mezi svobodné distribuce doporučované Nadací pro svobodný software (FSF).

Ladislav Hagara | Komentářů: 0
Používáte na serverech port knocking?
 (3%)
 (7%)
 (47%)
 (26%)
 (17%)
Celkem 329 hlasů
 Komentářů: 29, poslední 5.4. 12:25
    Rozcestník

    Dotaz: C++ pthread a trida - problem s vytvorenim vlakna

    29.11.2008 16:17 Tomáš Skočdopole | skóre: 13
    C++ pthread a trida - problem s vytvorenim vlakna
    Přečteno: 2125×

    Ahoj,

    v souvislosti s diskuzi Metody pristupu na seriovy port v C jsem se rozhodl resit to pres vlakna. Chtel jsem to udelat tak, ze by kazda instance tridy vytvorila dve vlakna - jedno pro RX, druhe pro TX.

    Bohuzel jsem narazil na problem nevim jak vytvorit vlakno, ktere se vytvori s "main" funkci, ktera je metodou dane tridy: 

    Udelal jsem jednoduchy example:

    trida.h

    #ifndef _TRIDA_H_
    #define _TRIDA_H_

    #include <iostream>
    #include <pthread.h>

    using namespace std;

    class my_class
    {
        public:
        my_class(void);
      
        private:
        void* my_thread_main(void*);
      
        pthread_t my_thread_tid;
    };


    #endif // _TRIDA_H_

     

    trida.cpp


    #include "trida.h"

    my_class::my_class (void)
    {
        cout << "Hello from my_class!";
      
        pthread_create(&(this->my_thread_tid),
                       NULL,
                       &(this->my_thread_main),
                       NULL);

        return;
    }

    my_class::~my_class (void)
    {
        /* pthread_join() */
      
        return;
    }

    void * my_class::my_thread_main (void *) {
      
        cout << "Hello from my_thread_main!";
      
        return(0);
    }

    test.cpp


    #include <iostream>
    #include "trida.h"

    using namespace std;

    int main (int argc, char **argv)
    {
        my_class example;
      
        cout << "Hello from main!\n";
      
        return (0);
    }

     

    Pri prekladu dostanu toto:

    g++ -c trida.cpp -o trida.o
    trida.cpp: In constructor ‘my_class::my_class()’:
    trida.cpp:9: error: ISO C++ forbids taking the address of a bound member function to form a pointer to member function.  Say ‘&my_class::my_thread_main’
    trida.cpp:10: error: cannot convert ‘void* (my_class::*)(void*)’ to ‘void* (*)(void*)’ for argument ‘3’ to ‘int pthread_create(pthread_t*, const pthread_attr_t*, void* (*)(void*), void*)’
    trida.cpp: At global scope:
    trida.cpp:15: error: definition of implicitly-declared ‘my_class::~my_class()’
    make: *** [trida.o] Error 1

     

    Dekuji vsem za pomoc! Tomas

    Odpovědi

    Bluebear avatar 29.11.2008 16:28 Bluebear | skóre: 30 | blog: Bluebearův samožerblog | Praha
    Rozbalit Rozbalit vše Re: C++ pthread a trida - problem s vytvorenim vlakna

    V prvé řadě: IMHO není vůbec dobrý nápad dělat komunikaci přes port tak, že jedno vlákno posílá a druhé přijímá. Možná se mýlím, ale myslím, že to bude strašný bordel.

    Metodu třídy my_main() máš deklarovanou jako metodu třídy my_class. Volání pthread_create() očekává ukazatel na funkci, ale ty se snažíš mu předat metodu třídy - to nemůžeš udělat, protože metoda třídy očekává navíc ukazatel na "this", který jí nemáš jak předat.

    Fungovalo by to, kdyby byla metoda my_main() deklarována jako statická, a ukazatel na příslušný objekt my_class bys jí předával explicitně; potom můžeš tento ukazatel předat jako "uživatelská data" skrz volání pthread_create() a vymalováno.

    To mi připomíná, jak jsem si pořídil květináč, že v něm budu mít květinu. Opravdu tam byla, ale potom být přestala...
    Bluebear avatar 29.11.2008 16:34 Bluebear | skóre: 30 | blog: Bluebearův samožerblog | Praha
    Rozbalit Rozbalit vše Re: C++ pthread a trida - problem s vytvorenim vlakna

    Jo: zkus se inspirovat nějakou už hotovou C++ knihovnou.

    Jako příklad se mrkni třeba na to, jak je udělaná třída QThread z Qt. Není to nijak těžké, jen je třeba udělat ten taneček okolo předávání pointeru na objekt.

    To mi připomíná, jak jsem si pořídil květináč, že v něm budu mít květinu. Opravdu tam byla, ale potom být přestala...
    29.11.2008 17:10 Tomáš Skočdopole | skóre: 13
    Rozbalit Rozbalit vše Re: C++ pthread a trida - problem s vytvorenim vlakna

    No ale jak lze tedy efektivne resit pristup k portu? Kdyz select nelze pouzit protoze chci behem prijimani a odesilani delat neco jineho a ne cekat na data od portu.

    Potrebuji totiz soubezne zpracovani dat na seriovem portu a provadeni jineho kodu.

    Pokud by ale byla metoda staticka, tak to by znamenalo, ze by vsechny instance tridy meli tuto metodu spolecnou.

    Ale ja bych chtel aby kazdy seriovy port mel sve dve vlakna.

    Josef Kufner avatar 30.11.2008 03:51 Josef Kufner | skóre: 68
    Rozbalit Rozbalit vše Re: C++ pthread a trida - problem s vytvorenim vlakna
    select() má timeout (poslední parametr) a ten může být nulový (nikoliv nullový).
    Hello world ! Segmentation fault (core dumped)
    ava avatar 30.11.2008 14:46 ava | skóre: 10
    Rozbalit Rozbalit vše Re: C++ pthread a trida - problem s vytvorenim vlakna

    Napis co vlastne potrebujes udelat (co ma ta aplikace delat kdyz se zrovna nepristupuje k seriaku), a myslim ze by bylo dobre zamyslet se nad tim jestli by to neslo resit jen s jednim vlaknem a neblokujicim ctenim, ve vetsine pripadu to jde a je to lepsi reseni nez s pomoci vlaken.

    Press any key to continue, or any other key to cancel
    Josef Kufner avatar 30.11.2008 04:03 Josef Kufner | skóre: 68
    Rozbalit Rozbalit vše Re: C++ pthread a trida - problem s vytvorenim vlakna
    Koukni se na mého krtečka... Byla to mimojiné i semestrálka z x36osy na téma "Chceme vlákna a chceme jich mooooooooc.". Zejména tě budou zajímat soubory thread.(cc|h) -- obsahují třídu, kterou si zdědíš, implementuješ main() a už jen vyrábíš co instance, to vlákno. Ale pozor, ty vlákna se s tím vyrábějí až nebezpečně lehce, tak se nezamotej :-D

    ... btw, nechce ovládání krtka někdo naportovat do tuxánků nebo zatacky? Mohlo by pak u jednoho počítače hrát několik dalších hráčů -- používali by jeden mikrofon a tůůůů, hůůůů, tůůůůůůů, pííííísk.
    Hello world ! Segmentation fault (core dumped)
    30.11.2008 10:04 vencas | skóre: 32
    Rozbalit Rozbalit vše Re: C++ pthread a trida - problem s vytvorenim vlakna

    Pripojuji se v tom smyslu, že dělat vlákna přes pthreads je v c++ zbytečná dřina. Osobně bych doporučil www.boost.org/doc/html/thread.html .

    Luboš Doležel (Doli) avatar 30.11.2008 13:07 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: C++ pthread a trida - problem s vytvorenim vlakna
    Zapojovat Boost (který zas jen zavolá pthreads) do jednoduchého programu mi zase přijde overkill.
    elviin avatar 30.11.2008 21:08 elviin | skóre: 29 | blog: elviin | Plzeň-Praha
    Rozbalit Rozbalit vše Re: C++ pthread a trida - problem s vytvorenim vlakna

    Pokud bude delat jen jeden programek v C++ tak je to overkill, pokud se tim bude dlouhodobe zabejvat, tak boost je jasna volba.

    30.11.2008 22:34 vencas | skóre: 32
    Rozbalit Rozbalit vše Re: C++ pthread a trida - problem s vytvorenim vlakna

    Přibere tím závislost navíc, ale co se týče čitelnosti kódu (a přenositelnosti, ale to je v tomto případě asi jedno), tak tím myslím získá.

    8.12.2008 12:14 Deleted [8409] | skóre: 14 | blog: darkblog
    Rozbalit Rozbalit vše Re: C++ pthread a trida - problem s vytvorenim vlakna
    Potřebujete to jen obalit do statické funkce, něco takového:
    #ifndef _TRIDA_H_
    #define _TRIDA_H_
    
    #include <iostream>
    #include <pthread.h>
    
    using namespace std;
    
    class my_class
    {
    public:
        my_class(void);
      
    private:
        static void* _entry(void*);
        void* main();
      
        pthread_t _id;
    };
    
    
    #endif // _TRIDA_H_
    
    my_class::my_class (void)
    {
        cout << "Hello from my_class!";
      
        pthread_create(&(this->_id), NULL, &_entry, NULL);
    
        return;
    }
    
    my_class::~my_class (void)
    {
        /* pthread_join() */
      
        return;
    }
    
    void* my_class::_entry (void* data)
    {
      my_class* thread = (my_class*)data;
      return thread->main();
    }
    
    void *my_class::main()
    {
        cout << "Hello from my_thread_main!";
      
        return(0);
    }
    

    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.