零拷贝(Zero-copy)和mmap
磁盘可以说是计算机系统最慢的硬件之一,读写速度相差内存 10 倍以上,所以针对优化磁盘的技术非常的多,比如零拷贝、直接 I/O、异步 I/O 等等,这些优化的目的就是为了提高系统的吞吐量,另外操作系统内核中的磁盘高速缓存区,可以有效的减少磁盘的访问次数。 这次,我们就以「文件传输」作为切入点,来分析 I/O 工作方式,以及如何优化传输文件的性能。 为什么要有 DMA 技术? 在没有 DMA 技术前…
磁盘可以说是计算机系统最慢的硬件之一,读写速度相差内存 10 倍以上,所以针对优化磁盘的技术非常的多,比如零拷贝、直接 I/O、异步 I/O 等等,这些优化的目的就是为了提高系统的吞吐量,另外操作系统内核中的磁盘高速缓存区,可以有效的减少磁盘的访问次数。 这次,我们就以「文件传输」作为切入点,来分析 I/O 工作方式,以及如何优化传输文件的性能。 为什么要有 DMA 技术? 在没有 DMA 技术前…
今天遇到一个问题就是mysql中insert into 和update以及delete语句中能使用as别名吗?目前还在查看,但是在查阅资料时发现了一些有益的知识,给大家分享一下,就是关于sql以及MySQL语句执行顺序: sql和mysql执行顺序,发现内部机制是一样的。最大区别是在别名的引用上。 一、sql执行顺序 from on join where group by(开始使用select…
刚开始使用Typora的初级开发者都会遇到下面这样的简单问题: 就是换行会自动继承上面的格式,按删除键和回退键以及多次换行都无效。 情况如下图所示: 次问题的解决方案如下: Mac OS 按下command+[ windows 的按键是ctrl+[ 版权声明:本文为liulei952413829原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。原文链接:https…
简介 ArrayList 是 java 集合框架中比较常用的数据结构了。继承自 AbstractList,实现了 List 接口。底层基于数组实现容量大小动态变化。允许 null 的存在。同时还实现了 RandomAccess、Cloneable、Serializable 接口,所以ArrayList 是支持快速访问、复制、序列化的。 成员变量 ArrayList 底层是基于数组来实现容量大小动态…
%Romberg积分法计算定积分 %参考教材:《数值分析》李乃成,梅立泉,科学出版社 %《计算方法教程》第二版 凌永祥,陈明逵 clear;clc;close all; format long % %被积函数为f(x)=4/(1+x^2);积分区间为[0,1] % b=1;a=0;h=b-a;eps=10^(-5); %误差界eps%被积函数为f(x)=(x^3+sin(x))/x;积分区间为[0…
1、为什么要使用RocketMQ RocketMQ是一款分布式、队列模型的消息中间件,支持严格的消息顺序,优点: 应用解耦:如果系统A、系统B、系统C,都直接依赖于系统X,那么系统之间的耦合度就非常高;如果在系统X之前加上RocketMQ,就实现了系统之间的解耦。 流量削峰:如果用户的每次访问都是直接连接到应用上的话,服务器的承受的访问压力就会非常大,达到服务器的承受上限时就可能会崩溃,同时对服务…
#制作镜像,默认Dockerfile在此目录 #sudo docker build -t 'cci/videocapture:0.6' -f Dockerfile ../. #sudo docker run --gpus all --runtime nvidia --ipc=host -itd -p 7780:80 -v /dev/ttyACM0:/tmp/ttyACM0 -u "0:0" --p…
1、Python因式分解代码:import time # 对一个数进行因式分解 def factorization(num): factor = [] while num > 1: for i in range(num - 1): k = i + 2 if num % k == 0: factor.append(k) num = int(num / k) break return facto…
问题: 利用vscode编辑代码时,设置了禁用非活动区域着色后,在一些编译脚本中配置的宏又识别不了 遇到#ifdef包住的代码就会变暗色,想查看代码不是很方便。如下图: 解决: 在vscode中添加全局宏定义。 步骤: 1.ctrl+shift+p,选择对应的编辑配置,比如c/c++的,进入文件c_cpp_properties.json 2.在配置文件中的defines项中加入需要的宏定义 版权声…