Android NDK开发(C语言字符串)
作者:冬日毛毛雨 发布时间:2023-06-18 10:21:28
标签: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 <stdio.h>
#include <stdlib.h>
#include <Windows.h>
//使用字符数组存储字符串
void main() {
//三种写法
//\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 <string.h>
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+3
char* p = strchr(str, 'w');
if (p){
printf("索引位置:%d\n", p - str);
}
else{
printf("没有找到");
}
system("pause");
}
结果输出:
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中的所有字符都设置成字符c
void 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-Z
if (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);
else
printf("Not Found!\n");
p = strpbrk(s1, "Da");
if (p)
printf("%s", p);
else
printf("Not Found!");
getchar();
}
来源:https://juejin.cn/post/7038465634683387912


猜你喜欢
- 前面已经认识了不同的数据类型,你们有没有尝试过让不同的数据类型进行运算呢?int a = 1;double b = a;Console.Wr
- 本文实例讲述了Android开发使用Drawable绘制圆角与圆形图案功能。分享给大家供大家参考,具体如下:1. 创建类RoundCircl
- 一、定义1、T 代表一种类型可以加在类上,也可以加在方法上1)T 加在类上class SuperClass<A>{//todo}
- Servlet 实现文件上传所谓文件上传就是将本地的文件发送到服务器中保存。例如我们向百度网盘中上传本地的资源或者我们将写好的博客上传到服务
- 在Android开发中,经常会遇到这样一种情况,即需要将用户偏好设置(如用户偏好的app色彩主题)、与特定登录用户相关的设置(如不同登陆用户
- 继承(加上封装和多态性)是面向对象的编程的三个主要特性(也称为“支柱”)之一。 继承用于创建可重用、扩展和修改在其他类中定义的行为的新类。其
- 智能指针(auto_ptr) 这个名字听起来很酷是不是?其实auto_ptr 只是C++标准库提供的一个类模板,它与传统的new/delet
- 导入后gradle building 一直到跑,卡住了,一般是gradle没有下载,又下不下来的原因。去 http://serv
- 本文实例讲述了Java算法之最长公共子序列问题(LCS)。分享给大家供大家参考,具体如下:问题描述:一个给定序列的子序列是在该序列中删去若干
- 本文实例讲述了Android的三种菜单。分享给大家供大家参考。具体分析如下:Android的菜单分为三种类型:选项菜单(Option Men
- springboot读取文件,打成jar包后访问不到最新开发出现一种情况,springboot打成jar包后读取不到文件,原因是打包之后,文
- 代理模式代理模式(Proxy):为其他对象提供一个代理以控制对这个对象的访问。主要解决:在直接访问对象时带来的问题,比如说:要访问的对象在远
- preHandle: 预先处理,在目标的controller方法执行之前,进行处理postHandle: 在目标的con
- 我们经常会看到有一些app的banner界面可以实现循环播放多个广告图片和手动滑动循环的效果。看到那样的效果,相信大家都会想到ViewPag
- 本文实例讲述了基于C#实现XML文件读取工具类。分享给大家供大家参考。具体如下:这是我去年写的一个XML文件读取工具类,现在做了一些调整 基
- idea默认带的equals和hashcode引起的bug最近因规范需要,统一使用idea,使用的版本为2017.4.建立一个实体类,在添加
- 序初涉江湖,还望海涵!写点东西,纯粹是因为个人的记忆能力较弱,写些笔记罢了,若有错误还望雅正!对Android中的时间获取做个记录,以下为结
- 1.图的遍历从图中某一顶点出发访问图中其余顶点,且每个顶点仅被访问一次图的遍历有两种深度优先遍历DFS、广度优先遍历BFS2.深度优先遍历深
- 前言先简单介绍下我们的使用场景,线上5台Broker节点的kafka承接了所有binlog订阅的数据,用于Flink组件接收数据做数据中台的
- Java 调用long的最大值和最小值今天对Java八种基本数据类型进行总结,当总结到整数类型中的long时,出现了测试long最大值和最小