IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C Discussion :

Poll et socket


Sujet :

C

  1. #1
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 012
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 012
    Points : 23 136
    Points
    23 136
    Par défaut Poll et socket
    Bonjour,

    Je j'ai ce code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
     
    void* ping(void* data)
    {
    	int port = *(int *)data;
        	SOCKET sock;
    	int n = 0;
    	char buffer[2];
       	SOCKADDR_IN sin = { 0 };
        	SOCKET csock;
    	SOCKADDR_IN csin;
    	socklen_t recsize = sizeof(csin);
    	int sock_err;
    	sock = socket(AF_INET, SOCK_DGRAM, 0);
    	if(sock == INVALID_SOCKET)
    	{
        		perror("socket()");
        		return NULL;
    	}
     
    	sin.sin_addr.s_addr = htonl(INADDR_ANY);
     
    	sin.sin_family = AF_INET;
     
    	sin.sin_port = htons(port);
     
    	if(bind (sock, (SOCKADDR *) &sin, sizeof sin) == SOCKET_ERROR)
    	{
        		perror("bind()");
        		return NULL;
    	}
    	struct hostent *hostinfo = NULL;
    	SOCKADDR_IN from = { 0 };
    	int fromsize = sizeof from;
    	while(1){
    	//poll + si fin, arrêter (break)
    	if((n = recvfrom(sock, buffer, sizeof buffer - 1, 0, (SOCKADDR *)&from, &fromsize)) < 0)
    	{
        		perror("recvfrom()");
        		return NULL;
    	}
     
    	buffer[n] = '\0';
     
    	if(sendto(sock, buffer, n, 0, (SOCKADDR *)&from, fromsize) < 0)
    	{
        		perror("sendto()");
        		return NULL;
    	}
    	}
    	closesocket(sock);
    	return NULL;
    }
    Le but est qu'à chaque réception de données, on la renvoie pour montrer que le serveur est en ligne.

    J'aimerais pouvoir arrêter ce thread à partir du père.
    Mais forcer l'arrêt du fils ne me semble pas très propre, de plus, il me semble que recvfrom fait de la scrutation acitive?

    Afin d'économiser des ressources et de fermer correctement le fils, j'aimerais intégrer un poll();

    ce poll() regardera s'il y a des données en entrée et si oui, laisse le recvfrom faire son boulot, sinon, au bout de x microsecondes, il regarde l'état d'une variable pour savoir s'il faut arrêter ou non la boucle.

    Malheureusement, je n'ai pas très bien compris ce qu'il faut mettre dans les deux premiers arguments.

    Pourriez-vous m'aider svp?

  2. #2
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 012
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 012
    Points : 23 136
    Points
    23 136
    Par défaut
    Niveau client :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    	while(1){
    		if(send(sock, buffer, 2, 0) < 0)
    		{
    	    		perror("send()");
    	    		return -1;
    		}
    		printf("y\n");
    		if((n = recv(sock, buffer, sizeof buffer - 1, 0)) < 0)
    		{
    			printf("h\n");
    			perror("recv()");
    			return -1;
    		}
    		printf("z\n");
    		buffer[2] = '\0';
    		printf("%s\n", buffer);
    	}
    Après avoir affiché quelques 1, le code se bloque lors du recv (il rend la main à mon terminal sans arrêter le programme) il n'affiche que yz1yz1 .... 1y.

    Auriez-vous une idée?

    J'ai rien dit. Il est bloquant et attend une réponse qui s'est perdue.
    Il faut donc plutôt que j'utilise un poll qui lui n'est pas bloquant.
    Je reviens donc à mon premier problème.


    EDIT : en fait, il suffit juste d'envoyer un paquet, si ça échoue, on est en offline.
    Côté serveur, il suffit juste d'ouvrir le port et c'est tout.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Long polling VS socket.id
    Par QAYS dans le forum Langage
    Réponses: 1
    Dernier message: 02/07/2015, 03h32
  2. executer une application a distance : Sockets ? RPC ? CORBA?
    Par a_hic dans le forum Développement
    Réponses: 5
    Dernier message: 30/05/2006, 13h02
  3. socket
    Par ben91 dans le forum Développement
    Réponses: 5
    Dernier message: 13/08/2002, 11h04
  4. Socket:Envoyer du texte d'un serveur vers tout les clients
    Par cedm78 dans le forum Web & réseau
    Réponses: 7
    Dernier message: 01/08/2002, 16h40
  5. transfert d'un fichier bitmap en socket tcp
    Par localhost dans le forum C++Builder
    Réponses: 5
    Dernier message: 29/07/2002, 00h40

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo