字符串指针作为函数参数的问题

时间:2023-01-07 16:27:53
int point_test(char *buff)
{
buff = "hello word!";

return 0;
}

int main()
{
        char *str_name = Null;
point_test(str_name);
printf("point_test-str_name:%s\n", str_name);

        return 0;

}

为何str_name打印出来啥都没有?望大家指点。

19 个解决方案

#1



我是这样理解的(仅供参考);
起初指向char类型的指针str_name为空,当把str_name传递给指针参数buff时,
相当与指针buff也为空。然后函数体里面将buff指向字符串常量,但这并没有改变
str_name的值。所以函数调用完以后str_name的值还是NULL;

#2



#include<stdio.h>
#include<stdlib.h>

int point_test(char **buff)
{
*buff = "hello word!";

return 0;
}

int main()
{
        char *str_name ;
point_test(&str_name);
printf("point_test-str_name:%s\n", str_name);

        return 0;

}

#3


刚开始,str_name指向NULL,然后调用point_test,buff也指向NULL,
再然后,buff指向了"hello world!",但是str_name还是指向NULL。
上述描述的就是C中一切都是传值的意思。

要达到你想要的效果,就得传“指针”,既然这里要修改的是指针,所以要传的是“指针的指针”。如下:

# include <stdio.h>

int point_test(char ** buff) // 注意这里
{
    *buff = "hello world!"; // 注意这里
    return 0;
}

int main()
{
    char * str_name = NULL;
    point_test(&str_name); // 注意这里
    printf("%s\n", str_name);

    return 0;
}


推荐用debugger跟踪整个程序,深入理解指针,指针指向的对象,函数调用传值。

#4


函数传参的实质都是传值,你可以用引用
int point_test(char *buff)改成int point_test(char *&buff)

#5


引用 2 楼 gaohuaid 的回复:
C/C++ code?1234567891011121314151617181920#include<stdio.h>#include<stdlib.h> int point_test(char **buff){*buff = "hello word!"; return 0;} int main(){        char *str_name ;point_test(&……

额,str_name应该是指向char,它的值为NULL吧??
或者说它是个NULL指针吧?

#6


首先,你在int point_test(char *buff)中根本就没有申请空间,我想你那里应该有错误吧。再者,即使你在这个函数中申请了空间,但是传进来的字符指针,是按值传递,也就是在这个函数中,buff为str_name的一个拷贝,buff中有值了,但并没有影响str_name中的值,所以str_name是空的,你可以传递地址的地址,即指针的指针作为参数

#7


函数传参的实质都是传值

林锐 《高质量c/c++编程》

#8


我想。。。
你在主函数里只是声明了一个空指针,并没有给他分配过内存;
将它传入到函数 point_test后,将它指向了一个字符串,但这个字符串所在的内存在 point_test函数执行完后就就被释放了。。。然后就打印不出值了
。。

#9


代码还比较短,要是长了,这样看着真dt,难道都不知道编辑框旁边有个插入代码的功能吗? 字符串指针作为函数参数的问题

#10


指针的地址和指针所指向内容的地址你还没完全明白

#11


#include <stdio.h>

int point_test(char *&buff)
{
buff = "hello word!";
return 0;
}

int main()
{
char *str_name = 0;
point_test(str_name);
printf("point_test-str_name:%s\n", str_name);

return 0;
}

#12


# include <stdio.h>
 
int point_test(char * buff) // 注意这里
{
   char *buff1 = "hello world!"; // 注意这里  
   buff = buff1; // 注意这里
    return 0;
}
 
int main()
{
    char * str_name = NULL;
    point_test(str_name); // 注意这里
    printf("%s\n", str_name);
 
    return 0;
}

#13


计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构……

对学习编程者的忠告:
眼过千遍不如手过一遍!
书看千行不如手敲一行!
手敲千行不如单步一行!
单步源代码千行不如单步对应汇编一行!

VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)

想要从本质上理解C指针,必须学习汇编以及C和汇编的对应关系。
从汇编的角度理解和学习C语言的指针,原本看似复杂的东西就会变得非常简单!
指针即地址。“地址又是啥?”“只能从汇编语言和计算机组成原理的角度去解释了。”
但我又不得不承认:
 有那么些人喜欢或者适合用“先具体再抽象”的方法学习和理解复杂事物;
 而另一些人喜欢或者适合用“先抽象再具体”的方法学习和理解复杂事物。
而我本人属前者。

这辈子不看内存地址和内存值;只画链表、指针示意图,画堆栈示意图,画各种示意图,甚至自己没画过而只看过书上的图……能从本质上理解指针、理解函数参数传递吗?本人深表怀疑!
这辈子不种麦不收麦不将麦粒拿去磨面;只吃馒头、吃面条、吃面包、……甚至从没看过别人怎么蒸馒头,压面条,烤面包,……能从本质上理解面粉、理解面食吗?本人深表怀疑!!

提醒:
“学习用汇编语言写程序”

“VC调试(TC或BC用TD调试)时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习C和汇编的对应关系。”
不是一回事!

不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!

有人说一套做一套,你相信他说的还是相信他做的?
其实严格来说这个世界上古往今来所有人都是说一套做一套,不是吗?

不要写连自己也预测不了结果的代码!

电脑内存或文件内容只是一个一维二进制字节数组及其对应的二进制地址;
人脑才将电脑内存或文件内容中的这个一维二进制字节数组及其对应的二进制地址的某些部分看成是整数、有符号数/无符号数、浮点数、复数、英文字母、阿拉伯数字、中文/韩文/法文……字符/字符串、汇编指令、函数、函数参数、堆、栈、数组、指针、数组指针、指针数组、数组的数组、指针的指针、二维数组、字符点阵、字符笔画的坐标、黑白二值图片、灰度图片、彩色图片、录音、视频、指纹信息、身份证信息……

十字链表交换任意两个节点C源代码(C指针应用终极挑战) http://download.csdn.net/detail/zhao4zhong1/5532495

#14


没理解什么是针,以及没理解C语言中的字符串。

#15


char * change( char **s)
{
*s = "hello world!" ;
return *s;
}
char *s = "say" ;
cout<< change(&s) ;

"say"找不到了,这样算不算内存泄漏??

#16


这个是编程的基础,也是重点

#17


这与函数传参方式有关,如果是C语言,则需要传递指向指针的指针,如果是C++,则还可以传递指针的引用。

#18


参数传的是副本,当参数是指针时,LZ你就理解错了

#19


http://bbs.csdn.net/topics/350206749

我的函数参数传递大总结帖,一看就了 字符串指针作为函数参数的问题

#1



我是这样理解的(仅供参考);
起初指向char类型的指针str_name为空,当把str_name传递给指针参数buff时,
相当与指针buff也为空。然后函数体里面将buff指向字符串常量,但这并没有改变
str_name的值。所以函数调用完以后str_name的值还是NULL;

#2



#include<stdio.h>
#include<stdlib.h>

int point_test(char **buff)
{
*buff = "hello word!";

return 0;
}

int main()
{
        char *str_name ;
point_test(&str_name);
printf("point_test-str_name:%s\n", str_name);

        return 0;

}

#3


刚开始,str_name指向NULL,然后调用point_test,buff也指向NULL,
再然后,buff指向了"hello world!",但是str_name还是指向NULL。
上述描述的就是C中一切都是传值的意思。

要达到你想要的效果,就得传“指针”,既然这里要修改的是指针,所以要传的是“指针的指针”。如下:

# include <stdio.h>

int point_test(char ** buff) // 注意这里
{
    *buff = "hello world!"; // 注意这里
    return 0;
}

int main()
{
    char * str_name = NULL;
    point_test(&str_name); // 注意这里
    printf("%s\n", str_name);

    return 0;
}


推荐用debugger跟踪整个程序,深入理解指针,指针指向的对象,函数调用传值。

#4


函数传参的实质都是传值,你可以用引用
int point_test(char *buff)改成int point_test(char *&buff)

#5


引用 2 楼 gaohuaid 的回复:
C/C++ code?1234567891011121314151617181920#include<stdio.h>#include<stdlib.h> int point_test(char **buff){*buff = "hello word!"; return 0;} int main(){        char *str_name ;point_test(&……

额,str_name应该是指向char,它的值为NULL吧??
或者说它是个NULL指针吧?

#6


首先,你在int point_test(char *buff)中根本就没有申请空间,我想你那里应该有错误吧。再者,即使你在这个函数中申请了空间,但是传进来的字符指针,是按值传递,也就是在这个函数中,buff为str_name的一个拷贝,buff中有值了,但并没有影响str_name中的值,所以str_name是空的,你可以传递地址的地址,即指针的指针作为参数

#7


函数传参的实质都是传值

林锐 《高质量c/c++编程》

#8


我想。。。
你在主函数里只是声明了一个空指针,并没有给他分配过内存;
将它传入到函数 point_test后,将它指向了一个字符串,但这个字符串所在的内存在 point_test函数执行完后就就被释放了。。。然后就打印不出值了
。。

#9


代码还比较短,要是长了,这样看着真dt,难道都不知道编辑框旁边有个插入代码的功能吗? 字符串指针作为函数参数的问题

#10


指针的地址和指针所指向内容的地址你还没完全明白

#11


#include <stdio.h>

int point_test(char *&buff)
{
buff = "hello word!";
return 0;
}

int main()
{
char *str_name = 0;
point_test(str_name);
printf("point_test-str_name:%s\n", str_name);

return 0;
}

#12


# include <stdio.h>
 
int point_test(char * buff) // 注意这里
{
   char *buff1 = "hello world!"; // 注意这里  
   buff = buff1; // 注意这里
    return 0;
}
 
int main()
{
    char * str_name = NULL;
    point_test(str_name); // 注意这里
    printf("%s\n", str_name);
 
    return 0;
}

#13


计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构……

对学习编程者的忠告:
眼过千遍不如手过一遍!
书看千行不如手敲一行!
手敲千行不如单步一行!
单步源代码千行不如单步对应汇编一行!

VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)

想要从本质上理解C指针,必须学习汇编以及C和汇编的对应关系。
从汇编的角度理解和学习C语言的指针,原本看似复杂的东西就会变得非常简单!
指针即地址。“地址又是啥?”“只能从汇编语言和计算机组成原理的角度去解释了。”
但我又不得不承认:
 有那么些人喜欢或者适合用“先具体再抽象”的方法学习和理解复杂事物;
 而另一些人喜欢或者适合用“先抽象再具体”的方法学习和理解复杂事物。
而我本人属前者。

这辈子不看内存地址和内存值;只画链表、指针示意图,画堆栈示意图,画各种示意图,甚至自己没画过而只看过书上的图……能从本质上理解指针、理解函数参数传递吗?本人深表怀疑!
这辈子不种麦不收麦不将麦粒拿去磨面;只吃馒头、吃面条、吃面包、……甚至从没看过别人怎么蒸馒头,压面条,烤面包,……能从本质上理解面粉、理解面食吗?本人深表怀疑!!

提醒:
“学习用汇编语言写程序”

“VC调试(TC或BC用TD调试)时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习C和汇编的对应关系。”
不是一回事!

不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!

有人说一套做一套,你相信他说的还是相信他做的?
其实严格来说这个世界上古往今来所有人都是说一套做一套,不是吗?

不要写连自己也预测不了结果的代码!

电脑内存或文件内容只是一个一维二进制字节数组及其对应的二进制地址;
人脑才将电脑内存或文件内容中的这个一维二进制字节数组及其对应的二进制地址的某些部分看成是整数、有符号数/无符号数、浮点数、复数、英文字母、阿拉伯数字、中文/韩文/法文……字符/字符串、汇编指令、函数、函数参数、堆、栈、数组、指针、数组指针、指针数组、数组的数组、指针的指针、二维数组、字符点阵、字符笔画的坐标、黑白二值图片、灰度图片、彩色图片、录音、视频、指纹信息、身份证信息……

十字链表交换任意两个节点C源代码(C指针应用终极挑战) http://download.csdn.net/detail/zhao4zhong1/5532495

#14


没理解什么是针,以及没理解C语言中的字符串。

#15


char * change( char **s)
{
*s = "hello world!" ;
return *s;
}
char *s = "say" ;
cout<< change(&s) ;

"say"找不到了,这样算不算内存泄漏??

#16


这个是编程的基础,也是重点

#17


这与函数传参方式有关,如果是C语言,则需要传递指向指针的指针,如果是C++,则还可以传递指针的引用。

#18


参数传的是副本,当参数是指针时,LZ你就理解错了

#19


http://bbs.csdn.net/topics/350206749

我的函数参数传递大总结帖,一看就了 字符串指针作为函数参数的问题

#20