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 01:55 | IT novinky

    Nejvyšší správní soud (NSS) podruhé zrušil pokutu za únik zákaznických údajů z e-shopu Mall.cz. Incidentem se musí znovu zabývat Úřad pro ochranu osobních údajů (ÚOOÚ). Samotný únik ještě neznamená, že správce dat porušil svou povinnost zajistit jejich bezpečnost, plyne z rozsudku dočasně zpřístupněného na úřední desce. Úřad musí vždy posoudit, zda byla přijatá opatření přiměřená povaze rizik, stavu techniky a nákladům.

    Ladislav Hagara | Komentářů: 0
    včera 18:44 | Komunita

    Organizace Free Software Foundation Europe (FSFE) zrušila svůj účet na 𝕏 (Twitter) s odůvodněním: "To, co mělo být původně místem pro dialog a výměnu informací, se proměnilo v centralizovanou arénu nepřátelství, dezinformací a ziskem motivovaného řízení, což je daleko od ideálů svobody, za nimiž stojíme". FSFE je aktivní na Mastodonu.

    Ladislav Hagara | Komentářů: 13
    včera 17:55 | IT novinky

    Paramount nabízí za celý Warner Bros. Discovery 30 USD na akcii, tj. celkově o 18 miliard USD více než nabízí Netflix. V hotovosti.

    Ladislav Hagara | Komentářů: 3
    včera 13:22 | IT novinky

    Nájemný botnet Aisuru prolomil další "rekord". DDoS útok na Cloudflare dosáhl 29,7 Tbps. Aisuru je tvořený až čtyřmi miliony kompromitovaných zařízení.

    Ladislav Hagara | Komentářů: 4
    včera 12:11 | Nová verze

    Iced, tj. multiplatformní GUI knihovna pro Rust, byla vydána ve verzi 0.14.0.

    Ladislav Hagara | Komentářů: 2
    včera 05:22 | Komunita

    FEX, tj. open source emulátor umožňující spouštět aplikace pro x86 a x86_64 na architektuře ARM64, byl vydán ve verzi 2512. Před pár dny FEX oslavil sedmé narozeniny. Hlavní vývojář FEXu Ryan Houdek v oznámení poděkoval společnosti Valve za podporu. Pierre-Loup Griffais z Valve, jeden z architektů stojících za SteamOS a Steam Deckem, v rozhovoru pro The Verge potvrdil, že FEX je od svého vzniku sponzorován společností Valve.

    Ladislav Hagara | Komentářů: 0
    včera 03:22 | Nová verze

    Byla vydána nová verze 2.24 svobodného video editoru Flowblade (GitHub, Wikipedie). Přehled novinek v poznámkách k vydání. Videoukázky funkcí Flowblade na Vimeu. Instalovat lze také z Flathubu.

    Ladislav Hagara | Komentářů: 0
    7.12. 15:11 | IT novinky

    Společnost Proton AG stojící za Proton Mailem a dalšími službami přidala do svého portfolia online tabulky Proton Sheets v Proton Drive.

    Ladislav Hagara | Komentářů: 6
    6.12. 15:55 | Komunita

    O víkendu (15:00 až 23:00) probíha EmacsConf 2025, tj. online konference vývojářů a uživatelů editoru GNU Emacs. Sledovat ji lze na stránkách konference. Záznamy budou k dispozici přímo z programu.

    Ladislav Hagara | Komentářů: 1
    6.12. 15:44 | Komunita

    Provozovatel internetové encyklopedie Wikipedia jedná s velkými technologickými firmami o uzavření dohod podobných té, kterou má s Googlem. Snaží se tak zpeněžit rostoucí závislost firem zabývajících se umělou inteligencí (AI) na svém obsahu. Firmy využívají volně dostupná data z Wikipedie k trénování jazykových modelů, což zvyšuje náklady, které musí nezisková organizace provozující Wikipedii sama nést. Automatické programy

    … více »
    Ladislav Hagara | Komentářů: 31
    Jaké řešení používáte k vývoji / práci?
     (34%)
     (48%)
     (19%)
     (17%)
     (22%)
     (15%)
     (24%)
     (16%)
     (18%)
    Celkem 444 hlasů
     Komentářů: 18, poslední 2.12. 18:34
    Rozcestník

    Dotaz: pthread_cancel

    Jardík avatar 8.5.2010 22:40 Jardík | skóre: 40 | blog: jarda_bloguje
    pthread_cancel
    Přečteno: 375×
    Snažím se nastavit handler pro úklid dat ve vláknu, ale nějak se nedaří, GCC mi píše nějaký blbosti.
    template<typename T>
    class CancelableThreadData
    {
    	protected:
    		bool _is_cleanup;
    		T* _data;
    		static void _cleanup_func(void* d);
    	public:
    		template<typename... T_args>
    		CancelableThreadData(T_args... args);
    		
    		~CancelableThreadData();
    		
    		T* operator->() { return _data; }
    		const T* operator->() const { return _data; }
    		
    		T& operator*() { return *_data; }
    		const T& operator*() const { return *_data; }
    };
    
    template<typename T>
    void CancelableThreadData<T>::_cleanup_func(void* d)
    {
    	((CancelableThreadData<T>*)(d))->_is_cleanup = true;
    	((CancelableThreadData<T>*)(d))->~CancelableThreadData();
    }
    
    template<typename T>
    template<typename... T_args>
    CancelableThreadData<T>::CancelableThreadData(T_args... args)
    {
    	_is_cleanup = false;
    	_data = new T(args...);
    	pthread_cleanup_push(_cleanup_func, (void*)_data);
    }
    
    /* Line 272 */template<typename T>
    CancelableThreadData<T>::~CancelableThreadData()
    {
    	if (!_is_cleanup) pthread_cleanup_pop(0);
    	delete _data;
    }
    
    
    Výstup gcc:
    Thread.h: In constructor ‘BurnLib::CancelableThreadData<T>::CancelableThreadData(T_args ...)’:
    Thread.h:272:10: error: expected ‘while’ before ‘<’ token
    Thread.h:272:10: error: expected ‘(’ before ‘<’ token
    Thread.h:272:10: error: expected primary-expression before ‘<’ token
    Thread.h:272:20: error: expected nested-name-specifier before ‘T’
    Thread.h:272:20: error: expected ‘(’ before ‘T’
    Thread.h:272:20: error: expected ‘)’ before ‘T’
    Thread.h:272:20: error: expected ‘;’ before ‘T’
    Thread.h:272:21: error: expected unqualified-id before ‘>’ token
    
    Věřím v jednoho Boha.

    Řešení dotazu:


    Odpovědi

    Jardík avatar 8.5.2010 23:18 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: pthread_cancel
    To voe, voni to jsou makra a ještě tak prasácký! Od kdy? Manuál mi tvrdí, že to jsou funkce a když kouknu do pthread.h, tak tam jsou samý makro-prasárny, až jsem se lekl.
    Věřím v jednoho Boha.
    8.5.2010 23:29 Sinuhet | skóre: 31
    Rozbalit Rozbalit vše Re: pthread_cancel

    Tak ten manual zahodte a poridte si lepsi:

    These functions may be implemented as macros. The application shall ensure that they appear as statements, and in pairs within the same lexical scope (that is, the pthread_cleanup_push() macro may be thought to expand to a token list whose first token is '{' with pthread_cleanup_pop() expanding to a token list whose last token is the corresponding '}' ).
    Jardík avatar 9.5.2010 00:04 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: pthread_cancel
    Akorát nevím, proč jsem se s tím dělal, když jsem teď zjistil, že se mi zavolá destruktor objektu i při přímém zavolání pthread_exit, či při použití pthread_cancel. Jak to? Vždyť se přece nedostanu mimo scope (teda dostanu, ale kompilátor to přece nemůže věďet?).
    Věřím v jednoho Boha.
    Jardík avatar 9.5.2010 00:18 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: pthread_cancel
    Na stránkách HP zase tvrdí, že C++ objekty uklízeny nejsou. Tak babo raď, u mě uklízeny jsou...?
    Věřím v jednoho Boha.
    Bluebear avatar 9.5.2010 00:34 Bluebear | skóre: 30 | blog: Bluebearův samožerblog | Praha
    Rozbalit Rozbalit vše Re: pthread_cancel
    Celou funkčnost POSIXových threadových funkcí zajišťuje libc (jsou to všechno wrappery nad clone(), pár dalšími voláními a signály); teoreticky to může být nějak ošetřené, aby se destruktory zavolaly, ale nespoléhal bych na to. Při představě použití se složitými objekty z C++, kde destruktor může provádět relativně komplikované akce, se mi ježí všechny chlupy; to se může volat ze signal handleru nebo s kdovíjakým kontextem, stačí jedno blbé volání a budeš to ladit až do důchodu.

    Pokud to nutně potřebuješ, nezbývá než se podívat do zdrojáků libc - ale upozorňuji, že tato část libc bude na čtení opravdu *strašná*, protože jsou to wrappery snažící se splňovat POSIXový standard, který je naprosto padlý na hlavu, za pomoci POSIXových signálů, které jsou padlé na hlavu taky, a Linuxových callů, které sice možná nejsou úplně šílené, ale nejsou navrženy pro použití normálním člověkem, nýbrž pouze autory libc. Blicí pytlík povolen a doporučen.
    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...
    Jardík avatar 9.5.2010 00:57 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: pthread_cancel
    Problém zase je, že když na to nebudu spoléhat a použiju ten "obal", co jsem použil výše, tak se mi pak zase destruktor zavolá 2x, tak si hezky vybrat :-). Nakonec pak skončim u assembleru, kde budu alespoň vědět, co se stane :-)
    Věřím v jednoho Boha.
    Bluebear avatar 9.5.2010 01:14 Bluebear | skóre: 30 | blog: Bluebearův samožerblog | Praha
    Rozbalit Rozbalit vše Re: pthread_cancel
    Dynamicky alokované objekty to nesebere, to nesmí; takže v nejhorším tudy vede jakás takás cesta.

    Vzhledem k tomu, že pthread_cleanup_push() vlastně začíná vlastní scope (protože obsahuje otevírací složenou závorku) a pthread_cleanup_pop() ho zase uzavírá, tak je představitelné (ale ne jisté), že pro objekty deklarované uvnitř toho scopu budou skutečně zavolány destruktory. Můžeš to zkusit; pokud to bude fungovat na Linuxu, snad by to mohlo být i přenositelné.

    Zvážil bych ještě možnost vyloučit pthread_cancel() ze hry úplně a udělat komunikaci mezi těmi thready jinak (třeba pomocí signálů, ty se aspoň dají pochopit, nebo pomocí socketů či něčeho takového).
    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...
    Jardík avatar 9.5.2010 13:13 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: pthread_cancel
    Ale ono i když pthread_cleanup_push() nepoužiju a ten objekt je ve scopu té funkce, kde se začíná vykonávat thread, tak po pthread_cancel i pthread_exit se mi ty destruktory zavolají, jakoby tam byl nějaký "zvláštní" mechanismus pro úklid. Něco jsem našel tu:
    Unlike some other implementations of threads, C++ destructors for automatic objects are allowed to run in a well defined and consistent manner when a thread is terminated.

    ....

    When a thread terminates, the following occurs: If the thread was ended using pthread_exit(), pthread_cancel() or return from the thread start routine, then cancellation cleanup handlers and data destructors are run.
    The thread is terminated. At the time that the thread is terminated, both C++ destructors for automatic objects and AS/400 cancel handlers run.
    Věřím v jednoho Boha.
    Jardík avatar 9.5.2010 00:06 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: pthread_cancel
    Jinak našel jsem to tam taky, ale proč mi na začátku tvrdí "these functions" a na konci (kde to nečtu :-)) mi řeknou, že to můžou být makra ...
    Věřím v jednoho Boha.
    Bluebear avatar 9.5.2010 00:37 Bluebear | skóre: 30 | blog: Bluebearův samožerblog | Praha
    Rozbalit Rozbalit vše Re: pthread_cancel
    Možná proto, aby čtenář nezešílel už při prvních řádcích. POSIXové thready je nutné člověku vysvětlovat pomalu a opatrně, jinak hrozí psychická újma.
    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...

    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.