C语言字符串与指针(6)

2019-03-16 14:44

四、string.h中的字符串处理函数 (一)字符操作函数

1. char * strcpy(char * s1, const char * s2) 把s2拷贝到s1,返回s1的值 2. char * strncpy(char * s1, const char * s2, size_t n) 拷贝s2中的n个字符到s1 3. char * strcat(char * s1, const char * s2) 把s2追加到s1后边

4. char * strncat(char * s1, const char * s2, size_t n) 把s2的n个字符追加到s1后 注意:

strncpy不一定拷贝第二个参数的终止符'\\0'(仅当n至少比s2长度大1时才拷贝) 但strncat则会自动将'\\0'拷贝到结果后边。 #include #include int main() {

char x[]=\ char y[]=\ char z[100]; //strcpy

printf(\ printf(\ //strncpy

printf(\ strncpy(z,x,5); z[5]='\\0'; puts(z);

//strcat

printf(\ printf(\ //strncat

printf(\ printf(\ return 0; } 输出:

strcpy Test:Happy EveryDay strncpy Test:Happy strcat Test:HappyHappy strncat Test:HappyHappyHa (二)比较函数

1. int strcmp(const char * s1, const char * s2) 比较字符串s1和s2,小于、等于、大于分别返回负值、0、正值

2. int strncmp(const char * s1, const char * s2, size_t n) 比较字符串s1和s2的n个字符,结果同strcmp(不比较'\\0'后的字符) (三)查找函数

1. char * strchar(const char * s, int c) 返回指向字符串s中字符c首次出现的指针,没有返回NULL 2. char * strrchar(const char * s, int c) 返回指向字符串s中字符c最后一次出现的指针,没有返回NULL 3. char * strstr(const char * s1, const char * s2) 返回指向字符串s1中首次出现s2位置的指针,无返回NULL

4. size_t strspn(const char * s1, const char * s2) 返回s1中只包含s2中字符的起始段的长度 5. size_t strcspn(const char * s1, const char * s2) 返回s1中不包含s2中字符的起始段的长度

6. char * strpbrk(const char * s1, const char * s2) 返回指向s1中首次出现s2中字符的位置的指针,没有返回NULL

7. char * strtok(char * s1, const char * s2)

将s1打断为用s2中包含的字符分开的记号。第1次调用把s1作为参数,以后为继续把该字符串打断成记号而再次调用strtok时要用NULL作为第一个参数,每次调用都返回指向当前记号的指针,字符串没有剩余记号时返回NULL。

注意:strtok会修改输入的字符串,故请拷贝后再调用。 示例:

#include #include int main() {

char str[]=\ char * tokenPtr; tokenPtr=strtok(str, \ while(tokenPtr != NULL) {

puts(tokenPtr);

tokenPtr=strtok(NULL,\ } return 0; } 输出: This

is a string

(四)内存函数

用来操作、比较和查询内存块,操作对象为”内存块“。

1. void * memcpy(void * s1, const void * s2, size_t n) 将s2中连续n个字节的数据拷贝到s1中 ,注意s1和s2内存区域不能重叠

2. void * memmve(void * s1, const void * s2, size_t n) 将s2中连续n个字节的数据拷贝到s1中 ,但s1和s2内存区域可以重叠

3. int memcmp(const void * s1, const void * s2, size_t n) 比较内存区域s1和s2的前n个字节,<、=、>分别返回负值、0、正值。

4. void * memchr(const void * s, int c, size_t n) 返回指向s1对象的前n个字节查找出现c的位置的指针,没有返回NULL

5. void * memset(void * s, int c, size_t n) 将c拷贝到s1中的前n个字节中 示例:

int array[5] = {1,4,3,5,2}; for(int i = 0; i < 5; i++) cout<

1. char * strerror(int errornum) 返回与errornum匹配的字符串指针

2. size_t strlen(const char * s) 计算字符串s的长度,返回终止符NULL前的字符个数

指针

指针是一个特殊的变量,它里面存储的数值被解释成为内存里的一个地址。 要搞

清一个指针需要搞清指针的四方面的内容:指针的类型,指针所指向的 类型,指针的值或者叫指针所指向的内存区,还有指针本身所占据的内存区。让我们分别说明。 先声明几个指针放着做例子: 例一: (1)int*ptr; (2)char*ptr; (3)int**ptr; (4)int(*ptr)[3]; (5)int*(*ptr)[4];

指针的类型

从语法的角度看,你只要把指针声明语句里的指针名字去掉,剩下的部分就是这个指针的类型。这是指针本身所具有的类型。让我们看看例一中各个指针的类型: (1)int*ptr;//指针的类型是int* (2)char*ptr;//指针的类型是char* (3)int**ptr;//指针的类型是int** (4)int(*ptr)[3];//指针的类型是int(*)[3] (5)int*(*ptr)[4];//指针的类型是int*(*)[4]

怎么样?找出指针的类型的方法是不是很简单? 指针所指向的类型

当你通过指针来访问指针所指向的内存区时,指针所指向的类型决定了编译器将把那片内存区里的内容当做什么来看待。

从语法上看,你只须把指针声明语句中的指针名字和名字左边的指针声明符*去掉,剩下的就是指针所指向的类型。例如: (1)int*ptr;//指针所指向的类型是int

(2)char*ptr;//指针所指向的的类型是char (3)int**ptr;//指针所指向的的类型是int* (4)int(*ptr)[3];//指针所指向的的类型是int()[3] (5)int*(*ptr)[4];//指针所指向的的类型是int*()[4]

在指针的算术运算中,指针所指向的类型有很大的作用。

指针的类型(即指针本身的类型)和指针所指向的类型是两个概念。当你对C越来越熟悉时,你会发现,把与指针搅和在一起的 \类型 \这个概念分成 \指针的类型 \和 \指针所指向的类型 \两个概念,是精通指针的关键点之一。我看了不少书,发现有些写得差的书中,就把指针的这两个概念搅在一起了,所以看起书来前后矛盾,越看越糊涂。

指针的值,或者叫指针所指向的内存区或地址 指针的值是指针本身存储的数值,这个值将被编译器当作一个地址,而不是一个一般的数值。在32位程序里,所有类型的指针的值都是一个32位整数,因为32位程序里内存地址全都是32位长。 指针所指向的内存区就是从指针的值所代表的那个内存地址开始,长度为si zeof(指针所指向的类型)的一片内存区。以后,我们说一个指针的值是XX,就相当于说该指针指向了以XX为首地址的一片内存区域;我们说一个指针指向了某块内存区域,就相当于说该指针的值是这块内存区域的首地址。


C语言字符串与指针(6).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:SNCR+SCR方案 - 图文

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: