- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
阅读本教程后
(https://www.tcpdump.org/pcap.html)
在最底部,作者将 u_char *packet
指针转换为结构。
这样的类型转换是不是这样的
假设我有这个结构
struct 16bits{
int8_t a;
int8_t b;
}
和一个16位的序列
0001 0011 0111 1111
如果我将它转换为 16 位结构,它会看起来像这样吗?
a = 0001 0011
b = 0111 1111
问题是我是否正确理解作者的转换。
我知道结构中的填充,但让我们认为编译器暂时不会添加它
最佳答案
Lets say I have this struct
struct 16bits{
int8_t a;
int8_t b;
}and a 16bit sequence
0001 0011 0111 1111
and if I cast it to 16bits struct it would look like this ?
a = 0001 0011
b = 0111 1111
我假设你的意思是这样的:
// this points at your 16-bit sequence
unsigned char *input_data = ...
struct 16bits *output_data = ( struct 16bits * ) input_data;
uint8_t a_bits = output_data->a;
uint8_t b_bits = output_data->b;
一般来说,不,你不能假设你能做到。一般来说,这将是 a strict aliasing violation和未定义的行为。 “严格的别名”规则基本上是说你不能把内存当作它不是的东西——但除了你每次总是可以访问任何一个 char
之外。 int
不是 float
。
此外,正如您提到的,结构中的字段之间可以有填充。
不过,在您的具体示例中,它几乎可以肯定在任何平台上“工作”,因为 int8_t
几乎可以肯定是 signed char
,所以几乎struct 16bits
中肯定没有填充,并且任何内存都可以作为 char
值访问。
不过,将 char
类型替换为 double
或 int64_t
类型,您可能会遇到对齐和填充问题。在某些平台上,这种严格的别名违规会导致代码失败并返回 SIGSEGV
或 SIGBUS
。
假设 8 位 char
值,所以 int8_t
实际上是一个 char
,这是一种完全符合标准的访问所应用的任何数据类型的方式到您的 16 位序列,因为两个 8 位值将是
// assume this points to your 16-bit sequence
unsigned char *input_data = ...
// create a structure that we can actually copy the bits into
struct 16bits output_data;
memcpy( &output_data, input_data, sizeof( output_data ) );
请注意,如果结构包含 char
类型以外的元素,则可能会进行填充。如果您使用 #pragma pack
之类的东西来消除填充,you can wind up with code that doesn't run on some platforms.
您提供的链接中的代码非常猖獗 - 它实际上是未定义的行为。但它“有效”,因为编写最流行的已发布代码的 x86 平台非常、非常、非常宽容未对齐的访问(尽管仍然存在性能损失)。但是这种类型的代码在任何有对齐要求的平台上根本无法正常工作。就Google pragma pack sigbus
例如,当在 x86 上运行良好的代码在 ARM 或 SPARC 平台上运行失败时,您会发现许多程序员感到惊讶的例子。
关于C libpcap API 将数据包转换为结构(令人困惑),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51380958/
我的程序像这样使用 libpcap: while pcaket = pcap_next() { ... (modify the pcaket and do checksum) ... pcap_sen
我正在为一个流量非常大的网络编写监控程序(高清视频通过网络流式传输)。大多数数据包都非常大,我只想查看 header (仅限 IP 和 UDP/TCP)。当然,我想避免复制整个数据的开销。 libpc
我对原始套接字和 libcap 的使用感到有点困惑。任何人都可以简单地指出使用两者的优点。我读了几个链接,但是,它让我感到困惑。 最佳答案 libpcap 在不同的操作系统上使用不同的机制。在 Lin
我在项目中看到了这种代码: while (1) { l_numPkts = pcap_next_ex( m_pcapHandle, &header, &pkt_data); //do some
我想使用 libpcap 使用 gcc 选项 -m32 将 .c 文件编译为 32 位可执行文件机器是linux 64位 fedora 16 但是,我收到以下错误 [root@fdf source]#
我只想从我的系统中嗅探传出的“TCP-ACK”数据包。因此,我在 lib-pcap 程序中将过滤器表达式设置为: char filter_exp[] = "src host 172.16.0.1 an
我正在尝试使用交叉编译器 arm-linux-gcc 编译 libpcap。当我运行“make”时出现错误: ./pcap-linux.c:254:14: conflicting types for
我正在编写相当简单的pcap“实时”捕获引擎,但是pcap_dispatch的数据包处理回调实现应花费相对较长的时间进行处理。 pcap是否在单独的线程中运行每个“pcap_handler”回调?如果
我正在使用 lib-pcap 库来安装/卸载过滤器。 为了安装 pcap 过滤器,我使用pcap_compile 后接 pcap_setfilter,效果很好。 对于卸载过滤器,我使用 pcap_fr
pcap_next 是否显示已发送的数据包? 例如:如果我在 libpcap 监听数据包时 ping google.com,然后运行 pcap_next 两次,返回的值将都是数据包,还是其中一个为
我正在尝试使用 libpcap 打印确认号。我确实知道我会得到与我在 pcap 文件中看到的不同的确认号。我的问题是,在 pcap 文件中,编号为 10、11 和 12 的数据包具有不同的 ack 编
我是 libpcap 的新手。 我正在使用这个库来捕获数据包,下面是我编写的捕获数据包的代码。 我正在窃听的接口(interface)总是充满arp数据包,因此总是有数据包到达该接口(interfac
使用 pcap,我声明了 rtp 结构,当我尝试指向数据包的这个区域时,我发现根据我的声明,它以不同的方式工作。 我写的是: struct udphdr *udp; struct rtphdr *rt
我想拦截来自用户空间的网络流量,所以我使用了 libpcap API 来捕获 tcp/ip 数据包。现在我只是在注册的回调中捕获有关数据包 header 和有效负载的信息。我如何使用此回调来阻止流量或
有人可以给我指出一个好的起点来了解 libpcap 如何从网络驱动程序获取数据包吗?我打算用快速实现替换接收函数。 最佳答案 “接收函数”是: 标准驱动程序接收函数,与用于接收数据包并将其交给常规网络
我用库 libpcap(Ubuntu, c) 捕获了信标帧 我将 wlan 模式更改为通过以下函数调用进行监控和捕获 // 3000 is large enough number for test p
我正在使用 libpcap 捕获特定端口上的所有数据包。但是我需要分开并清楚地知道我的设备正在发送哪些数据包,以及它正在接收哪些数据包。实际上,我使用 pcap_close() 来捕获数据包,而且效果
我正在尝试用 C 解析一个 pcap 文件。我不想使用 libpcap。但出于某种原因,我无法做到。你知道我该怎么做吗?这是我的尝试: fseek(f,24,0); while(countcaplen
我遇到了以下情况:我用 pcap_open_live() 打开我的网络接口(interface)之一。然后我正在为 pcap 编译一个过滤器,只捕获指定的以太网类型(ether proto 0x123
我正在尝试编写一个 c++ 应用程序 (linux) 来捕获无线数据包以及相关的信号强度(以 dBm 为单位)。捕获部分很简单,但问题是我找不到任何关于如何获取每个数据包信号强度的文档。 它是标题的一
我是一名优秀的程序员,十分优秀!