📜  使用C中的套接字编程对数组进行排序(1)

📅  最后修改于: 2023-12-03 14:49:48.095000             🧑  作者: Mango

使用C中的套接字编程对数组进行排序

在本文中,我们将探讨如何使用C中的套接字编程对数组进行排序。我们将使用TCP协议来连接客户端和服务端,并通过套接字编程实现数据传输和排序算法。

套接字编程

套接字编程是在计算机网络数据传输中常用的技术。套接字是一种通信机制,用于在计算机网络之间进行数据传输。在使用套接字编程时,我们需要定义一个套接字类型,这个套接字类型可以是IPV4或IPV6地址。接着,我们需要定义服务器地址和端口号,以便客户端能够连接服务器。最后,我们需要使用套接字来进行数据传输。

排序算法

在计算机科学中,排序算法是一种将一组数据按照特定的顺序排列的算法。排序算法通常用于处理大量数据,以便更好地管理和操纵数据。

在本文中,我们将使用冒泡排序算法。冒泡排序就像名字一样,它是一种排序算法,它将一个数组中的相邻元素依次比较,并在需要时进行交换。这种排序方式的效率相对较低,但它相对简单易懂,通常适用于较小的数据集。

编写代码

我们将编写客户端和服务端程序来实现对数组的排序。以下是完整代码:

/* server.c */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <unistd.h>

#define PORT 8000
#define MAX_SIZE 10

void bubbleSort(int arr[], int n);

int main(int argc, char const *argv[]) {
    int server_fd, new_socket, valread;
    struct sockaddr_in address;
    int addrlen = sizeof(address);
    int arr[MAX_SIZE] = {0};
       
    if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0) {
        perror("socket failed");
        exit(EXIT_FAILURE);
    }
       
    address.sin_family = AF_INET;
    address.sin_addr.s_addr = INADDR_ANY;
    address.sin_port = htons(PORT);
       
    if (bind(server_fd, (struct sockaddr *)&address, sizeof(address)) < 0) {
        perror("bind failed");
        exit(EXIT_FAILURE);
    }
    if (listen(server_fd, 3) < 0) {
        perror("listen");
        exit(EXIT_FAILURE);
    }
    if ((new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t*)&addrlen)) < 0) {
        perror("accept");
        exit(EXIT_FAILURE);
    }

    printf("Connection established.\n");

    valread = read(new_socket, arr, MAX_SIZE * sizeof(int));
    printf("Received array from client.\n");

    bubbleSort(arr, MAX_SIZE);

    send(new_socket, arr, MAX_SIZE * sizeof(int), 0);
    printf("Sorted array sent back to client.\n");

    return 0;
}

void bubbleSort(int arr[], int n) {
    int temp;
    for (int i = 0; i < n-1; i++) {
        for (int j = 0; j < n-i-1; j++) {
            if (arr[j] > arr[j+1]) {
                temp = arr[j];
                arr[j] = arr[j+1];
                arr[j+1] = temp;
            }
        }
    }
}

/* client.c */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <unistd.h>

#define PORT 8000
#define MAX_SIZE 10

void printArray(int arr[], int n);

int main(int argc, char const *argv[]) {
    int sock = 0, valread;
    struct sockaddr_in serv_addr;
    int arr[MAX_SIZE] = {0};
    
    if ((sock = socket(AF_INET, SOCK_STREAM, 0)) < 0) {
        printf("\n Socket creation error \n");
        return -1;
    }
   
    serv_addr.sin_family = AF_INET;
    serv_addr.sin_port = htons(PORT);
       
    if(inet_pton(AF_INET, "127.0.0.1", &serv_addr.sin_addr)<=0) {
        printf("\n Invalid address/ Address not supported \n");
        return -1;
    }
   
    if (connect(sock, (struct sockaddr *)&serv_addr, sizeof(serv_addr)) < 0) {
        printf("\nConnection Failed \n");
        return -1;
    }

    printf("Connection established.\n");

    printf("Enter %d integers to be sorted:\n", MAX_SIZE);
    for (int i = 0; i < MAX_SIZE; i++) {
        scanf("%d", &arr[i]);
    }

    send(sock, arr, MAX_SIZE * sizeof(int), 0);
    printf("Sent array to server.\n");

    valread = read(sock, arr, MAX_SIZE * sizeof(int));
    printf("Received sorted array from server.\n");

    printArray(arr, MAX_SIZE);

    return 0;
}

void printArray(int arr[], int n) {
    printf("Sorted array: ");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
}
运行程序

首先,我们需要在终端中打开两个分别的窗口,其中一个窗口用于运行服务器程序,另一个窗口用于运行客户端程序。在服务器窗口中,输入以下命令编译并运行服务器程序:

gcc server.c -o server
./server

在客户端窗口中,输入以下命令编译并运行客户端程序:

gcc client.c -o client
./client

在输入完整指令后,客户端就会与服务器连接。随后,客户端将提示用户输入要排序的数字,输入后,客户端将把它们发送到服务器进行排序。一旦服务器对数组排序完成后,它将发送已排序的数组回客户端。

结论

在本指南中,我们探讨了如何使用C中的套接字编程对数组进行排序。我们使用了TCP协议来连接客户端和服务端,并通过套接字编程实现数据传输和排序算法。这使得实时数据的传输很方便,同时在服务器端的运算并不会对客户端造成较大的压力。套接字编程在计算机科学中扮演着至关重要的角色,了解和理解套接字编程对于任何想要进行网络编程的人来说都是绝对必要的。