一.文件重定向     我们知道在linux shell 编程的时候,可以使用文件重定向功能,如下所示: [root@localhost pipe]# echo "hello world" hello world //没有进行重定向,在终端显示 [root@localhost pipe]# echo "hello world" > txt //进行重定向,不在终端显示 [root@localhost pipe]# cat txt //查看生成的文件 txt 的…
重定向和VT100编程 一.文件重定向     我们知道在linux shell 编程的时候,可以使用文件重定向功能,如下所示: [root@localhost pipe]# echo "hello world" hello world //没有进行重定向,在终端显示 [root@localhost pipe]# echo "hello world" > txt //进行重定向,不在终端显示 [root@localhost pipe]# cat txt //查…
引言: 前面的介绍专题中有朋友向我留言说介绍下关于P2P相关的内容的,首先本人对于C#网络编程也不是什么大牛,因为能力的关系,也只能把自己的一些学习过程和自己的一些学习过程中的理解和大家分享下的,下面就进入正题——P2P(Peer to Peer)编程 一.P2P的介绍 首先,现在大家熟知的BT.电驴.迅雷.QQ.MSN和PPlive等都是基于P2P方式实现的软件,并且对等联网(Peer to Peer,P2P)将是互联网的发展方向,因此对于P2P技术的了解显得非常的重要,下面就来介绍下P2P架…
转自:http://www.cnblogs.com/zhili/archive/2012/09/03/2666974.html 上次因为时间的关系,所以把上一个专题遗留下的一个问题在本专题中和大家分享下,本专题主要介绍下如何实现UDP广播的程序,下面就直接介绍实现过程和代码以及运行的结果. 一.程序实现 UDP广播程序的实现代码: using System; using System.Net; using System.Net.Sockets; using System.Text; using…
转自:http://www.cnblogs.com/zhili/archive/2012/09/01/2659167.html 引用: 前一个专题简单介绍了TCP编程的一些知识,UDP与TCP地位相当的另一个传输层协议,它也是当下流行的很多主流网络应用(例如QQ.MSN和Skype等一些即时通信软件传输层都是应用UDP协议的)底层的传输基础,所以在本专题中就简单介绍下UDP的工作原理和UDP编程的只是,希望可以对刚接触网络编程的朋友起到入门的作用. 一.UDP介绍 UDP和TCP都是构建在IP层…
转自:http://www.cnblogs.com/zhili/archive/2012/08/25/2656840.html 前言 前面专题的例子都是基于应用层上的HTTP协议的介绍, 现在本专题来介绍下传输层协议——TCP协议,主要介绍下TCP协议的工作过程和基于TCP协议的一个简单的通信程序,下面就开始本专题的正文了. 一.TCP的工作过程 首先TCP是一种面向连接的,可靠的,基于字节流的传输层通信协议.TCP的工作过程可以分为三个阶段:一.连接的建立:  二.传输数据: 三.断开连接,下…
最近学习linux系统下的应用编程,参考书籍是那本称为神书的<Unix环境高级编程>,个人感觉神书不是写给草鞋看的,而是 写给大神看的,如果没有一定的基础那么看这本书可能会感到有些头重脚轻的感觉.我自己就是这样,比方说看进程间通信信号量章 节的时候,开始感觉就很迷糊,因此也就想在这里写一些文字,给和我一样的草鞋分享一些自己的学习经历(算不上经验吧). 环境:   windows7,  VMware  9.0 操作系统版本: RHEL  5.5   内核版本:  2.6.18-194.el5 G…
一.网络通信简介   第一部分内容,暂时没法描述,内容实在太多,待后续专门的系列文章.   二.linux网络通信     在linux中继承了Unix下“一切皆文件”的思想, 在linux中要实现网络通信需要创建相关的网络文件:linux中 用相关的系统调用创建相关的网络文件.   1.网络服务器实现(基于TCP/IP)     要实现一个网络服务器,则按照以下步骤完成 (1)创建网络套接字文件     socket( )系统调用用来创建网络套接字.其原型如下: NAME socket - c…
一.应用程序多线程     当一个计算机上具有多个CPU核心的时候,每个CPU核心都可以执行代码,此时如果使用单线程,那么这个线程只能在一个 CPU上运行,那么其他的CPU核心就处于空闲状态,浪费了系统资源:引入多线程可以解决这个问题,可以充分利用系统CPU 的资源:  例如可以:线程2在CPU核心0上运行.线程2在CPU核心2上运行.     又或者,当应用程序需要做一件查找很费时的操作,如果使用单线程,那么应用程序在处理这个“费时操作”的时候,就不能 进行其他的操作,使用户等待操作处理过程,…
一.进程间通信        linux下面提供了多种进程间通信的方法, 管道.信号.信号量.消息队列.共享内存.套接字等.下面我们分别 介绍管道.信号量.消息队列.共享内存.        信号和套接字在后续介绍.   1.管道     管道又分为无名管道.命名管道.   无名管道用于父子进程间通信, 而命名管道则可以用于同一计算机上运行的 两个进程间的通信.管道可以用类似“水管”的原理来理解.   1)无名管道     要在父子进程进程间使用管道进行通信,那么先需要创建管道, 在linux中…