Linux网络编程(3)——多进程、多线程
在我的里面已经介绍了linux以下c的进程、线程接口,这里就不做过多阐述了。
多进程
这里多进程採用传统的多进程模型。每当有client发来的连接时创建一个进程来处理连接,一个子进程相应一个连接。
有了上篇单一进程的基础,此处仅仅做简单的改动便能够实现。
while(1){
clientfd = Accept(servfd, (struct sockaddr*)&cliaddr, &clientlen);
host = Gethostbyaddr((const char*)&cliaddr.sin_addr.s_addr, sizeof(cliaddr.sin_addr.s_addr), AF_INET);
printf("server connect to host: %s %s\n",host->h_name, inet_ntoa(cliaddr.sin_addr));
if ((child_pid = Fork()) == 0){
Close(servfd);
echo(clientfd);
Close(clientfd);
}
Close(clientfd);
}
仅仅须要在while里面加入进程的创建就可以,然后在子进程里先关闭父进程的监听套接字。
当然。不要忘了在上面加入Fork错误处理的包裹函数(在Fork一节中已讲到)。
void error_msg(char *msg){
perror(msg);
exit(0);
}
int Fork(){
pid_t pid;
if ( ( pid = fork() ) < 0 )
error_msg("fork failed");
return pid;
}
执行结果:
client:
server:
多线程
线程和进程在非常多方面是相通的,仿照上面的多进程的传统模型。不难实现多线程的传统模型。
依旧是在while里面做简单的改动就可以。
clientfd = (int*)malloc(sizeof(int));
*clientfd = Accept(servfd, (struct sockaddr*)&cliaddr, &clientlen);
host = Gethostbyaddr((const char*)&cliaddr.sin_addr.s_addr, sizeof(cliaddr.sin_addr.s_addr), AF_INET);
printf("server connect to host: %s %s\n",host->h_name, inet_ntoa(cliaddr.sin_addr));
Pthread_create(&tid, NULL, &thread, clientfd);
Close(*clientfd);
使用malloc是为了避免因为多线程訪问了同样的clientfd从而出现无法预估的后果,全部手动分配。
线程函数为
void *thread(void* arg){
int clientfd = *((int*)arg);
free(arg);
Pthread_detach(pthread_self());
echo(clientfd);
close(clientfd);
return NULL;
}
执行结果:
这段代码有个问题,clientfd传入线程之后。arg指针没有接收到值,指在了一个无法訪问的地方(gdb显示值为0x00),百思不得其解。
(原理非常easy,遇到的问题先记录下,假设有人知道错在哪里希望能指正出来。。
。
环境 ubuntu 64位,编译器gcc)
Linux网络编程(3)——多进程、多线程的更多相关文章
- linux网络编程echo多进程服务器
echo_server 多进程版本 #include <unistd.h> #include <stdlib.h> #include <stdio.h> #incl ...
- day31 网络编程,多进程多线程
今天的内容需要好好整理,概念性的东西比较多,都是需要理解的,这些是基层的理解,后期的很多知识都是要建立在今天的概念基础上的,以下两点是核心内容,必须要理解,自己把自己理解的注释加在里面: 进程就是程序 ...
- Linux网络编程入门 (转载)
(一)Linux网络编程--网络知识介绍 Linux网络编程--网络知识介绍客户端和服务端 网络程序和普通的程序有一个最大的区别是网络程序是由两个部分组成的--客户端和服务器端. 客户 ...
- [转] - Linux网络编程 -- 网络知识介绍
(一)Linux网络编程--网络知识介绍 Linux网络编程--网络知识介绍客户端和服务端 网络程序和普通的程序有一个最大的区别是网络程序是由两个部分组成的--客户端和服务器端. 客户 ...
- 《转》Linux网络编程入门
原地址:http://www.cnblogs.com/duzouzhe/archive/2009/06/19/1506699.html (一)Linux网络编程--网络知识介绍 Linux网络编程-- ...
- 很全的linux网络编程技巧
本文转载自:http://www.cnblogs.com/jfyl1573/p/6476607.html 1. LINUX网络编程基础知识 1 1.1. TCP/IP协议概述 1 1.2. OSI参考 ...
- Linux网络编程学习路线
转载自:https://blog.csdn.net/lianghe_work/article 一.网络应用层编程 1.Linux网络编程01——网络协议入门 2.Linux网络编程02——无连接和 ...
- Linux网络编程入门
(一)Linux网络编程--网络知识介绍 Linux网络编程--网络知识介绍客户端和服务端 网络程序和普通的程序有一个最大的区别是网络程序是由两个部分组成的--客户端和服务器端. 客户 ...
- 【linux草鞋应用编程系列】_5_ Linux网络编程
一.网络通信简介 第一部分内容,暂时没法描述,内容实在太多,待后续专门的系列文章. 二.linux网络通信 在linux中继承了Unix下“一切皆文件”的思想, 在linux中要实现网 ...
- 【转】Linux网络编程入门
(一)Linux网络编程--网络知识介绍 Linux网络编程--网络知识介绍客户端和服务端 网络程序和普通的程序有一个最大的区别是网络程序是由两个部分组成的--客户端和服务器端. 客户 ...
随机推荐
- HDU 1171 Big Event in HDU(多重背包)
Big Event in HDU Problem Description Nowadays, we all know that Computer College is the biggest depa ...
- 连载:面向对象葵花宝典:思想、技巧与实践(30) - SRP原则
前面具体阐述了"高内聚低耦合"的整体设计原则.但怎样让设计满足这个原则,并非一件简单的事情.幸好各位前辈和大牛已经帮我们归纳总结出来了,这就是"设计原则"和&q ...
- C# 用ManulResetEvent 控制Thread的 Suspend、Resume
class Program { static void Main(string[] args) { Thread thread = new Thread(Work); thread.Start(); ...
- (转)c++ typedef 函数指针详细说明
转自:http://blog.csdn.net/future200x/article/details/5350134 一个函数在编译时被分配一个入口地址,将这个入口地址称为函数的指针,可以用一个指针变 ...
- 用户命令切换-命令su
命令su格式为su [-] username su su - su test su root
- 淘宝druid报错:javax.management.InstanceNotFoundException: com.alibaba.druid:type=DruidDataSourceStat
问题: 启动tomcat报错: Tomat报出一下异常:ERROR [com.alibaba.druid.stat.DruidDataSourceStatManager] – unregister m ...
- SQL学习——基础语句(3)
先上数据表 student表 grade 表 SQL Union 语句 合并两个或多个select查询结果集. select s_id from student union select s_id ...
- intell-
intellect: n.[U, C] the ability to think in a logical way and understand things, especially at an ad ...
- bootstrap-导航条
默认样式的导航条 导航条是在您的应用或网站中作为导航页头的响应式基础组件.它们在移动设备上可以折叠(并且可开可关),且在视口(viewport)宽度增加时逐渐变为水平展开模式. 两端对齐的导航条导航链 ...
- Python安装遇到的问题
1.import MySQLdb 错误 导入MySQLdb模块时报错: >>> import MySQLdb Traceback (most recent call last): ...