博客
关于我
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中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>