读书人

新手指针有关问题一个小例子不通过。

发布时间: 2012-05-15 14:35:29 作者: rapoo

新手指针问题,一个小例子不通过。。。
我是C新手写个小例子向大家请教。
环境Cygwin+Netbeans
一个函数两个参数录入一个字符串,另一个是带查找字符串。如果没有返回NULL,如果找到返回这个字符的指针。
例如:“ADGCGH”,“KLL”返回NULL;“ABCDE”“KCT”返回C的指针。

ABCDE,SJKL
char *find_char(char const *source,char const *chars){
char c = '\0';
char s = '\0';
while( (c = *chars++) != '\0'){
//printf("%c",c);
while( (s = *source++) != '\0'){
if (c == s) {
printf("%c",s); 这里返回“L” 为什么?
}
}
s = '\0';
printf("\n");
}
return NULL;
}

第二个问题,h文件中定义了一些函数,c中实现了。
main中没有调用这些函数,为什么从打印结果上看是自动调用了这些函数?

[解决办法]
VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习汇编以及C和汇编的对应关系。
从汇编的角度理解和学习C语言的指针,原本看似复杂的东西就会变得非常简单!
指针即地址。“地址又是啥?”“只能从汇编语言和计算机组成原理的角度去解释了。”

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

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

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

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

[解决办法]
逻辑就不对,这个功能是C库函数strtok的功能。须要自己实现?
你包含了头文件这些编译时都能找到。

C/C++ code
char *find_char(char const *source,char const *chars){{    char *cp;    while('\0' != *source){        cp = chars;        while(*cp){            if(*cp++ == *source) return source;        }        ++source;    }    return NULL;}
[解决办法]
探讨

逻辑就不对,这个功能是C库函数strtok的功能。须要自己实现?
你包含了头文件这些编译时都能找到。
C/C++ code
char *find_char(char const *source,char const *chars){
{
char *cp;
while('\0' != *source){
cp = chars;
while(*……

[解决办法]
上面说的很好啊
[解决办法]
探讨

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

[解决办法]
C/C++ code
#include <stdio.h>char *find_char(char const *source,char const *chars){   char c = '\0';   char s = '\0';   const char *pString = source;//here   while( (c = *chars++) != '\0')   {         while( (s = *source++) != '\0')         {             if (c == s)             {                printf("%c",s);// 这里返回“L” 为什么?                }        }        s = '\0';        source = pString;//here,当外层while循环时,如果之前不把source值保存下来,那么source再自加就完全越界了        printf("\n");   }   return NULL;}//我在你的基础上修改成为如下版本/*char *find_char(char const *source,char const *chars){    size_t i = 0, j = 0;    while(*(chars + i))    {        while(*(source + j))        {            if (*(chars + i) == *(source + j))            {                printf("%c",*(source + j));// 这里返回“L” 为什么?               }            ++j;        }        ++i;        j = 0;        printf("\n");    }    return NULL;}*/int main(){    char source[] = "ADGCGH";    char chars[] = "KCT";    find_char(source, chars);} 

读书人网 >C语言

热点推荐