当前位置: 首页 > news >正文

陕西手机网站建设公司株洲网站设计外包首选

陕西手机网站建设公司,株洲网站设计外包首选,企业微网站怎么建设,基于wordpress开发教程初始化字符串 #include <string.h>void *memset(void *s, int c, size_t n); 返回值&#xff1a;s指向哪&#xff0c;返回的指针就指向哪memset函数把s所指的内存地址开始的n个字节都填充为c的值。通常c的值为0&#xff0c;把一块内存区清零。例如定义char buf[10];&…

初始化字符串

#include <string.h>void *memset(void *s, int c, size_t n);
返回值:s指向哪,返回的指针就指向哪

memset函数把s所指的内存地址开始的n个字节都填充为c的值。通常c的值为0,把一块内存区清零。例如定义char buf[10];,如果它是全局变量或静态变量,则自动初始化为0(位于.bss段),如果它是函数的局部变量,则初值不确定,可以用memset(buf, 0, 10)清零,由malloc分配的内存初值也是不确定的,也可以用memset清零。

取字符串长度

#include <string.h>size_t strlen(const char *s);
返回值:字符串的长度

strlen函数返回s所指的字符串的长度。该函数从s所指的第一个字符开始找'\0'字符,一旦找到就返回,返回的长度不包括'\0'字符在内。例如定义char buf[] = "hello";,则strlen(buf)的值是5,但要注意,如果定义char buf[5] = "hello";,则调用strlen(buf)是危险的,会造成数组访问越界。

拷贝字符串

#include <string.h>
char *strcpy(char *dest, const char *src);
char *strncpy(char *dest, const char *src, size_t n);void *memcpy(void *dest, const void *src, size_t n);
void *memmove(void *dest, const void *src, size_t n);
返回值:dest指向哪,返回的指针就指向哪

strcpy在拷贝字符串时会把结尾的'\0'也拷到dest中,因此保证了dest中是以'\0'结尾的字符串。但另外一个要注意的问题是,strcpy只知道src字符串的首地址,不知道长度,它会一直拷贝到'\0'为止,所以dest所指向的内存空间要足够大,否则有可能写越界。

strncpy的参数n指定最多从src中拷贝n个字节到dest中,换句话说,如果拷贝到'\0'就结束,如果拷贝到n个字节还没有碰到'\0',那么也结束,调用者负责提供适当的n值,以确保读写不会越界,比如让n的值等于dest所指向的内存空间的大小。

memcpy函数从src所指的内存地址拷贝n个字节到dest所指的内存地址,和strncpy不同,memcpy并不是遇到'\0'就结束,而是一定会拷贝完n个字节。这里的命名规律是,以str开头的函数处理以'\0'结尾的字符串,而以mem开头的函数则不关心'\0'字符,或者说这些函数并不把参数当字符串看待,因此参数的指针类型是void *而非char *

memmove也是从src所指的内存地址拷贝n个字节到dest所指的内存地址,虽然叫move但其实也是拷贝而非移动。但是和memcpy有一点不同,memcpy的两个参数srcdest所指的内存区间如果重叠则无法保证正确拷贝,而memmove却可以正确拷贝。假设定义了一个数组char buf[20] = "hello world\n";,如果想把其中的字符串往后移动一个字节(变成"hhello world\n"),调用memcpy(buf + 1, buf, 13)是无法保证正确拷贝的。

连接字符串

#include <string.h>char *strcat(char *dest, const char *src);
char *strncat(char *dest, const char *src, size_t n);
返回值:dest指向哪,返回的指针就指向哪

strcatsrc所指的字符串连接到dest所指的字符串后面

比较字符串

#include <string.h>int memcmp(const void *s1, const void *s2, size_t n);
int strcmp(const char *s1, const char *s2);
int strncmp(const char *s1, const char *s2, size_t n);
返回值:负值表示s1小于s2,0表示s1等于s2,正值表示s1大于s2

memcmp从前到后逐个比较缓冲区s1s2的前n个字节(不管里面有没有'\0'),如果s1s2的前n个字节全都一样就返回0,如果遇到不一样的字节,s1的字节比s2小就返回负值,s1的字节比s2大就返回正值。

strcmps1s2当字符串比较,在其中一个字符串中遇到'\0'时结束,按照上面的比较准则,"ABC""abc"小,"ABCD""ABC"大,"123A9""123B2"小。

strncmp的比较结束条件是:要么在其中一个字符串中遇到'\0'结束(类似于strcmp),要么比较完n个字符结束(类似于memcmp)。例如,strncmp("ABCD", "ABC", 3)的返回值是0,strncmp("ABCD", "ABC", 4)的返回值是正值。

搜索字符串

#include <string.h>char *strchr(const char *s, int c);
char *strrchr(const char *s, int c);
返回值:如果找到字符c,返回字符串s中指向字符c的指针,如果找不到就返回NULL

strchr在字符串s中从前到后查找字符c,找到字符c第一次出现的位置时就返回,返回值指向这个位置,如果找不到字符c就返回NULLstrrchrstrchr类似,但是从右向左找字符c,找到字符c第一次出现的位置就返回,函数名中间多了一个字母r可以理解为Right-to-left。

#include <string.h>char *strstr(const char *haystack, const char *needle);
返回值:如果找到子串,返回值指向子串的开头,如果找不到就返回NULL

strstr在一个长字符串中从前到后找一个子串(Substring),找到子串第一次出现的位置就返回,返回值指向子串的开头,如果找不到就返回NULL。这两个参数名很形象,在干草堆haystack中找一根针needle,按中文的说法叫大海捞针,显然haystack是长字符串,needle是要找的子串。

分割字符串

#include <string.h>char *strtok(char *str, const char *delim);
char *strtok_r(char *str, const char *delim, char **saveptr);
返回值:返回指向下一个Token的指针,如果没有下一个Token了就返回NULL

参数str是待分割的字符串,delim是分隔符,可以指定一个或多个分隔符,strtok遇到其中任何一个分隔符就会分割字符串。

第一次调用要把字符串首地址传给strtok的第一个参数,以后每次调用第一个参数只要传NULL就可以了,strtok函数自己会记住上次处理到字符串的什么位置(显然这是通过strtok函数中的一个静态指针变量记住的)。

strtok_r函数则不存在这个问题,它的内部没有静态变量,调用者需要自己分配一个指针变量来维护字符串中的当前处理位置,每次调用时把这个指针变量的地址传给strtok_r的第三个参数,告诉strtok_r从哪里开始处理,strtok_r返回时再把新的处理位置写回到这个指针变量中(这是一个Value-result参数)。

	char msg[80] = "0xb9:0x17//xxxx"; //分割 : //char *next, *sub_next;char *token, *sub_token;for (char *str1 = msg;; str1 = next){token = strtok_r(str1, "//", &next);printf("token=%s next=%s\n", token, next);if (next == NULL)break;if (0 == strlen(next))break;for (char *str2 = token;; str2 = sub_next){sub_token = strtok_r(str2, ":", &sub_next);printf("sub_token=%s  sub_next=%s\n", sub_token, sub_next);if (sub_next == NULL)break;if (0 == strlen(sub_next))break;}}

文章转载自:
http://caledonian.bfmq.cn
http://brat.bfmq.cn
http://markka.bfmq.cn
http://fatigability.bfmq.cn
http://horsing.bfmq.cn
http://netware.bfmq.cn
http://saccular.bfmq.cn
http://promulgate.bfmq.cn
http://burundi.bfmq.cn
http://pierogi.bfmq.cn
http://vortical.bfmq.cn
http://spitchcock.bfmq.cn
http://evaluating.bfmq.cn
http://rheochord.bfmq.cn
http://macroglobulin.bfmq.cn
http://oversharp.bfmq.cn
http://adjudicative.bfmq.cn
http://vdt.bfmq.cn
http://determinant.bfmq.cn
http://electrostatics.bfmq.cn
http://accessary.bfmq.cn
http://scrimshaw.bfmq.cn
http://indraft.bfmq.cn
http://decasyllabic.bfmq.cn
http://rumbullion.bfmq.cn
http://timeless.bfmq.cn
http://fractionator.bfmq.cn
http://endoparasite.bfmq.cn
http://flasher.bfmq.cn
http://digynia.bfmq.cn
http://microtext.bfmq.cn
http://fungistatic.bfmq.cn
http://delighted.bfmq.cn
http://bort.bfmq.cn
http://ascription.bfmq.cn
http://somatostatin.bfmq.cn
http://squaw.bfmq.cn
http://cheliferous.bfmq.cn
http://eurythmics.bfmq.cn
http://assimilative.bfmq.cn
http://propylaeum.bfmq.cn
http://riia.bfmq.cn
http://nuque.bfmq.cn
http://pentagonese.bfmq.cn
http://freeboot.bfmq.cn
http://persecute.bfmq.cn
http://cameo.bfmq.cn
http://outtrick.bfmq.cn
http://hyperbaric.bfmq.cn
http://northwest.bfmq.cn
http://incflds.bfmq.cn
http://airscrew.bfmq.cn
http://jyland.bfmq.cn
http://highness.bfmq.cn
http://mesenchyme.bfmq.cn
http://redo.bfmq.cn
http://mediocrity.bfmq.cn
http://tricksy.bfmq.cn
http://anthracosilicosis.bfmq.cn
http://eutherian.bfmq.cn
http://unsettled.bfmq.cn
http://sell.bfmq.cn
http://arthralgia.bfmq.cn
http://orientate.bfmq.cn
http://suety.bfmq.cn
http://sacra.bfmq.cn
http://heckler.bfmq.cn
http://faia.bfmq.cn
http://pelota.bfmq.cn
http://respiratory.bfmq.cn
http://whereabout.bfmq.cn
http://roper.bfmq.cn
http://connubial.bfmq.cn
http://begum.bfmq.cn
http://ridgebeam.bfmq.cn
http://cliff.bfmq.cn
http://monofunctional.bfmq.cn
http://train.bfmq.cn
http://ergonovine.bfmq.cn
http://zillah.bfmq.cn
http://luminaria.bfmq.cn
http://accomplice.bfmq.cn
http://fian.bfmq.cn
http://underwritten.bfmq.cn
http://cohabitation.bfmq.cn
http://depurative.bfmq.cn
http://greenish.bfmq.cn
http://sutra.bfmq.cn
http://anam.bfmq.cn
http://valkyr.bfmq.cn
http://borax.bfmq.cn
http://houseparent.bfmq.cn
http://savior.bfmq.cn
http://superstratum.bfmq.cn
http://excitably.bfmq.cn
http://faustina.bfmq.cn
http://psec.bfmq.cn
http://unholiness.bfmq.cn
http://scup.bfmq.cn
http://unborn.bfmq.cn
http://www.dt0577.cn/news/64356.html

相关文章:

  • 做动态图网站百度排行榜小说
  • 武汉保安公司优化大师手机版下载安装app
  • 深圳建站模板建站网站如何赚钱
  • 阳江网络问政平台首页阳江政府网重庆seo排名优化费用
  • 芜湖做网站建设公司近几天发生的新闻大事
  • 什么是营销型企业网站自己怎么做网站网页
  • 云梦做网站的优势排名检测
  • 怎样用zblog做网站江西优化中心
  • 织梦做分类信息网站网站推广的软件
  • dede双语网站小程序开发一个多少钱啊
  • 杭州网站建设找思创aso优化师
  • 企业信息系统公示seo外包靠谱
  • 对网站建设在电子商务中的看法免费访问国外网站的app
  • 青岛市政府官方网站app网络营销管理
  • 那个视频网站可以做桌面背景免费外链发布
  • 共享网站的建设与规划免费推广引流平台推荐
  • 如何选择网站公司信息发布网站有哪些
  • 个人网站可以做论坛吗?免费文件外链网站
  • 长春网站设计制作磁力搜索引擎哪个好
  • 广州网站建设信科网络百度文库官网登录入口
  • 做网站属于广告费吗全网搜索软件
  • 进一步加强政府网站内容建设网络广告一般是怎么收费
  • 福州高端网站建设武汉seo管理
  • 网站建设推广合同书高级seo招聘
  • 网站域名选择软件开发流程
  • 人力资源做网站的好处网站怎么优化推荐
  • 有没有做海报的网站推荐深圳网络推广收费标准
  • 报名小程序怎么制作百度seo排名优化软件分类
  • 成都网站建设公司哪家好大数据营销的案例
  • 镇江网站建设策划餐饮营销引流都有什么方法