神奇的malloc

原创 2012年03月25日 16:42:47

引用请注明出处:http://blog.csdn.net/int64ago/article/details/7392374

#include <stdio.h>
#include <malloc.h>

void int2str(int int_in)
{
        char *str_out = (char *)malloc(sizeof(char));
        printf("%s\n", str_out);
        free(str_out);
}
int main()
{
        int num;
        scanf("%d", &num);
        int2str(num);
        return 0;
}

本来准备实现一个整数转换成字符串输出的,结果调试的过程中发现一个奇怪的现象,就是上面的代码也能实现功能!关键就在于,malloc的时候它并不会为你初始化而且恰好开的区域正是scanf输入的地方,于是就出现了输出什么就输出什么的怪现象了……不过还有一个疑问,为什么malloc的内存区域会在scanf的区域呢?是偶然?还是平台内存控制机制问题?

本人用的是linux+gcc平台,不方便多平台测试,希望其它平台的朋友测试后,告诉一声……继续研究malloc中……如果有新的进展会在此贴跟新!



又发现一个问题,当把输入整型改成double的时候,不全是输入什么就输出什么。比如:输入123.456输出123.456,但是输入-123.456则输出123.456,这时malloc为什么又不完全从scanf内存区开始呢?

bzoj1416&1498: [NOI2006]神奇的口袋

传送门 傻逼题。 直接计算方案数,除上总方案数就可以了。 注意要用高精度。 为啥oj上有两道题?#include #include #include #include #include #de...
  • zhouyuyang233
  • zhouyuyang233
  • 2017年04月29日 15:42
  • 235

一段神奇的代码

做一个优雅的程序员,好像是很多程序员的一大目标,何为优雅,如何优雅?下面是一段神奇的代码,什么编码风格,什么编程规范,统统丢到一边吧,化腐朽为神奇才是更加难能可贵的! #define M 0...
  • u011836061
  • u011836061
  • 2015年06月04日 12:55
  • 1096

百练2755 神奇的口袋 【深搜】or【动规】or【普通递归】or【递推】

总Time Limit:  10000ms  Memory Limit:  65536kB 有一个神奇的口袋,总的容积是40,用这个口袋可以变出一些物品,这些物品的总体积必须是...
  • u012846486
  • u012846486
  • 2014年07月19日 18:39
  • 1180

记一次问题解决历程——脚本的神奇功能

今天一个测试的同事问我,你对adb熟悉吗?我说简单的会。然后说adb reboot(手机重启指令)知道吧?我说知道的。然后她的问题是:能不能一直让手机执行重启命令:我想了下,用脚本应该是可以的。之前接...
  • Simon_Crystin
  • Simon_Crystin
  • 2017年04月01日 20:42
  • 603

noi2006神奇口袋

神奇的口袋,考数学甚于考算法,【考虑无自由取球情况,那么,设A(X,Y)为第x次,取出颜色为Y的球,P{A(1,Y1),A(2,Y2)…}=P{A(1,Y1),A(2,Y1),A(3,Y1)}因为首先...
  • huyuncong
  • huyuncong
  • 2012年02月15日 18:51
  • 1636

NOIP2015 神奇的幻方 解题报告(水题模拟)

在线评测: http://codevs.cn/problem/4510/ 整体思路: 枚举一的位置,然后模拟就行了 失误之处: 数据<39,然后,我就把记录上一个点的数组...
  • qq_35772697
  • qq_35772697
  • 2016年08月27日 13:43
  • 976

Poj 2755:神奇的口袋

总时间限制: 10000ms 内存限制: 65536kB 描述有一个神奇的口袋,总的容积是40,用这个口袋可以变出一些物品,这些物品的总体积必须是40。John现在有n个想要得到的物品,每个...
  • qq_34125999
  • qq_34125999
  • 2016年05月19日 21:34
  • 560

NOI 2006 - 神奇的口袋 Bag

题目描述:输入:输出:(样例略)今天有同学问到这道题,我记得很久以前做这道题时用很优美的方法证明了一下,但今天仔细一想,却又纠结了(当时可能是伪证)。然后,今天花了半个上午+一个下午+半个晚上在这道题...
  • gy_jk
  • gy_jk
  • 2010年06月10日 20:58
  • 1935

神奇的fans

#include #include //用于qsort整数排序的比较函数 int IntCmp(const void *a, const void *b); int main(void) { in...
  • baidu_23955875
  • baidu_23955875
  • 2014年12月08日 21:23
  • 317

一行神奇的 javascript 代码

(!(~+[])+{})[--[~+""][+[]]*[~+[]] + ~~!+[]]+({}+[])[[~!+[]]*~+[]] 运行这段代码,结果有点意外。 其实这主要是运用到了js的类型转换...
  • miffy2016
  • miffy2016
  • 2017年04月13日 16:02
  • 339
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:神奇的malloc
举报原因:
原因补充:

(最多只允许输入30个字)