内存对齐#define _INTSIZEOF(n) ((sizeof(n)+sizeof(int)-1)&~(sizeof(int) - 1) ) .

利用C语言计算最小非负剩余与最大非正剩余
本文介绍了如何使用C语言实现最小非负剩余与最大非正剩余的计算方法,并通过实例展示了具体操作过程。
对于两个正整数 x, n 总存在整数 q, r 使得

x = nq + r, 其中  0<= r <n                  //最小非负剩余

q, r 是唯一确定的。q = [x/n], r = x - n[x/n]. 这个是带余除法的一个简单形式。在 c 语言中, q, r 容易计算出来: q = x/n, r = x % n.


所谓把 x 按 n 对齐指的是:若 r=0, 取 qn, 若 r>0, 取 (q+1)n. 这也相当于把 x 表示为:

x = nq + r', 其中 -n < r' <=0                //最大非正剩余   

nq 是我们所求。关键是如何用 c 语言计算它。由于我们能处理标准的带余除法,所以可以把这个式子转换成一个标准的带余除法,然后加以处理:

x+n = qn + (n+r'),其中 0<n+r'<=n            //最大正剩余

x+n-1 = qn + (n+r'-1), 其中 0<= n+r'-1 <n    //最小非负剩余

所以 qn = [(x+n-1)/n]n. 用 c 语言计算就是:

((x+n-1)/n)*n

若 n 是 2 的方幂, 比如 2^m,则除为右移 m 位,乘为左移 m 位。所以把 x+n-1 的最低 m 个二进制位清 0就可以了。得到:

(x+n-1) & (~(n-1))
 
转自: http://blog.youkuaiyun.com/swell624/article/details/3210779
这段代码是C语言中的一段宏定义,主要用于配置和定义与&ldquo;闹钟计划&rdquo;相关的常量。下面是对每一行的详细解释: --- ### 代码解释: ```c #define ALARM_SCHEDULE_MAX_NUM 5 ``` - **含义**:定义最大允许设置的闹钟计划数量为5。 - **用途**:在程序中可能用于限制用户最多只能设置5个闹钟。 ```c #define ALARM_SCHEDULE_CHECK_DURATION 60 ``` - **含义**:定义检查闹钟计划的时间间隔为60秒。 - **用途**:程序可能每隔60秒检查一次当前时间是否匹配某个闹钟计划。 ```c #define ALARM_SCHEDULE_MODULE_NAME &quot;alarm_schedule&quot; ``` - **含义**:定义模块名称为 `&quot;alarm_schedule&quot;`。 - **用途**:用于日志、调试、模块识别等场景,标识当前模块的功能是&ldquo;闹钟计划&rdquo;。 ```c #define ALARM_SCHEDULE_PLAN_PATH &quot;/audio_alarm_clock/plan&quot; ``` - **含义**:定义闹钟计划文件的存储路径为 `/audio_alarm_clock/plan`。 - **用途**:程序可能从该路径读取或写入闹钟计划信息(如文件)。 ```c #define ALARM_SCHEDULE_PREFIX_PATH &quot;/msg_alarm_plan/shp_alarm_plan_&quot; ``` - **含义**:定义闹钟计划文件的前缀路径为 `/msg_alarm_plan/shp_alarm_plan_`。 - **用途**:可能用于生成具体的闹钟计划文件名,例如 `shp_alarm_plan_1.json`。 ```c #define ALARM_SCHEDULE_PATH_SIZE (sizeof(ALARM_SCHEDULE_PREFIX_PATH) + 2) ``` - **含义**:定义存储闹钟路径字符串所需的缓冲区大小,包括前缀路径长度加上2个字符(例如用于数字和字符串结尾符 `\0`)。 - **解释**: - `sizeof(ALARM_SCHEDULE_PREFIX_PATH)`:计算字符串字面量的长度(包含结尾的 `\0`)。 - 加上 `2` 可能是为了存储编号(如 `_1`)和字符串结尾符 `\0`。 - **用途**:用于声明字符数组的大小,确保能够容纳完整的文件路径。 --- ### 示例代码:使用这些宏定义构造文件名 ```c #include &lt;stdio.h&gt; #include &lt;string.h&gt; #define ALARM_SCHEDULE_PREFIX_PATH &quot;/msg_alarm_plan/shp_alarm_plan_&quot; #define ALARM_SCHEDULE_PATH_SIZE (sizeof(ALARM_SCHEDULE_PREFIX_PATH) + 2) int main() { char filename[ALARM_SCHEDULE_PATH_SIZE]; int plan_id = 1; // 构造文件名,例如:/msg_alarm_plan/shp_alarm_plan_1 snprintf(filename, sizeof(filename), &quot;%s%d&quot;, ALARM_SCHEDULE_PREFIX_PATH, plan_id); printf(&quot;File path: %s\n&quot;, filename); return 0; } ``` #### 输出: ``` File path: /msg_alarm_plan/shp_alarm_plan_1 ``` --- ### 解释: - `snprintf`:用于安全地将整数 `plan_id` 转换为字符串并拼接到路径后。 - `filename`:字符数组大小由 `ALARM_SCHEDULE_PATH_SIZE` 定义,确保能容纳完整的路径字符串。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值