应用程序没有调用WSAStartup, 或者WSAStartup 失败

本文介绍了一种在Windows环境下使用C++编写Thrift服务时遇到的WSAStartup未调用的问题及解决方案。通过在main函数中初始化Winsock,成功解决了Thrift服务启动时出现的getaddrinfo错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在编写windows c++版本的thrift 代码时,代码完成后,启动服务端,报错:Thrift: getaddrinfo 10093: 应用程序没有调用WSAStartup, 或者WSAStartup 失败。

解决方法:

在server端main函数中添加下面红色字体,即能正常运行

int main(int argc, char **argv) {
  int port = 9090;
 
  TWinsockSingleton::create();

  shared_ptr<ServHandler> handler(new ServHandler());
  shared_ptr<TProcessor> processor(new ServProcessor(handler));
  shared_ptr<TServerTransport> serverTransport(new TServerSocket(port));
  shared_ptr<TTransportFactory> transportFactory(new TBufferedTransportFactory());
  shared_ptr<TProtocolFactory> protocolFactory(new TBinaryProtocolFactory());

  TSimpleServer server(processor, serverTransport, transportFactory, protocolFactory);
  server.serve();
  return 0;
}

 

错误代码 `[WinError 10093]` 是由于在 Windows 平台上,使用 `subprocess.PIPE` 重定向子进程的标准输出时,可能会导致套接字初始化错误。 为了解决这个问题,您可以尝试在创建子进程之前添加 `win32pipe` 模块的导入语句。 以下是一个示例代码,演示如何解决 `[WinError 10093]` 错误: ```python import subprocess import win32pipe # 创建子进程前导入 win32pipe 模块 subprocess.preload_modules = ('win32pipe',) # 创建子进程并执行命令 process = subprocess.Popen(['your_command'], stdout=subprocess.PIPE, stderr=subprocess.PIPE) # 循环读取子进程的输出 while True: # 读取一行输出 line = process.stdout.readline().decode('utf-8') # 如果读取到空行,表示输出已经到达末尾 if not line: break # 处理输出数据 # TODO: 进行你需要的处理 # 检查子进程是否已经结束 if process.poll() is not None: # 子进程已经结束,可以进行后续处理 # TODO: 进行你需要的后续处理 ``` 在上述代码中,我们首先通过 `subprocess.preload_modules` 设置了要预加载的模块为 `'win32pipe'`。然后,我们创建了一个子进程 `process`,并使用 `subprocess.PIPE` 将其标准输出重定向到管道。 接下来的代码与之前的示例相同,循环读取子进程的输出,并进行相应的处理。最后,我们使用 `process.poll()` 来检查子进程是否已经结束。 请根据您的具体需求修改代码中的 `'your_command'` 和处理输出的部分。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值