sscanf造成的越界

这几天写代码的时候发现了一个错误,比较奇怪。

代码如下:

#include "stdio.h"
#include "stdlib.h"
#include "stdint.h"


int main()
{
	uint8_t a = 0;
	uint16_t b = 0;
	uint32_t c = 100;
	uint8_t buff[] = "1 2";
	sscanf(buff,"%d %d",&a,&b);
	printf("a = %d,b = %d,c = %d\r\n",a,b,c);
	
	return 0;
	
}

看起来大头上没有什么问题。
但是执行起来

a = 1,b = 2,c = 0

其实这个编译的时候已经报了这个问题,但是我们常常会忽视他。
在这里插入图片描述
说到底,就是每次sscanf一个%d的时候都是按照4个字节来赋值的。但是我们给的是一个uint8_t,一个字节,这样旁边的几个位就被污染了,从而导致数据就变了。

那咋整呢这玩意

sscanf(buff,"%hhd %hd",&a,&b);

hh for uint8_t
h foruint16_t

a = 1,b = 2,c = 100

ok

你可能感兴趣的:(linux,c)