博客
关于我
C代码开发遇到的问题 变量初始化和结构体指针移动
阅读量:798 次
发布时间:2023-04-16

本文共 773 字,大约阅读时间需要 2 分钟。

1. 变量初始化

在C语言中,未被明确初始化的无符号整型变量不会自动设置为0,而是会随机赋值。这种行为可以导致程序运行结果不一致,特别是在循环或条件判断中可能引发意外错误。

例如:

#include 
void PrintUint() { unsigned int i; if (i != 0) { printf("i = %u \r\n", i); } return;}void main() { unsigned int i, j; printf("start test : \r\n"); for(j = 0; j < 5; j++) { PrintUint(); return; }}

每次运行PrintUint()可能会输出不同的随机值。


2. 结构体指针移动

在内核网络处理中,结构体指针的移动需要特别注意。假设有多个数据块连续存储,当从一个数据块的指针移动到相邻的下一个数据块时,只需要将指针加1即可,而无需加上整个结构体的大小。这是因为结构体指针的单位已经是基于结构体大小划分的。

例如,在处理网络报文结构体skb时:

struct iphdr *iph = ip_hdr(skb);struct udphdr *udph = iph + 1;  /* 正确操作 */

而错误的做法是:

struct iphdr *iph = ip_hdr(skb);struct udphdr *udph = iph + sizeof(struct iphdr);  /* 错误操作 */

通过这种方式,可以快速获取下一个数据块的指针,而无需计算每个结构体的具体大小。这样的操作在内核网络处理中非常常见,也反映了对C语言基础的深刻理解。

转载地址:http://nbgfk.baihongyu.com/

你可能感兴趣的文章
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>
mysql中的rbs,SharePoint RBS:即使启用了RBS,内容数据库也在不断增长
查看>>
mysql中的undo log、redo log 、binlog大致概要
查看>>
Mysql中的using
查看>>
MySQL中的关键字深入比较:UNION vs UNION ALL
查看>>
mysql中的四大运算符种类汇总20多项,用了三天三夜来整理的,还不赶快收藏
查看>>
mysql中的字段如何选择合适的数据类型呢?
查看>>
MySQL中的字符集陷阱:为何避免使用UTF-8
查看>>
mysql中的数据导入与导出
查看>>
MySQL中的时间函数
查看>>
mysql中的约束
查看>>
MySQL中的表是什么?
查看>>
mysql中穿件函数时候delimiter的用法
查看>>
Mysql中索引的分类、增删改查与存储引擎对应关系
查看>>
Mysql中索引的最左前缀原则图文剖析(全)
查看>>
MySql中给视图添加注释怎么添加_默认不支持_可以这样取巧---MySql工作笔记002
查看>>
Mysql中获取所有表名以及表名带时间字符串使用BetweenAnd筛选区间范围
查看>>
Mysql中视图的使用以及常见运算符的使用示例和优先级
查看>>
Mysql中触发器的使用示例
查看>>
Mysql中设置只允许指定ip能连接访问(可视化工具的方式)
查看>>