Android|Android NDK开发(C语言字符串)

目录

  • 1.C语音的字符串有两种
    • 1.1字符数组
    • 1.2字符指针
  • 2.字符串常用的方法
    • 2.1strcpy字符串拼接
    • 2.2strchr字符串中查找字符
    • 2.3strchr字符串中查找字符
    • 2.4更多用法...

1.C语音的字符串有两种

1.1字符数组

数组可以修改其中某一个值,不可以整体赋值。#define _CRT_SECURE_NO_WARNINGS#include #include #include //使用字符数组存储字符串voidmain() {//三种写法//\0代表 结束符char str[] = { 'h','e','l','l','o','\0' }; //char str[6]= { 'h','e','l','l','o' }; //char str[10] = "hello"; printf("%s\n", str); //地址printf("%#x\n", str); getchar(); }

结果输出:
hello
0xb3fb78


1.2字符指针

字符指针不可以修改其中某一个值,可以整体赋值。使用指针加法,结合结束符,可以进行截取。

void main() {char *str = "how are you?"; printf("%s\n", str); //str[1] = "w" ; //字符指针不可以修改其中某一个值str = "hello world"; printf("%s\n", str); printf("%#x\n", str); //使用指针加法,截取字符串str += 3; //指向第四个字符首地址while (*str) {printf("%c", *str); str++; }getchar(); }

结果输出:
how are you?
hello world
0x97b44
lo world


2.字符串常用的方法
相关的头文件:#include

2.1strcpy字符串拼接

原型:extern char *strcpy(char *dest,char *src);
功能:把src所指由NULL结束的字符串复制到dest所指的数组中。
说明:src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。
返回指向dest的指针。
举例:
void main(void){char dest[50]; char *a = "china"; char *b = " is powerful!"; strcpy(dest, a); strcat(dest, b); printf("%s\n", dest); system("pause"); }

结果输出:
china is powerful!


2.2strchr字符串中查找字符

原型:extern char *strchr(char *s,char c);
功能:查找字符串s中首次出现字符c的位置
说明:返回首次出现c的位置的指针,如果s中不存在c则返回NULL。
void main(void){char *str = "I want go to USA!"; printf("%#x\n", str); //U元素的指针//str+3char* p = strchr(str, 'w'); if (p){printf("索引位置:%d\n", p - str); }else{printf("没有找到"); }system("pause"); }

【Android|Android NDK开发(C语言字符串)】结果输出:
0x877b30
索引位置:2


2.3strchr字符串中查找字符

原型:extern char *strstr(char *haystack, char *needle);
功能:从字符串haystack中寻找needle第一次出现的位置(不比较结束符NULL)。
说明:返回指向第一次出现needle位置的指针,如果没找到则返回NULL。
//strstr 从字符串haystack中寻找needle第一次出现的位置void main(void){char *haystack = "I want go to USA!"; char *needle = "to"; //U元素的指针char* p = strstr(haystack, needle); if (p){printf("索引位置:%d\n", p - haystack); }else{printf("没有找到"); }system("pause"); }

结果输出:
索引位置:10


2.4更多用法...

//strset 把字符串s中的所有字符都设置成字符cvoid main(void){char str[] = "internet change the world!"; _strset(str,'w'); printf("%s\n",str); system("pause"); }//strrev 把字符串s的所有字符的顺序颠倒过来void main(void){char str[] = "internet change the world!"; _strrev(str); printf("%s\n", str); system("pause"); }//atoi 字符串转为int类型//atol():将字符串转换为长整型值void main(void){char* str = "a78"; //int r = atoi(str); printf("%d\n", r); system("pause"); }// 字符串转为double类型void main(void){char* str = "77b8b"; char** p = NULL; //char* p = str + 2; //参数说明:str为要转换的字符串,endstr 为第一个不能转换的字符的指针double r = strtod(str,p); printf("%lf\n", r); printf("%#x\n", p); system("pause"); }//strupr转换为大写void main(void){char str[] = "CHINA motherland!"; _strupr(str); printf("%s\n",str); system("pause"); }//转换为小写void mystrlwr(char str[],int len){int i = 0; for (; i < len; i++){//A-Z 字母 a-Zif (str[i] >= 'A' && str[i] <= 'Z'){str[i] = str[i]-'A' + 'a'; }}}void main(void){char str[] = "CHINA motherland!"; mystrlwr(str,strlen(str)); printf("%s\n", str); system("pause"); }//练习:删除字符串中指定的字符void delchar(char *str, char del){char *p = str; while (*str != '\0') {if (*str != del) {*p++ = *str; }str++; }*p = '\0'; }//删除最后一个字符int main(){char str[] = "vencent ppqq"; delchar(str,'t'); printf("%s\n", str); system("pause"); }//Java String replaceAll //StringBuffer buff.deleteCharAt(buff.length()-1); //删除最后一个字符void main(void){char str[] = "internet,"; str[strlen(str) - 1] = '\0'; printf("%s\n", str); //作业:realloc实现StringBuffer的拼接,而不是一开始开辟一个很大的数组//结构体StringBuffer system("pause"); }//memcpy 由src所指内存区域复制count个字节到dest所指内存区域void main(void){char src[] = "C,C++,Java"; char dest[20] = {0}; //字节memcpy(dest,src,5); printf("%s\n",dest); system("pause"); }//memchr 从buf所指内存区域的前count个字节查找字符ch。void main(void){char src[] = "C,C++,Java"; char ch = 'C'; //字节 (分段截取)char* p = memchr(src+3, ch, 5); if (p){printf("索引:%d\n", p - src); }else{printf("找不到\n"); }system("pause"); }//memmove 由src所指内存区域复制count个字节到dest所指内存区域。void main(){char s[] = "Michael Jackson!"; //截取的效果 memmove(s, s + 8, strlen(s) - 8 - 1); s[strlen(s) - 8] = 0; printf("%s\n", s); getchar(); }//在字符串s1中寻找字符串s2中任何一个字符相匹配的第一个字符的位置,空字符NULL不包括在内void main(){char *s1 = "Welcome To Beijing"; char *s2 = "to"; char *p; p = strpbrk(s1, s2); if (p)printf("%s\n", p); elseprintf("Not Found!\n"); p = strpbrk(s1, "Da"); if (p)printf("%s", p); elseprintf("Not Found!"); getchar(); }

到此这篇关于Android NDK开发(C语言字符串)的文章就介绍到这了,更多相关Android NDK C语言字符串 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    推荐阅读