P1 和 P2 从后向前遍历,当 P1 遍历到一个空格时,就需要令 P2 指向的位置依次填充 02%(注意是逆序的),否则就填充上 P1 指向字符的值。...从后向前遍是为了在改变 P2 所指向的内容时,不会影响到 P1 遍历原来字符串的内容。 ③ 当 P2 遇到 P1 时(P2 <= P1),或者遍历结束(P1 < 0),退出。...if (str.charAt(i) == ' ') { str.append(" "); } } //追加完后,...P2指向现在的末尾 int P2 = str.length() - 1; //从后往前遍历,如果发下空格就填充%20,否则把P1指向的内容往后挪 while
你的程序还需要返回被替换后的字符串的长度。 注意事项 如果使用 Java 或 Python, 程序中请用字符数组表示字符串。...先扩充,从后往前处理 这个说是字符串,实际上是字符数组,并没有用c++STL的string来做,要是那样就太简单了,因为string本身支持+操作,只要遍历遇到空格用%20代替加上就可以了,如果是字符数组的话就难一些...所以一个可行的思路是把原数组扩大,扩大的容量可以通过检查空格的个数来定,然后用两个指针,从后往前把字符放进去,遇到空格则连续放入%20,因为是从后往前,所以不会出现数据没有地方放的情况。...=32) //如果不是空格,就把这个值放进去,从后往前 { string[i+2*blank_count]=string
Python 截取字符串使用 变量[头下标:尾下标],就可以截取相应的字符串,其中下标是从0开始算起,可以是正数或负数,下标可以为空表示取到头或尾。...0000' + str(num) # 合并字符串 print str[-5:] # 输出字符串右5位 >> 00018 Python 替换字符串使用 变量.replace(“被替换的内容”,“替换后的内容...要注意的是使用replace替换字符串后仅为临时变量,需重新赋值才能保存。...查找到后会返回位置,位置从0开始算,如果每找到则返回-1。
从linux源码看epoll 前言 在linux的高性能网络编程中,绕不开的就是epoll。...简单的epoll例子 下面的例子,是从笔者本人用c语言写的dbproxy中的一段代码。由于细节过多,所以做了一些删减。...(注:由于是tcp socket,所以这边sock->ops=inet_stream_ops,这个初始化的过程在我的另一篇博客>中,博客地址如下: https...fput |->eventpoll_release |->ep_remove 所以我们在关闭对应的文件描述符后...总结 epoll作为linux下非常优秀的事件触发机制得到了广泛的运用。其源码还是比较复杂的,本文只是阐述了epoll读写事件的触发机制,探究linux kernel源码的过程非常快乐^_^。
前言 在linux的高性能网络编程中,绕不开的就是epoll。和select、poll等系统调用相比,epoll在需要监视大量文件描述符并且其中只有少数活跃的时候,表现出无可比拟的优势。...简单的epoll例子 下面的例子,是从笔者本人用c语言写的dbproxy中的一段代码。由于细节过多,所以做了一些删减。...那么,由accept获得的client_fd的结构如下图所示: (注:由于是tcp socket,所以这边sock->ops=inet_stream_ops,这个初始化的过程在我的另一篇博客>中,博客地址如下: https://my.oschina.net/alchemystar/blog/1791017) 既然知道了tfile->f_op->poll的实现...fput |->eventpoll_release |->ep_remove 所以我们在关闭对应的文件描述符后
从linux源码看socket的close 笔者一直觉得如果能知道从应用到框架再到操作系统的每一处代码,是一件Exciting的事情。...socket的时候,会使用close(fd)函数: int socket_fd; socket_fd = socket(AF_INET, SOCK_STREAM, 0); ... // 此处通过文件描述符关闭对应的...sys_close(unsigned int fd) { // 清除(close_on_exec即退出进程时)的位图标记 FD_CLR(fd, fdt->close_on_exec); // 释放文件描述符...但最终解决方案还是得从应用程序着手。...直到现在自己带着问题独立看linux源码的时候,尽管有之前的基础,仍旧被其中的各种细节所迷惑。希望笔者这篇文章能帮助到阅读linux网络协议栈代码的人。
(ls -l|grep “^-“| wc -l)查看某个文件夹下文件的个数。 (ls -lR|grep “^-“| wc -l)查看某个文件夹下文件的个数,包括子文件夹下的文件个数。...(ls -l|grep “^d”| wc -l)查看某个文件夹下文件夹的个数。 (ls -lR|grep “^d”| wc -l)查看某个文件夹下文件夹的个数,包括子文件夹下的文件夹个数。...(ls -l| wc -l)查看文件夹下所有的文件和文件夹。也就是统计ls -l命令所输出的行数。...说明: ls -l 长列表输出该目录下文件信息(注意这里的文件,不同于一般的文件,可能是目录、链接、设备文件等) grep “^-“ 这里将长列表输出信息过滤一部分,只保留一般文件,如果只保留目录就是...^d wc -l 统计输出信息的行数,因为已经过滤得只剩一般文件了,所以统计结果就是一般文件信息的行数,又由于 一行信息对应一个文件,所以也就是文件的个数。
很多时候,我们都是从代码层面去学习如何编程,却很少去看看一个个 Java 代码背后到底是什么。今天就让我们从一个最简单的 Hello World 开始看一看 Java 的类文件结构。...紧接着 0011 的后一个字节为 08,表示该常量为字符串引用类型(CONSTANT_String_info)的常量。...这里 Demo 类的字节码文件中,因为并没有实现任何接口,所以紧跟着父类索引后的两个字节是0x0000,这表示该类没有实现任何接口。因此后面的接口索引表为空。...在类接口集合后的2个字节是一个字段计数器,表示总有有几个属性字段。在字段计数器后,才是具体的属性数据。...方法表集合 在字段表后的 2 个字节是一个方法计数器,表示类中总有有几个方法。在字段计数器后,才是具体的方法数据。方法表中的每个方法都用一个 method_info 表示,其数据结构如下: ?
本文大部分讨论的是socket设置为block的情况,即setNonblock(false),仅在最后提及了nonblock socket(本文基于linux 2.6.32-431内核)。...kernel代码版本细微变化 值得注意的是,linux本身官方发布的2.6.32源码对于tcp_syn_retries2的解释和RFC并不一致(至少笔者阅读的代码如此,这个细微的变化困扰了笔者好久,笔者下载了和机器对应的内核版本后才发现代码改了...到期后timeout,其重传到期时间通过tcp_retries2以及TCP_RTO_MIN计算出来。...java的SocketInputStream的sockRead0超时时间 java的超时时间由SO_TIMOUT决定,而linux的socket并没有这个选项。...对端物理机宕机后没有数据发送,但在read等待 这时候如果设置了超时时间timeout,则在timeout后返回。
关于epoll的原理可以看下笔者之前的博客《从linux源码看epoll》: https://www.cnblogs.com/alchemystar/p/13161781.html 在这里描述一下原因,...Socket上(Sharding),毫无疑问可以利用多核能力,大幅提升连接成功后的Socket分发能力。...在accept_queue被填充后,由用户线程通过accept系统调用从队列中获取对应的fd 值得注意的是,当用户线程来不及处理的时候,内核会drop掉三次握手成功的连接,导致一些诡异的现象,具体可以看笔者的另一篇博客...: https://www.cnblogs.com/alchemystar/p/13473999.html 另外,对于accept_queue具体的填充机制以及源码,可以见笔者另一篇博客的详细分析 《从Linux...源码看Socket(TCP)的listen及连接队列》: https://www.cnblogs.com/alchemystar/p/13845081.html 总结 Linux内核源码博大精深,每次扎进去探索时候都会废寝忘食
mpstat # cpu 各个状态所占的比例 funccount # 统计函数调用次数 extrslower # ext4 文件系统读写哪些文件的耗时比较久 biotop # 哪些进程在占用磁盘...---- 观察 Linux 的 IO 使用情况 对于 IO 的观察也有一个原则,那就是先看总量再看结构,最后精确到文件。 1....看总量 mpstat 1 20 Linux 5.14.0-55.el9.x86_64 (git-sqlpy-com) 07/21/2022 _x86_64_ (2 CPU) 01:16:46...---- 优化后的各项指标 我们还是先看一下参数调整后 IO 的消耗怎么样,命令和输出如下。...,从 1.6k 提升到了 1.7k ,但是这次写的实在是太多了,下次再写吧。
前言 笔者一直觉得如果能知道从应用到框架再到操作系统的每一处代码,是一件Exciting的事情。...今天笔者就来从Linux源码的角度看下Server端的Socket在进行bind的时候到底做了哪些事情(基于Linux 3.10内核)。...inet_bind的流程 值得注意的是,由于对于<1024的端口号需要CAP_NET_BIND_SERVICE,我们在监听80端口号(例如启动nginx时候),需要使用root用户或者赋予这个可执行文件...这个分支表明之前bind的port和当前sock都设置了reuse同时当前sock状态不为listen // 或者同时设置了reuseport而且是同一个uid(注意,设置了reuseport后,...SO_REUSEPORT SO_REUSEPORT是Linux在3.9版本引入的新功能。
从linux源码看socket(tcp)的timeout 前言 网络编程中超时时间是一个重要但又容易被忽略的问题,对其的设置需要仔细斟酌。...kernel代码版本细微变化 值得注意的是,linux本身官方发布的2.6.32源码对于tcp_syn_retries2的解释和RFC并不一致(至少笔者阅读的代码如此,这个细微的变化困扰了笔者好久,笔者下载了和机器对应的内核版本后才发现代码改了...在timeout>0时,将socket设置为非阻塞,然后用select系统调用去模拟超时,而没有走linux本身的超时逻辑,如下图所示: ?...到期后timeout,其重传到期时间通过tcp_retries2以及TCP_RTO_MIN计算出来。...对端物理机宕机后没有数据发送,但在read等待 这时候如果设置了超时时间timeout,则在timeout后返回。
PostgreSQL 查看内存使用的方法比较多, 大部分都是进入到POSTGRESQL 中进行查看的,今天从PostgreSQL 外部来查看内存的使用方式和方法....在LINUX 中proc目录中有所有相关的进程的信息, PSS 通过下面的预计获得,所以RSS - PSS 等于的就是进程独享的内存 ps -u postgres o pid= | sed 's#.
Linux 3.2.0-23-generic (linux) 09/08/2014 _x86_64_ (8 CPU) 02:01:55 PM dentunusd file-nr inode-nr
Linux修改profile文件改错了,恢复的方法 在改profile的时候,改出问题了,除了cd以外的命令基本都不能用了, 连vi都不能用了,上网查了下, www.2cto.com
查看系统的最大文件句柄数和文件句柄的使用者PID ulimit -n查看当前系统的最大句柄数显示如下 ulimit命令详解 ulimit -HSn x设置当前系统的文件句柄数为x 以上命令中,H指定了硬性大小...,S指定了软性大小,n表示设定单个进程最大的打开文件句柄数量。...个人觉得最好不要超过4096,毕竟打开的文件句柄数越多响应时间肯定会越慢。设定句柄数量后,系统重启后,又会恢复默认值。...如果想永久保存下来,可以修改.bash_profile文件,可以修改 /etc/profile 把上面命令加到最后. lsof命令查看有关文件句柄的详细信息,如当前系统打开的文件数量,哪些进程在使用这些文件句柄等等...lsof -p 【PID】查看进程PID打开的文件句柄详细信息 # lsof -n|awk '{print $2}'|sort|uniq -c|sort -nr|more 查看当前进程打开了多少句柄数
跟随陈老师学习linux内核两个月了,对linux内核产生了极大的兴趣,最近学习文件系统,有一些自己的看法,很荣幸能在linux内核之旅进行分享^_^ 本篇文章使用尽量通俗的语言来说明linux内核文件系统中各个数据结构之间的关系...第一条线(绿色) 这一条线是进程部分,也就是以进程的眼光来看文件系统。task_struct是一个非常复杂的结构体,我们在这里只看与文件系统相关的字段。...在阅读大量书籍后,我自己给出的答案是file_system_type是描述这个文件系统的,而super_block是用来实际管理文件系统的,二者是不同的作用,就好比注册完以后,那张注册表还有别的作用吗?...一二条线的交叉部分 这里的交叉部分很巧妙,我学习文件系统的时候,是从super_block开始学习的,所以顺着下来是inode结构体,但是当时就在想,为什么不先是dentry目录,然后目录下再存放inode...从文件系统来看内核 这里假设大家已经细读了内核源码,我们可以发现,内核设计的标准套路,就是抽象、管理、操作,抽象是分为两种情况,一种是外部文件的抽象,一种是内部信息复杂而进行的抽象。
比如文件上传那部分,如果不了解 http 文件上传协议 RFC 1867,就很难搞懂为什么代码这么写。 今天,就以这个话题为基础,介绍下 Go 如何实现文件上传。...本文视频地址:Go 上传文件 简介 简单来说,HTTP 上传文件可以分三个步骤,分别是组织请求体,设置 Content-Type 和发送 Post 请求。...文件上传这种常见需求,如果有一套标准岂不更好。...name="uploadfile1"> 复制代码 提交表单后,...io.Copy(fileWriter, f) 添加字段就非常简单了,假设设置 words 为 123,代码如下: writer.WriteField("words", "123") 完成所有内容设置后,
前言:昨天有个同学碰到发送udp包时收到destination unreachable的icmp包问题,本文简单介绍一下linux5.9中icmp包的处理流程。...我们从收到一个udp包开始分析,具体函数是udp_rcv。...收到icmp包的处理流程 我们从收到ip包开始分析。...icmp_socket_deliver(skb, info);} 继续看icmp_socket_deliver static void icmp_socket_deliver(struct sk_buff...sk->sk_error_report = sock_def_error_report; 接着看sock_def_error_report static void sock_def_error_report
领取专属 10元无门槛券
手把手带您无忧上云