c語言編程-標準步驟(改進版)
server.c
複製代碼 代碼如下:
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define PORT 4444
#define BACKLOG 5
#define MAX_FD 256
void setnonblocking(int);
int main(int argc, char *argv[]) {
int sock_fd, new_fd, new_fd2, epfd, nfds;
struct sockaddr_in server_addr, client_addr;
int sin_size;
int nbytes;
int on = 1;
char buffer[1024];
struct epoll_event ev, events[20];
epfd = epoll_create(MAX_FD);
if ((sock_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {
perror("socket");
exit(1);
}
setsockopt(sock_fd, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on));
setnonblocking(sock_fd);
= sock_fd;
ts = EPOLLIN | EPOLLET;
epoll_ctl(epfd, EPOLL_CTL_ADD, sock_fd, &ev);
memset(&server_addr, 0, sizeof(struct sockaddr_in));
server__family = AF_INET;
server__addr.s_addr = htonl(INADDR_ANY);
server__port = htons(PORT);
if (bind(sock_fd, (struct sockaddr *)(&server_addr), sizeof(struct sockaddr)) == -1) {
perror("bind");
exit(1);
}
if (listen(sock_fd, BACKLOG) == -1) {
perror("listen");
exit(1);
}
printf("Server start... n");
sin_size = sizeof(struct sockaddr_in);
int i;
while (1) {
nfds = epoll_wait(epfd, events, 20, 500);
for (i = 0; i < nfds; i++) {
if (events[i] == sock_fd) {
if ((new_fd = accept(sock_fd, (struct sockaddr *)(&client_addr), &sin_size)) == -1) {
perror("accept");
exit(1);
}
printf("Server get connection from %sn", inet_ntoa(client__addr));
setnonblocking(new_fd);
= new_fd;
ts = EPOLLIN | EPOLLET;
epoll_ctl(epfd, EPOLL_CTL_ADD, new_fd, &ev);
} else if (events[i]ts & EPOLLIN) {
if ((new_fd2 = events[i]) < 0) continue;
if ((nbytes = read(new_fd2, buffer, 1024)) == -1) {
perror("read");
exit(1);
} else if (nbytes == 0) {
close(new_fd2);
events[i] = -1;
}
printf("Server read from %sn", inet_ntoa(client__addr));
= new_fd2;
ts = EPOLLOUT | EPOLLET;
epoll_ctl(epfd, EPOLL_CTL_MOD, new_fd2, &ev);
} else if (events[i]ts & EPOLLOUT) {
new_fd2 = events[i];
write(new_fd2, "Server Received", 16);
= new_fd2;
ts = EPOLLIN | EPOLLET;
epoll_ctl(epfd, EPOLL_CTL_MOD, new_fd2, &ev);
}
}
}
return 0;
}
void setnonblocking(int fd) {
int opts;
if ((opts = fcntl(fd, F_GETFL)) < 0) {
perror("fcntl(fd, F_GETFL");
exit(1);
}
opts = opts | O_NONBLOCK;
if (fcntl(fd, F_SETFL, opts) < 0) {
perror("fcntl(fd, F_SETFL, opts");
exit(1);
}
}
client.c
複製代碼 代碼如下:
#include
#include
#include
#include
#include
#include
#include
#define PORT 4444
int main(int argc, char *argv[]) {
int sock_fd;
struct sockaddr_in server_addr;
struct hostent *host;
char buffer[1024];
if (argc < 2) {
perror("Need hostname");
exit(1);
}
if ((host = gethostbyname(argv[1])) == NULL) {
perror("gethostbyname");
exit(1);
}
if ((sock_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {
perror("socket");
exit(1);
}
memset(&server_addr, 0, sizeof(struct sockaddr_in));
server__family = AF_INET;
server__port = htons(PORT);
server__addr = *((struct in_addr *)host->h_addr);
if (connect(sock_fd, (struct sockaddr *)(&server_addr), sizeof(struct sockaddr)) == -1) {
perror("connect");
exit(1);
}
while (1) {
printf("Please input something:n");
fgets(buffer, 1024, stdin);
write(sock_fd, buffer, strlen(buffer));
read(sock_fd, buffer, 1024);
printf("From server: %sn", buffer);
}
close(sock_fd);
return 0;
}
-
C語言合併排序及實例代碼
歸併排序也稱合併排序,其算法思想是將待排序序列分為兩部分,依次對分得的兩個部分再次使用歸併排序,之後再對其進行合併。下面是小編分享的C語言合併排序及實例代碼,一起來看一下吧。合併排序僅從算法思想上了解歸併排序會覺得很抽象,接下來就以對序列A[0],A[l]…,A...
-
C語言學習攻略
導語:C語言作為最流行的程序設計語言,是任何一個計算機專業及其愛好者們都必須掌握的一門編程語言。下面就由小編為大家介紹一下C語言學習攻略,歡迎大家閲讀!一、C語言學習中存在的問題(一)基礎薄弱,無法適應C語言學習的課程通常安排在大一,這個時候,學生們剛剛進入...
-
C語言指針的長度和類型講解
對於初學者深入理解C語言程序設計有很好的參考價值,下面是小編為大家整理的C語言指針的長度和類型講解,歡迎參考~一般來説,如果考慮應用程序的兼容性和可移植性,指針的長度就是一個問題,在大部分現代平台上,數據指針的長度通常是一樣的,與指針類型無關,儘管C標準沒有規...
-
如何使用C語言求N的階乘
使用C語言求N的階乘的方法是很多小夥伴都想知道的,下面小編給大家介紹如何使用C語言求N的階乘,歡迎閲讀!如何使用C語言求N的階乘用遞歸法求N的.階乘程序調用自身稱為遞歸(recursion).它通常把一個大型複雜的問題層層轉化為一個與原問題相似的規模較小的問題來求...