记录一个bug -- sprintf

 #include<iostream>
 #include<stdio.h>
 int  main ()
 {
    char buf[10] = {0};
    sprintf(buf,"%02x",-3);
    printf("%s
",buf);
    char buf2[10] = {0};
    sprintf(buf2,"%02x",(unsigned char)-3);
    printf("%s
",buf2);
     return 1 ;
 }

这是在云风的博客上看到的,

前者输出ffffffd

后者输出fd

如果前者的buf空间小一点就会溢出

原文地址:https://www.cnblogs.com/zsb517/p/3560039.html