c++ ip地址相关
#include <stdio.h> #include <string.h> #include <arpa/inet.h> #include <sys/types.h> #include <sys/socket.h> #include <pthread.h> #define NUM 20 void *working(void *args) { in_addr* inaddr = (in_addr* )args; //inaddr.s_addr=*(int *)args; for(int i=0; i<100000; i++) { //char buf[16]; //const char* ptr; //ptr = inet_ntop(AF_INET, inaddr, buf, sizeof(buf)); //printf("%s\t%u\n", ptr,(unsigned)pthread_self()); char *ptr = inet_ntoa(*inaddr); printf("%s\t%u\n", ptr,(unsigned)pthread_self()); } return NULL; } int main(int argc,char**argv){ int i; int nip = 16777343; pthread_t child[NUM]; for(i=0; i<NUM; i++) { int ip = nip + i; in_addr inaddr; inaddr.s_addr=ip; //char buf[16]; //const char* ptr; //ptr = inet_ntop(AF_INET, &inaddr, buf, sizeof(buf)); //printf("%s\t%u\n", ptr,(unsigned)pthread_self()); //char buf[20]; //char *ptr = inet_ntoa(inaddr); //printf("%s\t%u\n", ptr,(unsigned)pthread_self()); //pthread_create(&child[i], NULL, working, &ip); pthread_create(&child[i], NULL, working, &inaddr); } for(i=0; i<NUM; i++) { pthread_join(child[i], NULL); } }
inet_ntoa 不是线程安全的。
结论:
传ip 进去, 是无论怎么调用都是同一个ip显示,但却不连续, 135 直接到 137 。
传in_addr进去, 同一个线程内都不能保证同一个ip了。
同一个线程内传入的ip是可以保证这个ip一直不变的。
结论:
传ip 进去, 是无论怎么调用都是同一个ip显示,但却不连续, 135 直接到 137 。
传in_addr进去, 同一个线程内都不能保证同一个ip了。
同一个线程内传入的ip是可以保证这个ip一直不变的。