OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 2732|回复: 12

C语言指针一问

[复制链接]

11

主题

28

帖子

0

精华

初级会员

Rank: 2

积分
128
金钱
128
注册时间
2017-8-28
在线时间
39 小时
发表于 2018-2-23 16:03:04 | 显示全部楼层 |阅读模式
1金钱
本帖最后由 foodyou 于 2018-2-23 16:17 编辑

[mw_shl_code=c,true]#include <stdio.h>

unsigned char buff[20];
unsigned char len = 3;


void set(void){

buff[0] = 0xaa;
buff[1] = 0xbb;
buff[2] = 0xcc;

}


void func(unsigned char *buff, unsigned char len){
   
    while(len--){
        printf("%u", *buff++);
        printf(",");
    }
}


unsigned char i = 0;

void func2(void){
   
    while(i < 3){
        printf("%u", i++);
        printf(",");
    }
}


int main(void) {
    set();

        func(buff, len);
        printf("%u", *buff);
        printf("---");
        func2();
        printf("%u", i);
}[/mw_shl_code]


请问各位,为什么普通变量,在循环内进行加1运算,运算结果会在循环外保留;但是指针的话就不会呢?
可能这样我表达得不太清楚,就像代码里面的i,在循环内不断加1,然后完成循环当时的i值是3,循环外输出i值也是3;
但是指针的话,当时的指针的值应该是*buff+3,但是当到了循环外输出*buff的时候,就输出了*buff的最初值,就是循环的计算结果没有保留下来,为什么会这样呢?

最佳答案

查看完整内容[请看2#楼]

func的buff参数是拷贝传参,其生命周期存活到func结束,func中的buff并不是全局的buff[20], 所谓的拷贝传参,简单的说,就是函数内部在使用参数的时候,将参数重新拷贝一份来使用。 关于这个问题,给你出个练习题:设计一个函数,函数的功能就是交换两个数的数值。要求传参,自行设计函数签名。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

33

主题

984

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8024
金钱
8024
注册时间
2014-8-13
在线时间
1595 小时
发表于 2018-2-23 16:03:05 | 显示全部楼层
func的buff参数是拷贝传参,其生命周期存活到func结束,func中的buff并不是全局的buff[20],
所谓的拷贝传参,简单的说,就是函数内部在使用参数的时候,将参数重新拷贝一份来使用。

关于这个问题,给你出个练习题:设计一个函数,函数的功能就是交换两个数的数值。要求传参,自行设计函数签名。
回复

使用道具 举报

0

主题

64

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
249
金钱
249
注册时间
2018-1-19
在线时间
28 小时
发表于 2018-2-23 18:01:44 | 显示全部楼层
你程序的目的是干什么的?   func执行完了   就执行下面的语句啊  指针重新指向了初值把
回复

使用道具 举报

11

主题

28

帖子

0

精华

初级会员

Rank: 2

积分
128
金钱
128
注册时间
2017-8-28
在线时间
39 小时
 楼主| 发表于 2018-2-23 20:01:37 | 显示全部楼层
暂时还在学习中,只是随便写个测试程序,就是感觉好像C的有些运算,在处理指针和处理普通变量有点不一致,所以想问问了解一下
回复

使用道具 举报

7

主题

333

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1838
金钱
1838
注册时间
2012-7-16
在线时间
504 小时
发表于 2018-2-23 22:02:58 | 显示全部楼层
你这样对指针有点不太公平,i是个全局变量而buff是作为形参传递到函数里的。
回复

使用道具 举报

7

主题

333

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1838
金钱
1838
注册时间
2012-7-16
在线时间
504 小时
发表于 2018-2-23 22:03:44 | 显示全部楼层
你定义个全局*p=buff,再让p++试试看。
回复

使用道具 举报

7

主题

14

帖子

0

精华

初级会员

Rank: 2

积分
87
金钱
87
注册时间
2017-7-10
在线时间
11 小时
发表于 2018-2-23 23:10:00 | 显示全部楼层
我认为是++i与i++的区别。
回复

使用道具 举报

11

主题

28

帖子

0

精华

初级会员

Rank: 2

积分
128
金钱
128
注册时间
2017-8-28
在线时间
39 小时
 楼主| 发表于 2018-2-23 23:58:07 | 显示全部楼层
hyghyg1234 发表于 2018-2-23 22:02
你这样对指针有点不太公平,i是个全局变量而buff是作为形参传递到函数里的。

这个我觉得奇怪了,因为我单纯以为传入一个指针,函数内可以通这个指针过修改到函数外的变量的数值的,就例如下面的代码,为什么将数组当成指针就不行了呢?

[mw_shl_code=c,true]#include <stdio.h>

unsigned char i = 0;


void func(unsigned char *i){
     *i = 1;
}

int main(void) {
    func(&i);
    printf("%u", i);
}[/mw_shl_code]
回复

使用道具 举报

11

主题

28

帖子

0

精华

初级会员

Rank: 2

积分
128
金钱
128
注册时间
2017-8-28
在线时间
39 小时
 楼主| 发表于 2018-2-24 00:07:57 | 显示全部楼层
这个我或者有点头绪了,不知道对不对,是因为 *p++ 实际上执行的运算是 *(p++), 在函数内自增的不是 *p的值,而是 p 的值 。。。
回复

使用道具 举报

24

主题

695

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1666
金钱
1666
注册时间
2016-4-29
在线时间
266 小时
发表于 2018-2-24 10:06:37 | 显示全部楼层
看看  *buff++ 是什么意思,
还有,形参名与全局变量名不要写成一样的,buff是一个全局数组名,同时还是func的一个形参
回复

使用道具 举报

27

主题

195

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
232
金钱
232
注册时间
2016-8-31
在线时间
252 小时
发表于 2018-2-24 14:02:52 | 显示全部楼层
你没搞明白形参实参的问题,10楼说的对
回复

使用道具 举报

11

主题

28

帖子

0

精华

初级会员

Rank: 2

积分
128
金钱
128
注册时间
2017-8-28
在线时间
39 小时
 楼主| 发表于 2018-2-24 15:54:50 | 显示全部楼层
本帖最后由 foodyou 于 2018-2-24 16:44 编辑

拷贝传参这个我知道,意思就是函数内的值是一份副本吧,如果函数外声明一个值 i, 然后把这个 i 传入函数, 分别在函数外和函数内对 i 寻址, 这样会得出2个不同的地址,这个可以很清楚知道这2个 i 实际上是两个不同的东西,虽然数值相同,但是在内存里面实际上是不同的。
但是我不明白的是,现在我把数组传入函数,我在函数外和函数内分别对这个数组寻址,地址是一样的呀(还是我代码写错了?各位帮忙看一下),所以我才觉得不是形参的问题,还是形参的概念上面还有其他方面的描述我不知道。。。

[mw_shl_code=c,true]#include <stdio.h>

unsigned char buff[20];
unsigned char len = 3;


void set(void){

buff[0] = 0xaa;
buff[1] = 0xbb;
buff[2] = 0xcc;

}


void func(unsigned char *buff, unsigned char len){
   
    printf("%p", buff);
    printf("---");
     
    while(len--){
        printf("%u", *buff++);
        printf(",");
    }
   
   
}


unsigned char i = 0;

void func2(unsigned char i){
    printf("%p", &i);
}


int main(void) {
    set();

    func(buff, len);
    //printf("---");
    printf("%p", buff);
    printf("---");
    printf("%u", *buff);
   
   
    //--------------------------
   
    printf("===");
    printf("%p", &i);
    printf("---");
    func2(i);
}[/mw_shl_code]

还是因为我把形参名和全局变量名都写成一样有时把自己也搞混了 。。。我再试试 。。。
如果我把中间func那个函数中的形参改成 buff1,这样就很清楚buff 和 buff1 是不同的指针,他们只是指向内存里面相同的地址。。。
哈,或者是我对指针这个东西理解不够充分 。。。或者这个问题奇怪的地方应该在于,如果我对一个指针寻址,应该得到的是指针的地址,但是现在我对一个因为传入函数,由数组变成指针的指针寻址,得出的竟然是原来数组的地址,而不是形参指针的地址 。。。
回复

使用道具 举报

11

主题

28

帖子

0

精华

初级会员

Rank: 2

积分
128
金钱
128
注册时间
2017-8-28
在线时间
39 小时
 楼主| 发表于 2018-2-24 17:09:43 | 显示全部楼层
哈,我又写了一段小代码,现在可以比较清楚发现问题了,可能有时候我把“指针指向的地址”和“指针本身的地址”这2个概念搞混了 。。。


[mw_shl_code=c,true]#include <stdio.h>

int i = 0;
int *j = &i;

void func(int *k){
    printf("%p", k);
}

void func2(int *k){
    printf("%p", &k);
}

int main(void) {

        printf("%p", j);
        printf("---");
        func(j);
        printf("---");
        func2(j);
}[/mw_shl_code]
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-8 10:11

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表