C++中strlen(),sizeof()与size()的区别

目录
  • 一、简述
  • 二、详细介绍
    • 1. strlen()
    • 2. sizeof()
    • 3. size()
  • 三、题目
  • 四、代码

一、简述

有没有初学 C++ 的小白和我一样,对这几个的区别迷迷糊糊的,傻傻分不清。为了正确掌握其使用方法,我在做完下面这道题目后,决定做一个小结。

二、详细介绍

1. strlen()

返回字符串中的字符个数。其格式为 strlen(const char * Str),由此可见,其接受一个 char * 参数。其过程是从字符串的头开始,一直到遇到第一个空字符 ‘\0’ ,且不把空字符计算在内。

2. sizeof()

计算所占字节数。这是一个运算符,括号中可以是数组,类型,对象等。
以一个指针为例:

#include<iostream>
using namespace std;

int main()
{
    double pi = 3.14;
    double* pt = &pi;
    cout << "sizeof(pt) = " << sizeof(pt);
    cout << ", sizeof(*pt) = " << sizeof(*pt) << endl;

    return 0;
}

pt 是一个指针,而 *pt 是指针 pt 所指向的 double 类型的数 3.14,二者是不一样的。运行上述代码后,结果如下:

sizeof(pt) = 4, sizeof(*pt) = 8

说明指针占用 4 个字节,而 double 占用 8 个字节。

3. size()

返回字符串中的字符个数。其格式为 string_Name.size(),在使用 string 对象时使用。其过程是从字符串的头开始,一直到遇到第一个空字符 ‘\0’ ,且不把空字符计算在内。

三、题目

/*
    编写一个程序,让用户输入三次 40 码跑的成绩(如果您愿意,也可以让用户输入 40 米跑的成绩),
    并显示次数和平均成绩。请使用一个 array 对象来存储数据(如果编译器不支持 array 类,请使用数组)
*/

四、代码

#include<iostream>
#include<array>
#include<string>
using namespace std;

int main()
{
    array<double, 3> grade;
    string string_animal = "cat";
    
    cout << "1st: ";
    cin >> grade[0];
    cout << "2nd: ";
    cin >> grade[1];
    cout << "3th: ";
    cin >> grade[2];

    double time = (grade[0] + grade[1] + grade[2]) / 3;
    cout << "The number is " << sizeof(grade)/sizeof(grade[0]) << ", and grade is " << time << endl;
    cout << "The number of string_animal is " << string_animal.size() << endl;

    return 0;
}

到此这篇关于C++中strlen(),sizeof()与size()的区别的文章就介绍到这了,更多相关C++ strlen(),sizeof()与size()内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 浅析C++中strlen函数的使用与模拟实现strlen的方法

    strlen函数的简单运用与模拟实现 strlen函数的简单使用strlen函数的三种模拟实现使用临时变量的方法使用函数递归的方法使用指针相减的方法 strlen函数的简单使用 strlen函数是用来计算字符串长度的一个函数,返回类型是size_t #include<stdio.h> #include<string.h> int main() { char arr[] = "hello world"; size_t;//返回值是size_t unsigned i

  • C/C++中的sizeof运算符和size_t类型的详解

    sizeof的作用 sizeof是c的运算符之一,用于获取操作数被分配的内存空间,以字节单位表示. 这里指的操作数,可以是变量,也可以是数据类型,如int,float等.所以就可以通过它来获取本地c库定义的基本类型的范围. sizeof的使用 1.对于一般变量,形式2种:sizeof a 或 sizeof(a); 2.对于数据类型,必须使用带括号的方式,如sizeof(int). size_t的说明 size_t是标准C库中定义的,应为unsigned int,在64位系统中为 long uns

  • C++不使用变量求字符串长度strlen函数的实现方法

    本文实例讲述了C++不使用变量求字符串长度strlen函数的实现方法.分享给大家供大家参考.具体实现方法如下: 1.strlen的源码实现: size_t strlen(const char *str) //strlen不做内存非法判断,如果是NULL,会core. { const char *eos=str; while(*eos++); return (eos-str-1); } 2.常见面试题会要求不使用额外变量,实现strlen函数: 实现一: int strlen(const char

  • C++中strlen函数的三种实现方法

    目录 一.strlen函数是什么 二.strlen的三种实现方法 1.第一种方法(直接) 2.第二种方法(递归) 3.第三种方法(指针-指针) 四.小结 一.strlen函数是什么 我们经常用到strlen这个函数求字符串长度,但是它是怎么实现的呢?接下来让给我用三种方法带你们看看它是如何实现? 首先我们先来了解一下strlen这个函数,strlen 是求字符串长度的函数,它的返回值是size_t,就是unsigned int.字符串以'\0'作为结束标志,strlen函数返回的值就是在字符串中

  • C/C++ 中sizeof('a')对比详细介绍

    C/C++ 中sizeof('a')的值对比详细介绍 C语言: char a = 'a'; sizeof(char) = 1 sizeof(a) = 1 sizeof('a') = 4 C++语言: char a = 'a'; sizeof(char) = 1 sizeof(a) = 1 sizeof('a') = 1 字符型变量是1字节这个没错,奇怪就奇怪在C语言认为'a'是4字节,而C++语言认为'a'是1字节. 原因如下: C99标准的规定,'a'叫做整型字符常量(integer char

  • 聊聊c++数组名称和sizeof的问题

    一维数组名称的用途: 可以统计整个数组在内存中的长度 可以获取数组在内存中的首地址 示例: int main() { //数组名用途 //1.可以获取整个数组占用内存空间大小 int arr[10] = { 1,2,3,4,5,6,7,8,9,10 }; cout << "整个数组所占内存空间为: " << sizeof(arr) << endl; cout << "每个元素所占内存空间为: " << si

  • C++中strlen(),sizeof()与size()的区别

    目录 一.简述 二.详细介绍 1. strlen() 2. sizeof() 3. size() 三.题目 四.代码 一.简述 有没有初学 C++ 的小白和我一样,对这几个的区别迷迷糊糊的,傻傻分不清.为了正确掌握其使用方法,我在做完下面这道题目后,决定做一个小结. 二.详细介绍 1. strlen() 返回字符串中的字符个数.其格式为 strlen(const char * Str),由此可见,其接受一个 char * 参数.其过程是从字符串的头开始,一直到遇到第一个空字符 ‘\0’ ,且不把

  • 详解PHP中strlen和mb_strlen函数的区别

    在PHP里有两个计算字符串个数的函数一个是 strlen,一个是mb_strlen;先来看看手册中的定义strlenstrlen - 获取字符串长度int strlen ( string $string )返回给定的字符串 string 的长度. mb_strlenint mb_strlen ( string $str [, string $encoding ] )返回给定的字符串 string 的长度.encoding参数为字符编码.如果省略,则使用内部字符编码. 这么看除了mb_strlen

  • C++中CopyFile和MoveFile函数使用区别的示例分析

    1.函数定义 CopyFile(A, B, FALSE);表示将文件A拷贝到B,如果B已经存在则覆盖(第三参数为TRUE时表示不覆盖) MoveFile(A, B);表示将文件A移动到B 2.函数原型 CopyFile: MoveFile: 由函数原型可以看出,这两个函数的前两个输入参数都为LRCWSTR类型,如果我们定义的是char*,记得转换成LRCWSTR,否则会报错: 另外,这两个函数都返回一个bool型变量,表示执行成功与否,当目标位置路径不存在时,会return 0 3.Demo 示

  • Java 中的vector和list的区别和使用实例详解

    要了解vector,list,deque.我们先来了解一下STL. STL是Standard Template Library的简称,中文名是标准模板库.从根本上说,STL是一些容器和算法的集合.STL可分为容器(containers).迭代器(iterators).空间配置器(allocator).配接器(adapters).算法(algorithms).仿函数(functors)六个部分.指针被封装成迭代器,这里vector,list就是所谓的容器. 我们常常在实现链表,栈,队列或者数组时,

  • java中构造方法和普通方法的区别说明

    1.普通方法: 定义:简单的说方法就是完成特定功能的代码块. 普通方法定义格式: 修饰符 返回值类型 方法名 (参数类型 参数名1,参数类型 参数名2,.........) { 函数体: return 返回值: } 返回值类型用于限定返回值的数据类型. 普通方法分为:有明确返回值的方法和没有明确返回值的方法. A.有明确返回值的方法的调用 可以单独调用(无意义).输出调用.赋值调用(推荐). public static int sum (int a , int b) { int c =a+b;

  • 详解C++ STL vector容量(capacity)和大小(size)的区别

    很多初学者分不清楚 vector 容器的容量(capacity)和大小(size)之间的区别,甚至有人认为它们表达的是一个意思.本节将对 vector 容量和大小各自的含义做一个详细的介绍. vector 容器的容量(用 capacity 表示),指的是在不分配更多内存的情况下,容器可以保存的最多元素个数:而 vector 容器的大小(用 size 表示),指的是它实际所包含的元素个数. 对于一个 vector 对象来说,通过该模板类提供的 capacity() 成员函数,可以获得当前容器的容量

  • pytorch中的matmul与mm,bmm区别说明

    pytorch中matmul和mm和bmm区别 matmulmmbmm结论 先看下官网上对这三个函数的介绍. matmul mm bmm 顾名思义, 就是两个batch矩阵乘法. 结论 从官方文档可以看出 1.mm只能进行矩阵乘法,也就是输入的两个tensor维度只能是( n × m ) (n\times m)(n×m)和( m × p ) (m\times p)(m×p) 2.bmm是两个三维张量相乘, 两个输入tensor维度是( b × n × m ) (b\times n\times m

  • Python中read,readline和readlines的区别案例详解

    python中有神奇的三种读操作:read.readline和readlines read()  : 一次性读取整个文件内容.推荐使用read(size)方法,size越大运行时间越长 readline()  :每次读取一行内容.内存不够时使用,一般不太用 readlines()   :一次性读取整个文件内容,并按行返回到list,方便我们遍历 一般小文件我们都采用read(),不确定大小你就定个size,大文件就用readlines() 1)我们先用read来完整读取一个小文件,代码如下: f

  • Java中Validated、Valid 、Validator区别详解

    目录 1. 结论先出 JSR 380 Valid VS Validated 不同点? Validator 2. @Valid和​​​​​​​@Validated 注解 3. 例子 4.使用@Valid嵌套校验 5. 组合使用@Valid和@Validated 进行集合校验 6. 自定义校验 自定义约束注解 工作原理 结论 参考链接: 1. 结论先出 Valid VS Validated 相同点 都可以对方法和参数进行校验 @Valid和@Validated 两种注释都会导致应用标准Bean验证.

  • oracle中存储函数与存储过程的区别介绍

    在oracle中,函数和存储过程是经常使用到的,他们的语法中有很多相似的地方,可是也有它们的不同之处,这段时间刚学完函数与存储过程,来给自己做一个总结: 一:存储过程:简单来说就是有名字的pl/sql块. 语法结构: create or replace 存储过程名(参数列表) is --定义变量 begin --pl/sql end; 案例: create or replace procedure add_(a int,b int) is c int; begin c:=a+b; dbms_ou

随机推荐