Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
HUAWEI WiFi Mesh X3 Pro Suite è probabilmente il router mesh più fotogenico che si possa acquistare oggi in Italia, ma dietro il guscio in acrilico trasparente e le luci LED dinamiche c'è una macchina tecnica costruita attorno allo standard Wi-Fi 7, con velocità teoriche Dual-Band fino a 3,6 Gbps e una copertura fino a 120 m² una volta abbinato il router principale all'extender incluso nel kit
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte
Abbiamo provato le nuove CPU Intel Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: più core e ottimizzazioni al funzionamento interno migliorano le prestazioni, anche in virtù di prezzi annunciati interessanti. A questo si aggiungono nuove ottimizzazioni software. Purtroppo, a fronte di prestazioni di calcolo elevate, il quadro rimane incerto nel gaming, dove l'andamento rimane altalenante. Infine, rimane il problema della piattaforma a fine vita.
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
Il modello "build to order" di PCSpecialist permette di selezionare una struttura base per un sistema, personalizzandolo in base alle specifiche esigenze con una notevole flessibilità di scelta tra i componenti. Il modello Lafité 14 AI AMD è un classico notebook clamshell compatto e potente, capace di assicurare una elevata autonomia di funzionamento anche lontano dalla presa di corrente
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-04-2002, 19:10   #1
Fabrizio73
Member
 
Iscritto dal: Dec 2001
Città: Bari.
Messaggi: 209
VC++ e MFC: Sono alle prime armi!

Di (V)C++ e MFC so pochissimo, praticamente nulla e vorrei porre rimedio a qs mia lacuna.

Ho tentanto di realizzare un programmino che crea un thread, il quale si limita a visualizzare un parametro passatogli all'atto della creazione.

Codice:
#include <iostream.h>
#include <afxwin.h>


UINT threadBody (LPVOID pParam) {
    int* threadParam = (int*) pParam;
	cout << *threadParam << endl;
	return 0;
}


void main (int argc, char* argv[]) {
    int threadParam = 0;
	CWinThread* thread = AfxBeginThread (threadBody, &threadParam);
}
Tuttavia durante il linking ottengo qs errori:

Quote:
--------------------Configuration: prova - Win32 Debug--------------------
Compiling...
prova.cpp
Linking...
nafxcwd.lib(thrdcore.obj) : error LNK2001: unresolved external symbol __endthreadex
nafxcwd.lib(thrdcore.obj) : error LNK2001: unresolved external symbol __beginthreadex
Debug/prova.exe : fatal error LNK1120: 2 unresolved externals
Error executing link.exe.

prova.exe - 3 error(s), 0 warning(s)
Dov'è il problema?

JAVA dove sei ?
__________________
Se il giudice fosse giusto, forse il criminale non sarebbe colpevole - Dostoevskij
Fabrizio73 è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2002, 19:53   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Hai linkato il file senza MFC... Project -> Settings -> General e nel menù a tendina seleziona MFC come shared DLL...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2002, 20:11   #3
Fabrizio73
Member
 
Iscritto dal: Dec 2001
Città: Bari.
Messaggi: 209
Thanks ... però il programma non funziona, infatti dovrebbe visualizzare il contenuto di threadParam, ossia 0 ma non visualizza nulla... che altro ho combinato?
__________________
Se il giudice fosse giusto, forse il criminale non sarebbe colpevole - Dostoevskij
Fabrizio73 è offline   Rispondi citando il messaggio o parte di esso
Old 28-04-2002, 01:53   #4
-=Krynn=-
Senior Member
 
L'Avatar di -=Krynn=-
 
Iscritto dal: Dec 2001
Città: Firenze - Nosgoth
Messaggi: 7333
uh, anche io mi sto scontrando contro quel muro che è la MFC.....
se riesci a risolvere il tuo problema dimelo magari in pvt
__________________
Xbox GamerTag: Falux || Psn: Falux79 || -=Krynn=-
-=Krynn=- è offline   Rispondi citando il messaggio o parte di esso
Old 28-04-2002, 13:02   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da Fabrizio73
[b]Thanks ... però il programma non funziona, infatti dovrebbe visualizzare il contenuto di threadParam, ossia 0 ma non visualizza nulla... che altro ho combinato?
Il problema sta nel fatto che il thread che lanci finisce dopo il main...quindi la variabile threadParam non risulta più inizializzata...

Quindi le soluzioni possono essere diverse...

Ad esempio metti una Sleep in fondo al main...oppure la soluzione corretta è usare la WaitForSingleObject...

Il problema è che non so come recuperare l'HANDLE dal CWinThread...ho usato la WaitForSingleObject per molte cose, ma non per i thread...

Una soluzione potrebbe essere creare il thread con
HANDLE CreateThread(
LPSECURITY_ATTRIBUTES lpThreadAttributes, // pointer to security attributes
DWORD dwStackSize, // initial thread stack size
LPTHREAD_START_ROUTINE lpStartAddress, // pointer to thread function
LPVOID lpParameter, // argument for new thread
DWORD dwCreationFlags, // creation flags
LPDWORD lpThreadId // pointer to receive thread ID
);

che come vedi ritorna l'HANDLE da poter usare con la WaitForSingleObject...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 28-04-2002, 14:40   #6
Fabrizio73
Member
 
Iscritto dal: Dec 2001
Città: Bari.
Messaggi: 209
Che SVISTA... hai ragione il main thread termina prima!!!

Ho risolto così:

Codice:
#include <iostream.h>
#include <afxwin.h>


UINT threadBody (LPVOID pParam) {
    int* threadParam = (int*) pParam;
    cout << *threadParam << endl;
    return 0;
}


void main (int argc, char* argv[]) {
    int threadParam = 0;
    CWinThread* thread = AfxBeginThread (threadBody, &threadParam);
    [B]HANDLE threadHandle = (*thread).m_hThread;
    ::WaitForSingleObject (threadHandle, INFINITE);[/B]
}
Grazie 1000

Cionci for Moderator
__________________
Se il giudice fosse giusto, forse il criminale non sarebbe colpevole - Dostoevskij
Fabrizio73 è offline   Rispondi citando il messaggio o parte di esso
Old 28-04-2002, 15:01   #7
Fabrizio73
Member
 
Iscritto dal: Dec 2001
Città: Bari.
Messaggi: 209
Mi sta venendo un dubbio... se il thread creato invece, terminasse prima che il main thread riuscisse a recuperare l'handle... che accadrebbe?

Forse sarebbe il caso di creare il thread in modalità suspended, recuperare l'handle (o duplicare l'handle?) e quindi effettuare il resume!

E' giusto?
__________________
Se il giudice fosse giusto, forse il criminale non sarebbe colpevole - Dostoevskij
Fabrizio73 è offline   Rispondi citando il messaggio o parte di esso
Old 28-04-2002, 15:10   #8
Fabrizio73
Member
 
Iscritto dal: Dec 2001
Città: Bari.
Messaggi: 209
Codice:
#include <iostream.h>
#include <afxwin.h>


UINT threadBody (LPVOID pParam) {
    int* threadParam = (int*) pParam;
    cout << *threadParam << endl;
    return 0;
}


void main (int argc, char* argv[]) {
    int threadParam = 0;
    CWinThread* thread = AfxBeginThread (threadBody, &threadParam,
                                         THREAD_PRIORITY_NORMAL, 0, CREATE_SUSPENDED);
    HANDLE threadHandle;
    ::DuplicateHandle (GetCurrentProcess (), (*thread).m_hThread,
                       GetCurrentProcess (), &threadHandle, 0, FALSE, DUPLICATE_SAME_ACCESS);
    (*thread).ResumeThread ();
    ::WaitForSingleObject (threadHandle, INFINITE);
    ::CloseHandle (threadHandle);
}
Possibile che si debba fare tutto questo casino?
Java diventa sempre più il mio preferito...
__________________
Se il giudice fosse giusto, forse il criminale non sarebbe colpevole - Dostoevskij
Fabrizio73 è offline   Rispondi citando il messaggio o parte di esso
Old 28-04-2002, 15:43   #9
Fabrizio73
Member
 
Iscritto dal: Dec 2001
Città: Bari.
Messaggi: 209
Ho trovato una soluzione più bella : impedire alla MFC di distruggere l'oggetto CWinThread quando esso termina, in questo modo si può recuperare l'handle a patto di distruggere "manualmente" l'oggetto...

Codice:
#include <iostream.h>
#include <afxwin.h>


UINT threadBody (LPVOID pParam) {
    int* threadParam = (int*) pParam;
    cout << *threadParam << endl;
    return 0;
}


void main (int argc, char* argv[]) {
    int threadParam = 0;
    CWinThread* thread = AfxBeginThread (threadBody, &threadParam,
                                         THREAD_PRIORITY_NORMAL, 0, CREATE_SUSPENDED);
    (*thread).m_bAutoDelete = FALSE;
    HANDLE threadHandle = (*thread).m_hThread;
    (*thread).ResumeThread ();
    ::WaitForSingleObject (threadHandle, INFINITE);
    delete thread;
}
__________________
Se il giudice fosse giusto, forse il criminale non sarebbe colpevole - Dostoevskij
Fabrizio73 è offline   Rispondi citando il messaggio o parte di esso
Old 28-04-2002, 17:19   #10
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Vabbè...niente male...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 28-04-2002, 17:25   #11
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da Fabrizio73
[b]Mi sta venendo un dubbio... se il thread creato invece, terminasse prima che il main thread riuscisse a recuperare l'handle... che accadrebbe?
Ma sinceramente credo che se fa un WaitForSingleObject su un HANDLE non più valido esca subito...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2002, 18:09   #12
Fabrizio73
Member
 
Iscritto dal: Dec 2001
Città: Bari.
Messaggi: 209
Scusatemi se vi annoio ancora ... ma ho un altro problemino .

Ho realizzato qs classe:

Codice:
class Client
{
	private:
		double interArrivalMeanTime;
		Queue* queue;
		BOOL isInterrupted;
		CWinThread* thread;
		UINT threadBody (LPVOID pParam);
	public:
		Client (double interArrivalMeanTime, Queue* queue);
		~Client ();
		void start ();
		void interrupt ();
};


UINT Client::threadBody (LPVOID pParam)
{
	// Corpo del thread...
	return 0;
}


Client::Client (double interArrivalMeanTime, Queue* queue)
{
	(*this).interArrivalMeanTime = interArrivalMeanTime;
	(*this).queue = queue;
	isInterrupted = FALSE;
	[COLOR=RED]thread = AfxBeginThread (threadBody, NULL, THREAD_PRIORITY_NORMAL, 0, CREATE_SUSPENDED);[/COLOR]
	(*thread).m_bAutoDelete = FALSE;
}


Client::~Client ()
{
	delete thread;
}


void Client::start ()
{
	(*thread).ResumeThread ();
}


void Client::interrupt ()
{
	isInterrupted = TRUE;
}
All'atto della compilazione, viene segnalato il seguente errore sulla linea di codice in rosso:

Quote:
error C2665: 'AfxBeginThread' : none of the 2 overloads can convert parameter 1 from type 'unsigned int (void *)'
Se invece definisco la classe Client in qs modo, ossia faccio in modo che la funzione threadBody sia globale...

Codice:
class Client
{
	private:
		double interArrivalMeanTime;
		Queue* queue;
		BOOL isInterrupted;
		CWinThread* thread;
	public:
		Client (double interArrivalMeanTime, Queue* queue);
		~Client ();
		void start ();
		void interrupt ();
};


[COLOR=BLUE]UINT threadBody (LPVOID pParam)
{
	// Corpo del thread...
	return 0;
}[/COLOR]


Client::Client (double interArrivalMeanTime, Queue* queue)
{
	(*this).interArrivalMeanTime = interArrivalMeanTime;
	(*this).queue = queue;
	isInterrupted = FALSE;
	thread = AfxBeginThread (threadBody, NULL, THREAD_PRIORITY_NORMAL, 0, CREATE_SUSPENDED);
	(*thread).m_bAutoDelete = FALSE;
}


Client::~Client ()
{
	delete thread;
}


void Client::start ()
{
	(*thread).ResumeThread ();
}


void Client::interrupt ()
{
	isInterrupted = TRUE;
}
...non viene segnalato alcun errore di compilazione!

Cosa non va ?
__________________
Se il giudice fosse giusto, forse il criminale non sarebbe colpevole - Dostoevskij
Fabrizio73 è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2002, 19:07   #13
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Prova a definire la funzione threadBody come static UINT ThreadBody(LPVOID pParam)...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2002, 19:19   #14
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Guarda un po'...questa sembra funzionare bene...
Codice:
#include <iostream.h>
#include <afxwin.h>


typedef char Queue;

class Client
{
	private:
		double interArrivalMeanTime;
		Queue* queue;
		BOOL isInterrupted;
		CWinThread* thread;
		static UINT threadBody2 (LPVOID pParam);
	public:
		Client (double interArrivalMeanTime, Queue* queue);
		~Client ();
		void start ();
		void interrupt ();
};


UINT Client::threadBody2 (LPVOID pParam)
{
	// Corpo del thread...

	cout << ((Client*)pParam)->interArrivalMeanTime << endl;
	return 0;
}


Client::Client (double interArrivalMeanTime, Queue* queue)
{
	(*this).interArrivalMeanTime = interArrivalMeanTime;
	(*this).queue = queue;
	isInterrupted = FALSE;
	thread = AfxBeginThread (threadBody2, this, THREAD_PRIORITY_NORMAL, 0, CREATE_SUSPENDED);
	(*thread).m_bAutoDelete = FALSE;
}


Client::~Client ()
{
	delete thread;
}


void Client::start ()
{
	(*thread).ResumeThread ();
}


void Client::interrupt ()
{
	isInterrupted = TRUE;
}

UINT threadBody (LPVOID pParam) {
    int* threadParam = (int*) pParam;
	cout << *threadParam << endl;
	return 0;
}


void main (int argc, char* argv[]) {
    int threadParam = 0;

	Client *thread[5];

	for(int i=0; i<5; ++i)
	{
		thread[i] = new Client((double)i,0);
		thread[i]->start();
	}
	Sleep(300);
}
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2002, 19:36   #15
Fabrizio73
Member
 
Iscritto dal: Dec 2001
Città: Bari.
Messaggi: 209
Bhé... che dire... sei un genio ... ma xché è necessario dichiarare la funzione di controllo del thread static?
__________________
Se il giudice fosse giusto, forse il criminale non sarebbe colpevole - Dostoevskij
Fabrizio73 è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2002, 19:46   #16
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Forse perchè gli indirizzi delle funzioni vengono tradotti al tempo della compilazione quindi non essendo static (cioè c'è una sola istanza di quella funzione valida per tutte le classi) non può determinare a priori a quale istanza della classe ti riferisci...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2002, 19:52   #17
Fabrizio73
Member
 
Iscritto dal: Dec 2001
Città: Bari.
Messaggi: 209
Non fa una grinza !!!

Ascolta un po'... in Java esistono due comodissime funzioni, molto utili in problemi del tipo produttore/consumatore. Mi riferisco alle funzioni wait () e notify () (esiste anche notifyAll ()). Esiste qualcosa di simile in VC++/MFC?
__________________
Se il giudice fosse giusto, forse il criminale non sarebbe colpevole - Dostoevskij
Fabrizio73 è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2002, 20:05   #18
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Spiegami un po' il significato...anche se un po' mi sembra di capirlo...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2002, 20:22   #19
Fabrizio73
Member
 
Iscritto dal: Dec 2001
Città: Bari.
Messaggi: 209
Ti faccio un esempio. Supponiamo di voler simulare un sistema client/server assegnando ad un thread il compito del client e ad un altro il compito del server. Il client formula le richieste inserendole in una coda (queue). Il server non fa altro che estrarre le richieste dalla coda ed eseguirle.

Per evitare che il server esegua un'attesa attiva sulla coda (ossia controlli continuamente se vi sono richieste), esso può invocare il metodo wait dell'oggetto queue e si addormenta:

Codice:
synchronized (queue) {
    if (queue.isEmpty ()) {
        queue.wait ();
    }
    request = (Request)queue.get ();
}
Quando il client inserisce una richiesta nella coda, provvede a risvegliere il thread server invocando il metodo notify dell'oggetto queue:

Codice:
synchronized (queue) {
    queue.put (request);
    queue.notify ();
}
C'è da dire che in Java ogni classe possiede di default alcuni metodi fra i quali ci sono wait e notify, per cui non è necessario definire qs funzioni quando si definisce la classe.

Inoltre un thread per poter invocare la wait di un oggetto, deve possedere il lock su tale oggetto (synchronized). Quando la wait viene invocata il lock sull'oggetto viene automaticamente rilasciato per evitare deadlock.

Carino... no?

Tutto questo è possibile in VC++/MFC?
__________________
Se il giudice fosse giusto, forse il criminale non sarebbe colpevole - Dostoevskij
Fabrizio73 è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2002, 20:32   #20
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
In pratica che nei sistemi oeprativi si chiama semaforo ?!?!?

CMultiLock does not have a base class.

An object of class CMultiLock represents the access-control mechanism used in controlling access to resources in a multithreaded program. To use the synchronization classes CSemaphore, CMutex, and CEvent, you can create either a CMultiLock or CSingleLock object to wait on and release the synchronization object. Use CMultiLock when there are multiple objects that you could use at a particular time. Use CSingleLock when you only need to wait on one object at a time.

To use a CMultiLock object, first create an array of the synchronization objects that you wish to wait on. Next, call the CMultiLock object’s constructor inside a member function in the controlled resource’s class. Then call the Lock member function to determine if a resource is available (signaled). If one is, continue with the remainder of the member function. If no resource is available, either wait for a specified amount of time for a resource to be released, or return failure. After use of a resource is complete, either call the Unlock function if the CMultiLock object is to be used again, or allow the CMultiLock object to be destroyed.

CMultiLock objects are most useful when a thread has a large number of CEvent objects it can respond to. Create an array containing all the CEvent pointers, and call Lock. This will cause the thread to wait until one of the events is signaled.

For more information on how to use CMultiLock objects, see the articleMultithreading: How to Use the Synchronization Classes in Visual C++ Programmer’s Guide.
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte Core Ultra 7 270K Plus e Core Ultra 7 250K Plus:...
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Google risolve il problema della memoria...
Un altro colpo alle auto elettriche: Pan...
Core Ultra 9 290K Plus: Intel conferma c...
Addio connettori fusi? MSI promette di f...
Basta brani fake su Spotify: la nuova fu...
OPPO Find X9 Ultra: come funziona il riv...
Prezzo diverso per giochi digitali e fis...
DDR5 32GB a meno di 340€: le Corsair Ven...
Harry Potter: HBO pubblica il primo trai...
Android 17 Beta 2 si allarga: la lista c...
RDNA 4m: AMD evolve RDNA 3.5 con AI e FS...
Sunseeker ha un mostro per i Pro e un'in...
Storica sentenza negli USA: Meta e Googl...
Musica generativa, arriva Lyria 3 Pro: o...
Melania Trump scortata da un robot umano...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 13:49.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v