套接字绑定不会返回 int

socket binding won't return an int

本文关键字:返回 int 绑定 套接字      更新时间:2023-10-16

我的代码片段如下:

int descriptor = socket(AF_INET, SOCK_STREAM, 0);
if(descriptor < 0){
    cerr << "Error establishing socket connection." << endl;
    return -1;
}
int port = 3400;
struct sockaddr_in address;
char buffer[140];
address.sin_family = AF_INET;
address.sin_addr.s_addr = htons(INADDR_ANY);
address.sin_port = htons(port);
int size = sizeof(address);
if(bind(descriptor,(struct sockaddr*)&address,size) < 0){
    cerr << "Error binding socket." << endl;
}
cout << "Waiting for connection on " << INADDR_ANY << " on port " << port << ends;

每当我尝试编译这个,我得到以下错误:

error: invalid operands to binary expression 
('__bind<int &, sockaddr *, int &>' and 'int')
if(bind(descriptor,(struct sockaddr*)&address,size) < 0){

有人知道这是什么意思吗?bind()应该返回一个整数,我是这么想的。我的导入是这样的:

#include <iostream>     
#include <string.h>   
#include <string>       
#include <sys/socket.h> 
#include <sys/types.h> 
#include <netinet/in.h>
#include <arpa/inet.h> 
#include <netdb.h>  
#include <unistd.h>
using namespace std;

谢谢!

using namespace std;加上太多的头包含可能是这里的罪魁祸首-这就是为什么它在SO 而不是上一再重复使用它的原因。通过这样做,编译器看到bind并认为您的意思是<functional>中的std::bind,而不是套接字的::bind。所以要么做正确的事情,如果你真的需要包括所有的头和摆脱使用声明,或使用::bind (编辑:或两者-使用::来表明你想使用一些标准的API函数从全局命名空间)检查