这位博主:http://blog.csdn.net/chgaowei/archive/2009/10/27/4731498.aspx提出了读S 计划- C 方向项目详细计划
给出了关于C语言的很多知识点。我觉得很有意思,于是自己做了一下,当然也从网上借鉴了不少。
C语言深入学习--checklist(1)字符串、数组、结构体:
字符串
1. strlen()函数的返回值是什么类型的? Size_t size_t的定义:<stddef.h>
typedef unsigned int size_t
2. 字符串strlen() 的值,是否和他占据的内存空间相同?
不想同,字符串最后一个为’/0’,但是strlen()结果不包含’/0’;
例如定义char buf[] = “hello”, 则strlen(buf)的值是5,占据6个字节大小。但要注意,如果定义char buf[5] = "hello";,则调用strlen(buf)是危险的,会造成数组访问越界。
3. 你是否知道strcpy 函数存在的潜在风险?如何避免?
Char *Strcpy(char *dest, const char *src):作用:src所指向的字符串拷贝到dest所指向的内存空间。注意的问题是,strcpy只知道src字符串的首地址,不知道长度,它会一直拷贝到'/0'为止,所以dest所指向的内存空间要足够大,否则有可能写越界。
风险之一是就是string2的长度比string1长的话,string1就不会包含’/0’。没有结束符号会在以后使用中带来很大的问题。
可以增加一个判断
Strcpy的实现:
替代:char strncpy(char *dest,const char *src, size_t n
)strncpy的参数n指定最多从src中拷贝n个字节到dest中,换句话说,如果拷贝到'/0'就结束,如果拷贝到n个字节还没有碰到'/0',那么也结束,调用者负责提供适当的n值,以确保读写不会越界,比如让n的值等于dest所指向的内存空间的大小:
这意味着dest有可能不是以'/0'结尾的。例如上面的调用,虽然把"hello world"截断到10个字符拷贝至buf中,但buf不是以'/0'结尾的,如果再printf(buf)就会读越界。如果你需要确保dest以'/0'结束,可以这么调用
srncpy还有一个特性,如果src字符串全部拷完了不足n个字节,那么还差多少个字节就补多少个'/0',但是正如上面所述,这并不保证dest一定以'/0'结束,当src字符串的长度大于n时,不但不补多余的'/0',连字符串的结尾'/0'也不拷贝。
4如果一个字符串没有字符串结束符,而调用str 开头的库函数,会发生什么?
没有结束符'/0',str就不知道什么时候结尾,导致运行结果的不确定性:
strlen(const char *str)就是当遇到'/0'后停止;如果字符串没有结束符'/0',那么函数会继续遍历后序的内存单元,直到遇到'/0'为止;
类似地,strcpy,strcat都是如此。
5. Strcpy(),strcat(),strcmp(),strncpy(),strncat(),strncmp()内部到底是如何运行
的?这些函数到底对源字符串和目标字符串做了些什么?你是否观察过它们运行时两个字
符串内存的变化?
待后面补充;
6、 上面这些函数使用时,各有哪些需要注意的地方?
待补充;
7.你会几种字符串查找操作?
不太清楚这道问题的意思,调用strstr即可。
8.C语言中有字符串这个数据类型吗?
没有
9 对字符串进行操作的时候,是否为字符串结尾符预留存储位置?不然的话容易造成非
常访问内存
应该是在强调'/0'的重要性