博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
strlen()
阅读量:2047 次
发布时间:2019-04-28

本文共 691 字,大约阅读时间需要 2 分钟。

调用strlen()函数的头文件为  #include<string.h>

strlen()是一种计算字符串的长度的函数。

'\0’作为终止符;
strlen的结果运行的时候才出来(不是编译期求值),是计算字符串长度的。
其参数只能是字符型指针(char*)。
返回值为int。

#include <stdio.h>

#include <string.h>
int main()
{
    char *p = "strlen";
    char arr1 []= "strlen";
    char arr2[] = { 's', 't', 'r', 'l', 'e','n' };
    printf("%d\n", sizeof( p));
    //结果8,因为指针变量的所占空间大小仅仅和操作系统位数有关32-4,64-8
    printf("%d\n", sizeof(arr1));
    //结果7,字符串默认以\0结尾,sizeof()包含\0的计算
    printf("%d\n", sizeof(arr2));
    //结果为6,因为为字符型表示,并不含有\0(仅仅字符串有\0)
    printf("%d\n", strlen( p));
    //结果为6,strlen求的是字符串的长度,不包含\0
    printf("%d\n", strlen(arr1));
    //结果为6,strlen求的是字符串的长度,不包含\0
    printf("%d\n", strlen(arr2));
    //因为字符型不包含\0,但字符串需要找到\0才可结束,所以在'n'之后继续向后读取直到找到\0,所以是一个随机值
    return 0;
}

转载地址:http://mwqof.baihongyu.com/

你可能感兴趣的文章
Leetcode C++ 随手刷 547.朋友圈
查看>>
手抄笔记:深入理解linux内核-1
查看>>
内存堆与栈
查看>>
Leetcode C++《每日一题》20200621 124.二叉树的最大路径和
查看>>
Leetcode C++《每日一题》20200622 面试题 16.18. 模式匹配
查看>>
Leetcode C++《每日一题》20200625 139. 单词拆分
查看>>
Leetcode C++《每日一题》20200626 338. 比特位计数
查看>>
Leetcode C++ 《拓扑排序-1》20200626 207.课程表
查看>>
Go语言学习Part1:包、变量和函数
查看>>
Go语言学习Part2:流程控制语句:for、if、else、switch 和 defer
查看>>
Go语言学习Part3:struct、slice和映射
查看>>
Go语言学习Part4-1:方法和接口
查看>>
Leetcode Go 《精选TOP面试题》20200628 69.x的平方根
查看>>
Leetcode C++ 剑指 Offer 09. 用两个栈实现队列
查看>>
Leetcode C++《每日一题》20200707 112. 路径总和
查看>>
云原生 第十一章 应用健康
查看>>
Leetcode C++ 《第202场周赛》
查看>>
云原生 第十二章 可观测性:监控与日志
查看>>
Leetcode C++ 《第203场周赛》
查看>>
云原生 第十三章 Kubernetes网络概念及策略控制
查看>>