python 开发的三种运行模式详细介绍


Posted in Python onJanuary 18, 2017

Python 三种运行模式

  Python作为一门脚本语言,使用的范围很广。有的同学用来算法开发,有的用来验证逻辑,还有的作为胶水语言,用它来粘合整个系统的流程。不管怎么说,怎么使用python既取决于你自己的业务场景,也取决于你自己的python应用能力。就我个人而言,我觉得python作为既可以用来进行业务的开发,也可以进行产品原型的开发.一般来说,python的运行主要下面这三种模式。

1.单循环模式

  单循环模式使用的最多,也最简单,当然也最稳定。为什么呢,因为单循环本来代码就写的很少,出错的机会就更少,所以一般只要写对了接口,犯错误的机会还是很低的。当然,我们不是说单循环就没什么用,恰恰相反。单循环模式是我们最经常使用的一种模式。这种开发对于一些小工具、小应用、小场景特别合适。

#!/usr/bin/python
import os
import sys
import re
import signal
import time

g_exit = 0

def sig_process(sig, frame):
  global g_exit
  g_exit = 1
  print 'catch signal'

def main():
  global g_exit
  signal.signal(signal.SIGINT, sig_process)
  while 0 == g_exit:
    time.sleep(1)

    '''
    module process code
    ''' 

if __name__ == '__main__':
  main()

2.多线程模式

  多线程模式经常用在那些容易阻塞的场合。比如多线程客户端读写,多线程web访问等等。这里的多线程有个特点,那就是每个线程都是按照客户端创建的。简单的举例就是服务器socket,来一个socket创建一个thread,这样如果存在多个用户的话,就有多个thread并发连接。这种方式比较简单,用起来很快,缺点就是所有业务有可能并发执行,全局数据保护起来很麻烦。

#!/usr/bin/python
import os
import sys
import re
import signal
import time
import threading

g_exit=0

def run_thread():
  global g_exit
  while 0 == g_exit:
    time.sleep(1)

    '''
    do jobs per thread
    '''

def sig_process(sig, frame):
  global g_exit
  g_exit = 1

def main():

  global g_exit

  signal.signal(signal.SIGINT, sig_process)
  g_threads = []
  for i in range(4):
    td = threading.Thread(target = run_thread)
    td.start()
    g_threads.append(td)

  while 0 == g_exit:
    time.sleep(1)

  for i in range(4):
    g_threads[i].join()


if __name__ == '__main__':
  main()

3.reactor模式

  reactor模式,不复杂,简单的来说,就是利用多线程来处理每一个业务。如果一个业务已经被某一个thread处理了,那么其他的thread就不能再次处理这个业务了。这样,它相当于解决了一个问题,也就是我们在前面所说的锁的问题。因此,对于这种模式的开发者来说,编写业务其实是一件简单的事情,因为他所要关注的只是自己的一亩三分地就可以了。之前云风同学编写的skynet就是这么一种模式,只不过它使用了c+lua来开发的。其实只要了解了reactor模式本身,用什么语言开发不重要,关键是理解reactor的精髓就可以了。 

python 开发的三种运行模式详细介绍

  如果写成code,那应该是这样的,

#!/usr/bin/python

import os
import sys
import re
import time
import signal
import threading

g_num = 4
g_exit =0
g_threads = []
g_sem = []
g_lock = threading.Lock()
g_event = {}

def add_event(name, data):
  global g_lock
  global g_event

  if '' == name:
    return

  g_lock.acquire()
  if name in g_event:
    g_event[name].append(data)
    g_lock.release()
    return

  g_event[name] = []

  '''
  0 means idle, 1 means busy
  '''
  g_event[name].append(0)
  g_event[name].append(data)
  g_lock.release()

def get_event(name):
  global g_lock
  global g_event

  g_lock.acquire()
  if '' != name:
    if [] != g_event[name]:
      if 1 != len(g_event[name]):
        data = g_event[name][1]
        del g_event[name][1]
        g_lock.release()
        return name, data
      else:
        g_event[name][0] = 0

  for k in g_event:
    if 1 == len(g_event[k]):
      continue

    if 1 == g_event[k][0]:
      continue

    g_event[k][0] =1
    data = g_event[k][1]
    del g_event[k][1]
    g_lock.release()
    return k, data

  g_lock.release()
  return '', -1

def sig_process(sig, frame):
  global g_exit
  g_exit =1
  print 'catch signal'

def run_thread(num):
  global g_exit
  global g_sem
  global g_lock

  name = ''
  data = -1

  while 0 == g_exit:
    g_sem[num].acquire()

    while True: 
      name, data = get_event(name)
      if '' == name:
        break

      g_lock.acquire()
      print name, data
      g_lock.release()


def test_thread():
  global g_exit

  while 0 == g_exit:
    for i in range(100):
      add_event('1', (i << 2) + 0)
      add_event('2', (i << 2) + 1)
      add_event('3', (i << 2) + 2)
      add_event('4', (i << 2) + 3)

    time.sleep(1)


def main():
  global g_exit
  global g_num
  global g_threads
  global g_sem

  signal.signal(signal.SIGINT, sig_process)
  for i in range(g_num):
    sem = threading.Semaphore(0)
    g_sem.append(sem)
    td = threading.Thread(target=run_thread, args=(i,))
    td.start()
    g_threads.append(td)

  '''
  test thread to give data
  '''
  test = threading.Thread(target=test_thread)
  test.start()

  while 0 == g_exit:
    for i in range(g_num):
      g_sem[i].release()
    time.sleep(1)

  '''
  call all thread to close
  '''
  for i in range(g_num):
    g_sem[i].release()

  for i in range(g_num):
    g_threads[i].join()

  test.join()
  print 'exit now'

'''
entry
'''
if __name__ == '__main__':
  main()

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Python 相关文章推荐
python文件特定行插入和替换实例详解
Jul 12 Python
python之pandas用法大全
Mar 13 Python
python中的常量和变量代码详解
Jul 25 Python
Django 实现购物车功能的示例代码
Oct 08 Python
在python 不同时区之间的差值与转换方法
Jan 14 Python
详解Python字符串切片
May 20 Python
Python基础学习之基本数据结构详解【数字、字符串、列表、元组、集合、字典】
Jun 18 Python
python实现的批量分析xml标签中各个类别个数功能示例
Dec 30 Python
解决python3插入mysql时内容带有引号的问题
Mar 02 Python
python 深度学习中的4种激活函数
Sep 18 Python
python 检测nginx服务邮件报警的脚本
Dec 31 Python
python利用while求100内的整数和方式
Nov 07 Python
Python 3中的yield from语法详解
Jan 18 #Python
Python中的字符串操作和编码Unicode详解
Jan 18 #Python
关于Python中异常(Exception)的汇总
Jan 18 #Python
python:socket传输大文件示例
Jan 18 #Python
详解使用pymysql在python中对mysql的增删改查操作(综合)
Jan 18 #Python
python实现下载整个ftp目录的方法
Jan 17 #Python
ansible作为python模块库使用的方法实例
Jan 17 #Python
You might like
服务器端解压缩zip的脚本
2006/12/22 PHP
安装PHP可能遇到的问题“无法载入mysql扩展” 的解决方法
2007/04/16 PHP
php数组函数序列之array_pop() - 删除数组中的最后一个元素
2011/11/07 PHP
php将session放入memcached的设置方法
2014/02/14 PHP
php程序总是提示验证码输入有误解决方案
2015/01/07 PHP
CentOS下PHP安装Oracle扩展
2015/02/15 PHP
php防止网站被攻击的应急代码
2015/10/21 PHP
php表单提交实例讲解
2015/11/12 PHP
php+ajax实现异步上传文件或图片功能
2017/07/18 PHP
Javascript isArray 数组类型检测函数
2009/10/08 Javascript
iframe自适应宽度、高度 ie6 7 8,firefox 3.86下测试通过
2010/07/29 Javascript
Javascript全局变量var与不var的区别深入解析
2013/12/09 Javascript
jQuery中contents()方法用法实例
2015/01/08 Javascript
jQuery实现简单的日期输入格式化控件
2015/03/12 Javascript
Js与Jq 获取页面元素值的方法和差异对比
2015/04/30 Javascript
深入理解JQuery循环绑定事件
2016/06/02 Javascript
关于javascript事件响应的基础语法总结(必看篇)
2016/12/26 Javascript
jQuery Jsonp跨域模拟搜索引擎
2017/06/17 jQuery
Django中使用jquery的ajax进行数据交互的实例代码
2017/10/15 jQuery
Vue2 配置 Axios api 接口调用文件的方法
2017/11/13 Javascript
详解VUE中常用的几种import(模块、文件)引入方式
2018/07/03 Javascript
详解Koa中更方便简单发送响应的方式
2018/07/20 Javascript
详解Node.js读写中文内容文件操作
2018/10/10 Javascript
apicloud拉起小程序并传递参数的方法示例
2018/11/21 Javascript
关于vue表单提交防双/多击的例子
2019/10/31 Javascript
Python实现的ini文件操作类分享
2014/11/20 Python
Python3指定路径寻找符合匹配模式文件
2015/05/22 Python
python用模块zlib压缩与解压字符串和文件的方法
2016/12/16 Python
pytorch学习教程之自定义数据集
2020/11/10 Python
python中的测试框架
2020/11/13 Python
总经理秘书工作职责
2013/12/26 职场文书
《中国梦我的梦》小学生演讲稿
2014/08/20 职场文书
学生无故旷课检讨书
2014/09/20 职场文书
运动会广播稿200字(10篇)
2014/10/12 职场文书
安全检查汇报材料
2014/12/26 职场文书
浅谈css实现背景颜色半透明的两种方法
2021/12/06 HTML / CSS