1、利用windows api对文件系统进行监听
尝试1:利用FindFirstChangeNotificationA、WaitForMultipleObjects、FindNextChangeNotification组合
这一组合缺点是就api而言无法获取变更的文件名,还要自己遍历文件夹比对。放弃。
尝试2:CreateFileA、ReadDirectoryChangesW组合,完美的组合,可以获取到变更的文件名,唯一不足的是还要用一个函数来转换获取到的文件名(WideCharToMultiByte)。
2、关于python调用c语言。使
用distutils可以将c程序编译成pyd,然后倒入到python程序中调用。
3、由于GIL的关系
由于GIL的关系,在调用c程序时,解释器会被锁住,直到c调用结束才释放(也可以自己释放,函数组:PyEval_AcquireLock();PyEval_ReleaseLock();),在监听等待操纵系统通知的时候是阻塞的,锁住之后再被阻塞,程序就不动了,于是便利用popen来调用。在c程序中以printf来与python程序交互。(感谢RednaxelaFX)
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
int main(int argcount, char** args) {
if(argcount != 2){
return EXIT_SUCCESS;
}
char* path = args[1];
HANDLE hDir = CreateFileA(path, FILE_LIST_DIRECTORY, FILE_SHARE_READ | FILE_SHARE_DELETE, NULL, OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL);
FILE_NOTIFY_INFORMATION Buffer[1024];
DWORD BytesReturned;
int i = 0;
if (ReadDirectoryChangesW(hDir, &Buffer, sizeof(Buffer), TRUE, FILE_NOTIFY_CHANGE_CREATION | FILE_NOTIFY_CHANGE_LAST_WRITE | FILE_NOTIFY_CHANGE_SIZE
| FILE_NOTIFY_CHANGE_DIR_NAME | FILE_NOTIFY_CHANGE_FILE_NAME, &BytesReturned, NULL, NULL)) {
for (i = 0; i < BytesReturned; i++) {
if (Buffer[i].FileNameLength > 0) {
char* action = "_default_";
switch (Buffer[i].Action) {
case FILE_ACTION_ADDED:
action = "added";
break;
case FILE_ACTION_REMOVED:
action = "removed";
break;
case FILE_ACTION_MODIFIED:
action = "modified";
break;
case FILE_ACTION_RENAMED_OLD_NAME:
action = "renamed_old_name";
break;
case FILE_ACTION_RENAMED_NEW_NAME:
action = "renamed_new_name";
break;
case FILE_ACTION_ADDED_STREAM:
action = "ADDED_STREAM";
break;
case FILE_ACTION_ID_NOT_TUNNELLED:
action = "ID_NOT_TUNNELLED";
break;
case FILE_ACTION_MODIFIED_STREAM:
action = "MODIFIED_STREAM";
break;
case FILE_ACTION_REMOVED_BY_DELETE:
action = "REMOVED_BY_DELETE";
break;
case FILE_ACTION_REMOVED_STREAM:
action = "REMOVED_STREAM";
break;
case FILE_ACTION_TUNNELLED_ID_COLLISION:
action = "TUNNELLED_ID_COLLISION";
break;
}
char path[MAX_PATH];
WideCharToMultiByte(CP_ACP, 0, Buffer[i].FileName, Buffer[i].FileNameLength, path, sizeof(path), NULL, FALSE);
printf("%s:%s", action, path);
break;
}
}
}
return EXIT_SUCCESS;
}
os.popen("FileSystemChangeListener.exe %s" % self.path).read()
分享到:
相关推荐
注意,由于C++的并发模型和Python的GIL(全局解释器锁)不同,因此C++版本的服务器可能会在处理多客户端并发时表现出不同的性能特征。 总之,C++实现的SocketServer类可以提供类似Python的便捷服务端编程体验,同时...
在这个项目中,我们使用Python编写了一个多线程的HTTP服务器,这对于学习和测试网页应用或者本地文件共享都非常有用。接下来,我们将详细探讨Python实现HTTP服务器的关键知识点。 1. **Python内置HTTP服务器模块**:...
2. **创建TCP套接字**:使用`socket.socket()`函数创建一个TCP套接字,然后通过`bind()`绑定到指定的IP和端口,最后调用`listen()`来开始监听连接。 ```python server_socket = socket.socket(socket.AF_INET, ...
在Python多线程编程中,需要注意GIL(全局解释器锁)的存在,虽然Python的多线程在CPU密集型任务上可能表现不佳,但在I/O密集型任务(如网络和串口通信)中,由于线程间等待I/O的时间较长,多线程仍能有效提高程序...
Python的多线程或多进程可以解决这个问题,但Python的全局解释器锁(GIL)可能导致并发性能限制。因此,可能采用了非阻塞I/O模型,如异步编程(asyncio库)或者第三方库如Twisted或Tornado来提高并发性能。 6. **...
在Stackless Python中,我们可以创建一个主循环,用于监听新的连接,接收和发送数据。通过创建协程(coroutines)或通道(channels),我们可以实现数据在不同任务间的异步传递。 3. **用户认证**:为了确保安全性...
- **epoll**:相比于select和poll更加高效,因为它不会遍历整个被监听的文件描述符列表,而是只做必要的检查。 #### 装饰器 - **概念**:装饰器是一种特殊的语法结构,允许我们在不修改原函数的情况下为其添加新...
- **GIL(全局解释器锁)**:Python解释器的特性,使得任何时刻只有一个线程在执行。这限制了多线程在CPU密集型任务中的性能提升,但对I/O密集型任务影响较小。 - **greenlet和gevent**:这些第三方库通过用户空间...
学习如何创建、绑定、监听、接受连接和发送/接收数据是掌握Python网络编程的关键。 5. **多线程与并发处理** 在网络编程中,为了提高服务效率,往往需要处理多个并发连接。Python的threading模块可以用来创建和...
4. **Multithreading**:尽管Python的GIL(全局解释器锁)限制了多线程,但Kivy通过其事件循环和异步操作实现了非阻塞的用户体验。这使得UI可以保持流畅,即使在执行耗时任务时也是如此。 5. **OpenGL支持**:Kivy...
3. **随机数**:为了让烟花秀看起来自然且富有变化,我们需要用到Python的`random`模块来生成随机的位置、颜色、速度和方向,这样每朵烟花都有独特的轨迹和效果。 4. **运动和动画**:烟花升空、绽放和消散的过程...
- 涉及到socket编程、HTTP协议详解、TCP协议、echoserver和文件处理等。 11. Web开发: - 介绍Web开发中的常用技术,包括Requests库、XPath解析、Scrapy框架、Django和Flask框架等。 12. 数据库技术: - 包括...
07 Python条件语句和基本数据类型 08 Python while循环语句以及练习题 09 练习题讲解 第10章 01 上节内容回顾以及补充 02 上周作业实现 03 Pycharm的安装和使用 04 Python 运算符 05 Python 运算符以及总结 06 ...
但需要注意的是,Python的全局解释器锁(GIL)会限制同一时间只有一个线程执行Python字节码,这意味着多线程在Python中并不能实现真正的并行计算。不过,对于I/O密集型任务,线程可以交替运行,依然能提升程序响应...
不过,Python的全局解释器锁(GIL)限制了多线程的并行执行,因此在性能要求较高的情况下,多进程可能更为合适。 6. **异常处理**: 在编写socket程序时,应考虑到各种可能的网络异常,如连接中断、超时、数据传输...
Python并发编程是Python编程中的一个重要领域,特别是在处理大数据、网络编程和实时系统时,它能够显著提高程序的执行效率。本专题将深入探讨Python中实现并发的各种方法和技术。 首先,我们要理解什么是并发。并发...
在Python编程中,多线程...总结来说,Python的多线程编程提供了丰富的API来实现线程的创建、管理和同步,但在追求高性能计算时,可能需要借助多进程或第三方库如`multiprocessing`来绕过GIL限制,实现真正的并行计算。
本资源摘要信息涵盖了 Python Web 全栈开发的学习路线,从 Linux 运维到 Python 基础、前端开发、数据库和缓存等方面都有所涉及。 Linux 运维 * Linux 安装 * 网络基础知识点 * ISO 七层模型 * Linux 基本命令 * ...
在学习了这些基础知识后,你就可以通过观看"python入门教程-02-静态web服务器-多任务版.ev4.mp4"视频,进一步深入了解Python构建静态Web服务器的实践操作和多任务处理的具体实现。视频中可能涵盖了如何配置服务器,...
下面将详细介绍Python的多进程和Socket编程相关的知识。 首先,我们来了解Python的多进程编程。在Python中,`multiprocessing`模块提供了创建和管理进程的功能。它与`threading`模块类似,但进程之间拥有独立的内存...