转载——top 执行一次、显示所有进程信息

原文链接:https://blog.csdn.net/purplegalaxy/article/details/38302415

1、执行一次
top命令会动态显示信息,若需要静态的,比如只执行一次,或者只需要关于CPU的分析的那几行,则使用代以下参数的命令:
top -n 1
top执行一次,这样便可以很方便的取出信息,比如把这个信息存到一个文件中。

top -n 1 | head -n 5
显示 top 的前面几行

top -n 1 | grep ‘^Cpu’
只显示 Cpu 那一行
2、显示所有进程信息
用top只能显示一部分进程
top -b
top -b -n 1
这样就可以显示所有进程信息。

Lede openwrt编译备忘

说明:此备忘仅限于当前时间的Lede版本

配置备忘:

1.修改feeds.conf.default:更改luci分支为主分支;打开helloworld插件

src-git luci https://github.com/coolsnowwolf/luci
#src-git luci https://github.com/coolsnowwolf/luci.git;openwrt-23.05
src-git helloworld https://github.com/fw876/helloworld.git

2.make menuconfig配置
Target Images —> Build GRUB images

LuCI ---> 3.Applications ---> Shadowsocks Client Selection ---> Shadowsocks-libev
LuCI ---> 3.Applications ---> Shadowsocks Server Selection ---> Shadowsocks-libev
LuCI ---> 3.Applications ---> V2ray-core Selection ---> V2ray-core

说明:

1.更改Luci分支的原因是由于运行Frpc会提示如下错误:

RPCError
RPC call to uci/get failed with ubus code 4: 未找到资源
at ClassConstructor.handleCallReply (http://192.168.1.1/luci-static/resources/rpc.js?v=git-24.292.31352-6b57333:94:7)

修改luci为master分支后,打开Frpc正常。

2.参考https://github.com/fw876/helloworld/issues/1536,由于Shadowsocks Selection默认是选择Shadowsocks-rust,我在编译openwrt的时候总是会报错:

....
failed to parse bitcode for LTO module: Invalid alignment value (Producer: 'LLVM18.1.2-rust-1.78.0-stable' Reader: 'LLVM 18.1.2-rust-1.78.0-stable')
....

改为Shadowsocks-libev后,编译可以正常通过。
3.修改Shadowsocks时我顺便把V2ray-core Selection改为了V2ray-core,这个选项默认是Xray-core,我没有试过选择Xray-core编译是否可以正常通过。
4.关于Frpc插件的问题,也可以不修改Luci分支。参考http://fisherworks.cn/?p=2829,编译时不打开Frpc,运行openwrt后手动安装Frpc,可以正常运行。

失去免费公网IP,重回FRP

前两天电信网络升级,预存话费升级千兆带宽。在确认不会更改套餐价格后,我选择了参加这个活动。结果昨天发现,之前的公网IP变为内网IP了。在与客服经过一阵电话沟通之后,确认了现在的公网IP不能免费申请了,要用的话需要每月多交100元费用。经过再三沟通,说可以免费赠送一年体验使用,但是一年之后是什么情况就不知道了。上网了解了一下情况,深圳电信从2022年末开始不再免费提供公网IP申请。已申请的公网IP,在更改套餐或者移机后都会转为内网IP。

虽对公网IP有需求,但是要每月多交100元费用感觉不值得。我对公网IP的主要用途是群晖的照片管理——可以随时随地访问和备份照片。即如此只能想用其它途径实现这个需求。尝试了Frp,可以实现此功能。但是国内的VPS太贵,又不太想使用第三方的frp服务,因此只能在之前的国外服务器上搭建。测试了一下速度能到2MB,虽然速度不如公网IP快,至少能够正常使用。

 
说点其它的:
之前我有发现使用zerotier组网后的传输速度只有几百KB,无法跑满网络的上传带宽;使用公网IP就可以跑满上传带宽。我一直以为是我配置的问题,或者是硬件的问题:我以为是硬件性能差,因此尝试在i7-12700上安装openwrt使用,但是同样速度会有限制;我测试不在虚拟机中运行,直接在N1上运行,速度同样会有限制;我把zerotier直接安装在群晖上面,速度还是一样;我把路由器的端口映射配置了,还是没有效果!我查看了zerotier的状态,是直连状态,说明P2P成功了;我甚至怀疑是zerotier软件的限速。

直到我看到这几个网页https://www.aihao.cc/thread-96523-1-1.htmlhttps://www.right.com.cn/forum/thread-8254767-1-1.htmlhttps://github.com/coolsnowwolf/lede/issues/4124,才知道是运营商限速。那就没有办法了,看来想通过zerotier传输大文件的想法是行不通了,而且我也没有必要再去折腾 tailscale、wireguard来提高内网的传输速度了。

PY32F003 GPIO速度对LED亮度影响

实测发现PY32F003的GPIO速度对LED灯的亮度有影响。

硬件连接如下:
LED正极接VCC,负极串一个10欧的电阻到IO口。IO输出为高电平灯灭,IO输出为低电平灯亮。

在调试中发现,当IO口的速度配置为GPIO_SPEED_FREQ_LOW时,LED亮度最低;把速度配置为GPIO_SPEED_FREQ_VERY_HIGH时,LED亮度最亮。

上下拉电阻对休眠功耗的影响

调试休眠电流,系统启动直接休眠的电流是100uA;程序正常运行后再进入休眠的电流由200uA。经过排查是IO口配置的上下拉电阻引起的漏电流:配置了上拉电阻休眠时输出低电平,配置了下拉电阻休眠时输出高电平。把IO口更改为无上下拉电阻后,休眠电流正常。

对于IO口输出,若无特殊需求,可以禁用上下拉电阻。对于特定接口比如串口,这种有要求上拉的,需要打开上拉电阻,在休眠之前一定要上拉功能关闭,并配置为高阻输入模式,降低休眠电流。

转载——C语言八进制表示

原文链接:https://blog.csdn.net/lulujiajiawenwen/article/details/8045034

C语言中8进制和16进制怎么表示

C语言本身支持的三种输入是:
1. 十进制。比如20,457;
2. 十六进制,以0x开头。比如0x7a;
3. 八进制,以0开头。比如05,0237

所以C语言没有二进制输入,最多可用函数去实现。

八进制数的表达方法

C/C++规定,一个数如果要指明它采用八进制,必须在它前面加上一个0(数字0),如:123是十进制,但0123则表示采用八进制。这就是八进制数在C、C++中的表达方法。

C和C++都没有提供二进制数的表达方法

现在,对于同样一个数,比如是100,我们在代码中可以用平常的10进制表达,例如在变量初始化时:

int a = 100;

我们也可以这样写:

int a = 0144; //0144是八进制的100;

千万记住,用八进制表达时,你不能少了最前的那个0。否则计算机会通通当成10进制。不过,有一个地方使用八进制数时,却可以不使用加0,那就是用于表达字符的“转义符”表达法。
八进制数在转义符中的使用

我们学过用一个转义符’/’加上一个特殊字母来表示某个字符的方法,如:’\n’表示换行(line),而’\t’表示Tab字符,’\”则表示单引号。今天我们又学习了另一种使用转义符的方法:转义符’\’后面接一个八进制数,用于表示ASCII码等于该值的字符。

比如,查一下ASCII码表,我们找到问号字符(?)的ASCII值是63,那么我们可以把它转换为八进值:77,然后用 ‘\77’来表示’?’。由于是八进制,所以本应写成 ‘\077’,但因为C/C++规定不允许使用斜杠加10进制数来表示字符,所以这里的0可以不写。

例如:

printf(“\077\n\77\n”)

则输出结果为:

?

?

1

C语言函数转Python函数注意事项

由于Python3的整型没有大小限制,因此当移植C语言代码到Python中,要进行转换处理

一、C语言的32位整数,Python中要进行转换处理

from ctypes import c_int32
n= c_int32(n).value

二、C语言的移位操作,Python中要进行位数截断处理

(z & 0xFFFFFFFF)>>5)^((y & 0xFFFFFFFF)<<2)

三、C语言的for循环,Python中要对应处理

C语言的for循环

for(i = 0; i < n-1; i++)
{
    #do something
}
//此时i=n-1
buff[i]

Python的for循环

for i in range(n - 1):
    #do something
#此时i=0。为了保持C语言的一直性,此处必须对i强制赋值
i = n - 1
buff[i]