浏览 3255 次
锁定老帖子 主题:丢人阿,居然在指针上犯了错误
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2008-07-06
虽然从未用c/c++正儿八经的写过东西,但我一直认为自己对c/c++的掌握还是很不错的,想不到还没正式使用就栽了跟头。 char *str = "Hello World"; size_t len = strlen(str); memset(str, 65 ,len); cout << str << endl; 结果总是报段错误,我以为是memeset函数的用法不对,我用的len太大了,导致访问了不该访问的内存,就把len改成了1,想不到还是报段错误。错了几次之后,我把代码改成了这样: char str[] = "Hello World"; size_t len = strlen(str); memset(str, 65 ,len); cout << str << endl; 想不到竟然可以了。 我一直以为char *str和char str[]是一样的,会一个正常运行,一个出错呢。没办法,google了一下,发现自己果然是学艺不精,原来char *str和char str[]的编译方式是不一样的。编译器会把char *str = "Hello World"这种形式中的Hello world放在常量区,把地址放在str,相当于const char *str = "Hello World",不能用str[3]这种方式修改。而对char str[] = "Hello World",编译器看成char str[] = {'H', 'e', 'l'...'\0'},各字符是放在栈上的,可以用str[]这样的形式修改。 终于弄清楚了,惭愧的很啊
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2008-07-06
刚从其他语言换到c时最容易出错误的就是字符串处理了
|
|
返回顶楼 | |
发表时间:2008-07-07
最头大的是用c来搞unicode这样的数组
|
|
返回顶楼 | |
发表时间:2008-09-05
指针即不简单又简单,看你的背景。要是你用汇编,指针对你来说简单。否则就难。
|
|
返回顶楼 | |
发表时间:2008-09-05
静态(全局)变量区 和 栈
|
|
返回顶楼 | |