sinat_24243075 2015-05-17 12:40 采纳率: 50%
浏览 1350
已采纳

缓冲溢出代码缝分析!!

#include
#include
#include
#include

const char card[] = "IDB_CARD_";

const char *card_4[] = { "SWORD_", "WAND_", "PENT_", "CUP_" };

const char *card_royal[] = { "KING", "KNAVE", "QUEEN", "KNIGHT" };

char *point_to_card[78] = { NULL };

int sort[78] = { 0 };//the card's sorting

int main()//this is a model to get name in dll ,it's ok
{
char current_name[20] = "0", num[2] = "0";
int count = 0, big_count = 0, card_count = 0;

int i;
strcpy(current_name, card);
for (big_count = 1; big_count <= 5; big_count++)
{
    if (big_count == 1)
    {
        for (count = 0; count <= 21; count++)
        {
            itoa(count, num, 10);
            strcat(current_name, num);
            point_to_card[card_count] = (char*)malloc(sizeof(char)*strlen(current_name));
            strcpy(point_to_card[card_count], current_name);
            strcpy(current_name, card);
            card_count++;
        }
    }
    else{
        for (count = 1; count <= 14; count++)
        {
            if (count <= 10)
            {
                strcat(current_name, card_4[big_count - 2]);
                itoa(count, num, 10);
                strcat(current_name, num);
                point_to_card[card_count] = (char*)malloc(sizeof(char)*strlen(current_name));
                strcpy(point_to_card[card_count], current_name);
                strcpy(current_name, card);
                card_count++;
            }

            else
            {
                strcat(current_name, card_4[big_count - 2]);
                strcat(current_name, card_royal[count - 11]);
                point_to_card[card_count] = (char*)malloc(sizeof(char)*strlen(current_name));
                strcpy(point_to_card[card_count], current_name);
                strcpy(current_name, card);
                card_count++;
            }
        }
    }
}

}
调试时会出现图片说明

  • 写回答

2条回答 默认 最新

  • Tiger_Zhao 2015-05-18 05:36
    关注

    num[2] 大小不够。
    内容("0"~"21")最多2个字符,字符串结束符 \0 在哪里?
    不就溢出了!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 很想要一个很好的答案或提示
  • ¥15 扫描项目中发现AndroidOS.Agent、Android/SmsThief.LI!tr
  • ¥15 怀疑手机被监控,请问怎么解决和防止
  • ¥15 Qt下使用tcp获取数据的详细操作
  • ¥15 idea右下角设置编码是灰色的
  • ¥15 全志H618ROM新增分区
  • ¥15 在grasshopper里DrawViewportWires更改预览后,禁用电池仍然显示
  • ¥15 NAO机器人的录音程序保存问题
  • ¥15 C#读写EXCEL文件,不同编译
  • ¥15 MapReduce结果输出到HBase,一直连接不上MySQL