| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1006 人关注过本帖, 1 人收藏
标题:一道内存寻址的题
取消只看楼主 加入收藏
hahayezhe
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖南张家界
等 级:贵宾
威 望:24
帖 子:1386
专家分:6999
注 册:2010-3-8
结帖率:100%
收藏(1)
已结贴  问题点数:50 回复次数:5 
一道内存寻址的题
void sort();
int main()
{
   int a[] = {2,5,29,90,34,45,47};
   sort();
   return 0;
}
void sort()
{  
}
在sort()里面实现对数组a的排序(只能在sort()里面操作)
已经做出来了
但是感觉过于暴力 不合法
void sort();
int main()
{
    int a[] = {2,5,29,90,34,45,47};
    sort();
        return 0;
}

void sort()
{
    int b[7];
    int x=1;
    while (1)//寻找a[0]的首地址
    {
        if(*(b+x)==2)
        {
            printf("%d\n",x);
            break;
        }
        x++;
    }
    int c;
    for(int i=0;i<7;i++)
    {
       for (int j=i+1;j<7;j++)
       {
           if(*(b+x+i)>*(b+x+j))
           {
               c=*(b+x+i);
               *(b+x+i) = *(b+x+j);
               *(b+x+j) = c;

           }
       }
    }
    for (int i=0;i<7;i++)
    {
        printf("%d\n",*(b+x+i));
    }

}
期待更好的解决方法
搜索更多相关主题的帖子: 内存 寻址 
2010-05-04 16:20
hahayezhe
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖南张家界
等 级:贵宾
威 望:24
帖 子:1386
专家分:6999
注 册:2010-3-8
收藏
得分:0 
以下是引用rib在2010-5-4 16:23:52的发言:

这样会不会找到错误的地址?
不知道 地址是随着数组的维数而变化

很想知道编译器数组存储,内存分配的规律

但是资料没有找到好的
2010-05-04 16:27
hahayezhe
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖南张家界
等 级:贵宾
威 望:24
帖 子:1386
专家分:6999
注 册:2010-3-8
收藏
得分:0 
回复 4楼 mywaylgh
那段内存空间已经划分给了 编译器 所以 系统应该是不会调用的吧
2010-05-04 16:51
hahayezhe
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖南张家界
等 级:贵宾
威 望:24
帖 子:1386
专家分:6999
注 册:2010-3-8
收藏
得分:0 
其实 我就是想知道 主函数和 子函数之间的内存跨度是多少字节
是固定的 字节么? 很好奇
void sort();
int main()
{
    char *p;
    printf("&p=%d\n",&p);
    sort();
}

void sort()
{
    char *p;   
    printf("&p=%d\n",&p);
}
两者相距为 776 字节;将char换成其他的也一样
2010-05-04 16:58
hahayezhe
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖南张家界
等 级:贵宾
威 望:24
帖 子:1386
专家分:6999
注 册:2010-3-8
收藏
得分:0 
程序代码:
void sort();
int main()
{
    char *p;
    printf("外部&p=%d\n",&p);
    {
        char *p;
        printf("局部&p=%d\n",&p);
        {
            char *p;
        printf("局部&p=%d\n",&p);
        }
    }
    sort();
}

void sort()
{
    char *p;   
    printf("&p=%d\n",&p);
}
图片附件: 游客没有浏览图片的权限,请 登录注册

很有意思耶 有达人解答下么?
2010-05-04 17:02
hahayezhe
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖南张家界
等 级:贵宾
威 望:24
帖 子:1386
专家分:6999
注 册:2010-3-8
收藏
得分:0 
回复 8楼 Devil_W
没有用过gdb
windows都还没掌握呢 liunx还很遥远
2010-05-04 17:11
快速回复:一道内存寻址的题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.013180 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved