执行linux c++;windows中的程序 我看到Windows中的一些C++头文件在Linux中有替代。在这里,我在linux-c++中创建了套接字程序和一个字符串处理程序

执行linux c++;windows中的程序 我看到Windows中的一些C++头文件在Linux中有替代。在这里,我在linux-c++中创建了套接字程序和一个字符串处理程序,c++,linux,visual-c++,C++,Linux,Visual C++,是否可以进行修改,使相同的代码在两个windows中都能工作以及在linux中工作 代码1: #include <fcntl.h> #include <string.h> #include <stdlib.h> #include <errno.h> #include <stdio.h> #include <netinet/in.h> #include <resolv.h> #include <sys/soc

是否可以进行修改,使相同的代码在两个windows中都能工作以及在linux中工作

代码1:

#include <fcntl.h>
#include <string.h>
#include <stdlib.h>
#include <errno.h>
#include <stdio.h>
#include <netinet/in.h>
#include <resolv.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <unistd.h>
//#include <sstream.h>
#include <pthread.h>                        
#include <iostream>
#include <sstream>
#include <cstdio>
#include <vector>
#include <map>
#include "dictionary_exclude.h"
#pragma GCC diagnostic ignored "-Wwrite-strings"

void *SocketHandler(void *);

int main(int argv, char **argc)
{
    int host_port = 1103;
    char buf[20];
    int k;
    struct sockaddr_in my_addr;
    int hsock;
    int *p_int;
    int err;
    socklen_t addr_size = 0;
    int *csock;
    sockaddr_in sadr;
    pthread_t thread_id = 0;

    hsock = socket(AF_INET, SOCK_STREAM, 0);
    if (hsock == -1) {
    printf("Error initializing socket %dn", errno);
    goto FINISH;
    }

    p_int = (int *) malloc(sizeof(int));
    *p_int = 1;

    if ((setsockopt(hsock, SOL_SOCKET, SO_REUSEADDR, (char *) p_int, sizeof(int)) == -1) || (setsockopt(hsock, SOL_SOCKET, SO_KEEPALIVE, (char *) p_int, sizeof(int)) == -1)) {
    printf("Error setting options %dn", errno);
    free(p_int);
    goto FINISH;
        }
    free(p_int);

    my_addr.sin_family = AF_INET;
    my_addr.sin_port = htons(host_port);

    memset(&(my_addr.sin_zero), 0, 8);
    my_addr.sin_addr.s_addr = INADDR_ANY;

    if (bind(hsock, (sockaddr *) & my_addr, sizeof(my_addr)) == -1) {
    fprintf(stderr, "Error binding to socket, make sure nothing else is listening on this port %dn", errno);
    goto FINISH;
    }
    if (listen(hsock, 10) == -1) {
    fprintf(stderr, "Error listening %dn", errno);
    goto FINISH;
    }
    //Now lets do the server stuff

    addr_size = sizeof(sockaddr_in);

    while (true) {
    printf("waiting for a connectionn\n");
    csock = (int *) malloc(sizeof(int));
    if ((*csock = accept(hsock, (sockaddr *) & sadr, &addr_size)) != -1) {
        printf("---------------------nReceived connection from %s\n", inet_ntoa(sadr.sin_addr));
        pthread_create(&thread_id, 0, &SocketHandler, (void *) csock); //Pthread to manage requests from multiple clients
        pthread_detach(thread_id);
    } else {
        fprintf(stderr, "Error accepting %dn", errno);
    }
    }

  FINISH:
    ;
}

void *SocketHandler(void *lp)
{
    int ar[10];
    int result=0;
    int *csock = (int *) lp;
    char buf[20];
    int k;

    const unsigned int MAX_BUF_LENGTH = 4096;
    std::vector<char> buffer(MAX_BUF_LENGTH);
    std::string input;   
    int bytesReceived = 0;

    //char buffer[1024];
    int buffer_len = 1024;
    int bytecount;

    int i = 0;
    std::string current;
    std::vector<std::string> sentences;

    if ((bytecount = recv(*csock, (char*) input.c_str(), input.length(), 0)) == -1) { 
    fprintf(stderr, "Error receiving data %d \n", errno);
    goto FINISH;
    }    

                do {
        bytesReceived = recv(*csock, buffer.data(), buffer.size(), 0);
        // append string from buffer.

        if ( bytesReceived == -1 ) 
        { 
            fprintf(stderr, "Error receiving data %d \n", errno);
        goto FINISH;
    } 
    else 
            input.append( buffer.cbegin(), buffer.cend() );         

    } while ( bytesReceived == MAX_BUF_LENGTH );  

    while(i < input.length())
    {
        current += input[i];
        if(input[i] == '"')
        {
            int j = i + 1;
            while( j < input.length() && input[j] != '"')
            {
                current += input[j];
                j ++;
            }
            current += input[j];
            i = j + 1;
        }

        if(input[i] == '.' || input [i] == '!' || input[i] == '?')
        {
            sentences.push_back(current);
            current = "";
        }
        i ++;
    }

    for(i =0; i<sentences.size(); i++)
    {
        std::cout << i << " -> " << sentences[i] << std::endl;
    }



    if ((bytecount = send(*csock, (char *)ar, i *sizeof(int), 0)) == -1) { // Here we cant send lenth-1. It consider exact
    fprintf(stderr, "Error sending data %d\n", errno);
    goto FINISH;
    }

  FINISH:
    free(csock);
    return 0;
}
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
//#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括“dictionary_exclude.h”
#已忽略pragma GCC诊断“-Wwrite字符串”
void*SocketHandler(void*);
int main(int argv,字符**argc)
{
int主机_端口=1103;
char-buf[20];
int k;
我的地址中的结构sockaddr\u;
int hsock;
int*p_int;
INTERR;
socklen\u t addr\u size=0;
int*csock;
萨德尔的索卡德鲁;
pthread\u t thread\u id=0;
hsock=socket(AF_INET,SOCK_STREAM,0);
如果(hsock==-1){
printf(“初始化套接字%dn时出错”,errno);
去完成;
}
p_int=(int*)malloc(sizeof(int));
*p_int=1;
if((setsockopt(hsock,SOL_SOCKET,SO_REUSEADDR,(char*)p_int,sizeof(int))=-1)|(setsockopt(hsock,SOL_SOCKET,SO_KEEPALIVE,(char*)p_int,sizeof(int))=-1)){
printf(“错误设置选项%dn”,errno);
免费(p_int);
去完成;
}
免费(p_int);
我的地址sin家庭=AFINET;
my_addr.sin_port=htons(主机_端口);
memset(&(my_addr.sin_zero),0,8);
my_addr.sin_addr.s_addr=INADDR\u ANY;
if(bind(hsock,(sockaddr*)和my_addr,sizeof(my_addr))=-1){
fprintf(stderr,“绑定到套接字时出错,请确保此端口%dn上没有其他内容正在侦听”,errno);
去完成;
}
如果(监听(hsock,10)=-1){
fprintf(stderr,“侦听%dn时出错”,errno);
去完成;
}
//现在让我们来做服务器的事情
addr_size=sizeof(sockaddr_in);
while(true){
printf(“等待连接n\n”);
csock=(int*)malloc(sizeof(int));
如果(*csock=accept(hsock,(sockaddr*)和sadr,以及addr_size))!=-1){
printf(“--------------从%s\n”接收到的连接,inet_ntoa(sadr.sin_addr));
pthread_create(&thread_id,0,&SocketHandler,(void*)csock);//pthread管理来自多个客户端的请求
pthread_detach(线程id);
}否则{
fprintf(stderr,“接受%dn时出错”,errno);
}
}
完成:
;
}
void*SocketHandler(void*lp)
{
int-ar[10];
int结果=0;
int*csock=(int*)lp;
char-buf[20];
int k;
常量无符号整数最大长度=4096;
标准::向量缓冲区(最大长度);
std::字符串输入;
int字节数=0;
//字符缓冲区[1024];
int buffer_len=1024;
int字节数;
int i=0;
串电流;
向量句;
如果((bytecount=recv(*csock,(char*)input.c_str(),input.length(),0))=-1{
fprintf(stderr,“接收数据%d时出错”,errno);
去完成;
}    
做{
bytesReceived=recv(*csock,buffer.data(),buffer.size(),0);
//从缓冲区追加字符串。
如果(字节接收==-1)
{ 
fprintf(stderr,“接收数据%d时出错”,errno);
去完成;
} 
其他的
input.append(buffer.cbegin(),buffer.cend());
}while(bytesReceived==最大长度);
而(i对于(i=0;i套接字和线程没有Windows和Linux都使用的标准API。虽然它们有些相似,但您必须修改代码才能使其在Windows下工作。

是的,我以前移植过套接字代码。只需使用ifdef获取当前操作系统。如果您想要示例/完整代码,请询问。您也可以这样做使用
Boost
进行跨平台开发。@poljpocket:你的意思是在这两个版本中都可以使用相同的代码吗?如果是,那么我想看看是否相同的代码在两个linux版本中都可以使用。因为套接字库头文件是为linux指定的。我所做的是围绕两个不太不同的实现编写一个包装器套接字类。这样,您的代码在两种平台上看起来都是一样的。因此,相同的套接字代码不能在Windows和linux中使用,对吗?不。Windows套接字API需要一些附加的基本调用(如WSAStartup)。有关概述,请参阅:
#include<stdio.h>
#include<string.h>
#include "client.h"
int main(int argc, char *argv[] )
{
    const char *buffer;
    const char *ch;
    std::string input = argv[1];
    int ar[2];
    printf("Client : \n");
    if ( argc != 2 ) /* argc should be 2 for correct execution */
    {
              printf( "\n%s filename\n", argv[0] );
    }
    else 
    {       

    ch=client(input);
    ar[0]=((int*)ch)[0];
    ar[1]=((int*)ch)[1];

    }

    printf("\n @ar[0]=%d;ar[1]=%d@ \n",ar[0],ar[1]);
    return ar[1];
}
#include <iostream>
#ifndef client_h__
#define client_h__
extern char *client(std::string string_input);

#endif