用POLL的方式,没有跑出结果来,立此存照

咦,这些内容,和我以前看内核时的东东,对应起来了。。

SELECT,POLL,EPOLL,非阻塞,异步之类的。。。

但我没有调出来。回家有空了可以看看,不用再敲打代码啦。。。

#!/usr/bin/env python
import socket, sys, select

port = 54321
host = ‘127.0.0.1‘

spinsize = 10
spinpos = 0
spindir = 1

def spin():
    global spinsize, spinpos, spindir
    spinstr = ‘.‘ * spinpos +     ‘|‘ + ‘.‘ * (spinsize - spinpos -1 )
    sys.stdout.write(‘\r‘ + spinstr + ‘ ‘)
    sys.stdout.flush()

    spinpos += spindir
    if spinpos < 0:
    spindir = 1
    spinpos = 1
    elif spinpos >= spinsize:
    spinpos = 2
    spindir = -1

s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect((host, port))

p = select.poll()
p.register(s.fileno(), select.POLLIN | select.POLLERR | select.POLLHUP)

while 1:
    results = p.poll(50)
    if len(results):
    if results[0][1] == select.POLLIN:
        data = s.recv(4096)
        if not len(data):
        print "\rRemote end closed connection; exiting."
        break
        sys.stdout.write("\rReceived: " + data)
        sys.stdout.flush()
    else:
        print "\rProblem occurred; exiting."
        sys.exit(0)
spin()
时间: 2024-11-08 17:28:21

用POLL的方式,没有跑出结果来,立此存照的相关文章

RabbitMQ Consumer获取消息的两种方式(poll,subscribe)解析

以下转自:http://blog.csdn.net/yangbutao/article/details/10395599 rabbitMQ中consumer通过建立到queue的连接,创建channel对象,通过channel通道获取message, Consumer可以声明式的以API轮询poll的方式主动从queue的获取消息,也可以通过订阅的方式被动的从Queue中消费消息, 最近翻阅了基于java的客户端的相关源码,简单做个分析. 编程模型伪代码如下: ConnectionFactory

Linux内核3.11的socket busy poll机制避免睡眠切换

Linux的网络协议栈非常独立,上下通过两个接口分别和用户态以及设备相连,也可以看作是北向和南向接口...北向通过socket接口,南向通过qdisc接口(你可以认为是上层的netdev queue,对于接收接口,NAPI的poll队列则是另一个例子),不管是socket还是qdisc,都是基于队列来管理的,也就是说,三个部分是独立的,socket只能看到读写队列,而看不到协议栈本身,socket在读一个数据的时候,它取的是队列里面的数据,至于说这个数据是谁放进去的,它并不知道,是不是协议栈放进

select epoll poll

如何理解 Epoll select 和 poll 三种模型,能否用生活中的例子做比喻? 比如说你从某宝下单买了几个东西,这几个东西分别由N个快递员分别给你送过来.在某一时刻,你开始等快递.对于select/poll,就是你在睡觉的时候,收到一条短信"你有快递到了,取一下",但不知道发送方是谁(但一定是那N个快递员中的某人/某几个人给你发的),所以你必须挨个给那N个快递员分别打个电话,问他们,是不是我的快递已经到了.至于select/poll的区别,类似于你和快递员都分别有两个手机号,一

linux poll机制使用(一)

一.poll机制的作用 1.poll机制的作用 在前面的使用中断的的方式来读取按键值(linux 中断管理(四)).使用这种方式读取按键,如果按键没有按下的时候,应用程序会一直处于睡眠的状态.如果想要即使按键没有按下,在一定的时间后也能返回,要实现这种功能,可以使用poll机制.(select IO复用和epoll也可以实现这种功能,这里只写poll机制) 二.poll机制的应用编程 1.应用层函数接口 1).API: int poll(struct pollfd *fds, nfds_t nf

20150218【改进信号量】IMX257实现GPIO-IRQ中断按键获取键值驱动程序

[改进信号量]IMX257实现GPIO-IRQ中断按键获取键值驱动程序 2015-02-18 李海沿 前面我们使用POLL查询方式来实现GPIO-IRQ按键中断程序 这里我们来使用信号量,让我们的驱动同时只能有一个应用程序打开. 一.首先在前面代码的基础上来一个简单的信号 1.定义一个全局的整形变量 2.在打开函数中,每次进入打开函数canopen都自减1, 3.当我们不使用时,在realease 中canopen自加1 4.这样就实现了一个简单的信号量,我们编译,测试 当我们使用两个应用程序来

线程基础:线程池(6)——基本使用(中)

(接上文:<线程基础:线程池(5)--基本使用(上)>) 3-4.JAVA主要线程池的继承结构 我们先来总结一下上文中讨论过的内容,首先就是JAVA中ThreadPoolExecutor类的继承结构.如下图所示: ThreadPoolExecutor:这个线程池就是我们这两篇文章中介绍的重点线程池实现.程序员可以通过这个线程池中的submit()方法或者execute()方法,执行所有实现了Runnable接口或者Callable接口的任务:ThreadPoolExecutor对于这些任务的执

【高性能服务器】Nginx剖析

引言 Nginx是一个流行的高性能服务器,官方宣称在压力测试下可以支持5万个并发连接,而且占用内存极低.相比于其他昂贵的硬件负载均衡解决方案,Nginx是开源免费的,可以大大降低成本.本文将从一下几个方面来剖析其内部结构. 特点 进程模型 惊群效应 负载均衡 核心模块 模块分类 事件驱动模块机制 反向代理模块 配置文件 Nginx的特点 Nginx是俄罗斯工程师开发的高性能Web服务器,为了实现高效Nginx全部采用C语言编写,因为底层对不同的操作系统进行了封装,所以Nginx实现了平台无关性.

【转】网络编程常见问题总结

网络编程常见问题总结 这里对在网络程序中遇到的一些问题进行了总结, 这里主要针对的是我们常用的TCP socket相关的总结, 可能会存在错误, 有任何问题欢迎大家提出. 对于网络编程的更多详细说明建议参考下面的书籍 <UNIX网络编程> <TCP/IP 详解> <Unix环境高级编程> < div> 网络编程常见问题总结 相关说明 非阻塞IO和阻塞IO 基本概念 设置 区别: 读: 写: 超时控制: 长连接和短连接的各种可能的问题及相应的处理 短连接: 长

c# 线程的等待(堵塞)

这里我要强调一个概念, 多线程是多线程, 异步编程是异步编程 这两个是有区别的概念: 我可以说多线程天生就要异步的特点:但你不能说多线程成就等同于我们的异步编程: 根不能说异步编程就是我们的多线程.这里不要搞混淆了: 再net中的进化如下: 多线程:Thread =>ThreadPool=> Task 异步编程:BenginInvokeXXX EndInvokeXXX IAsyncResult=> async await (这里面配合着Task的使用). 好接下来,再来总结我们的线程(任