C语言:字符串赋值的方法

C语言:字符串赋值的方法main nbsp nbsp chars 30 nbsp strcpy s GoodNews 给数组赋字符串 nbsp nbsp nbsp nbsp nbsp 上面程序在编译时 遇到 chars 30 这条语句时 编译程序会在内存的某处留 nbsp 出连续 30 个字节的区域 并将第一个字节的地址赋给 s 当遇到 strcpy strcpy 为 nbsp TurboC2 0 的函数 时 首先在目标文件的

 

——————————————————————————————————————

补充:

无论是静态,局部还是全局数组只有在定义时才能初始话,否则必须通过其它方法,比如循环操作实现。

——————————————————————————————————————-

还有:不能使用关系运算符“==”来比较两个字符串,只能用strcmp() 函数来处理。

char str1[10], str2[10];

利用=运算符来把字符串复制到字符数组中是不可能的:

str1 = “abc”;     /* WRONG */

str2 = str1;       /* WRONG */

C语言把这些语句解释为一个指针与另一个指针之间的(非法的)赋值运算。但是,使用=初始化字符数组是合法的:

char str1[10] = “abc”;

这是因为在声明中,=不是赋值运算符。

试图使用关系运算符或判等运算符来比较字符串是合法的,但不会产生预期的结果:

if (str1==str2) …    /* WRONG */

这条语句把str1和str2作为指针来进行比较,而不是比较两个数组的内容。因为str1和str2有不同的地址,所以表达式str1 == str2的值一定为0。

 

 

————————————————————————————————————————————-

有空再查下动态数组的定义使用:

数组到底应该有多大才合适,有时可能不得而知。所以希望能够在运行时具有改变数组大小的能力。
动态数组就可以在任何时候改变大小。

 

通俗的说静态数组就是在定义数组的时候,由操作系统分配的空间,比如
int a[10];
这就是在定义时由系统给你分配了10个int类型的空间,这个空间是可以初始化的,比如
int a[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
那么在这个定义之后,系统会首先分配10个int类型的存储空间,然后把大括号里面的数字分别的,按顺序放到这10个空间里。你所做的只是写这么一句,而数组赋值的操作就由系统完成了。当然,初始化与否看你的需求,初始化不是强制性操作,想初始化就初始化,不想也没问题,还是上面的例子继续:
int a[10];
这里定义了,但是没初始化,这没有任何问题,以后你可以自己往里面赋值,比如
a[1] = 8;
a[5] = 3;
或者
for(int i = 0; i < 10; i++)
    a[i] = i;
等等

对于动态数组,不能被初始化,因为动态数组在定义时只是个指针,比如
int *a;
这里变量a只是个指向int类型的指针,而不是数组。动态分配有10个int类型元素的数组,如下:
a = (int) malloc(10*sizeof(int));
很明显,指针a在定义的时候不能被初始化,比如这样写就是错误的:
int *a = {1,2,3,4,5,6,7,8,9,10}; /* 错误! */
因为a是只有4个字节的指针,没有可用的存储空间给需要初始化的变量。



















—————————————————————————————————————————————————-

 

第三节  初始化数组

1.数组的初始化

  数组可以初始化,即在定义时,使它包含程序马上能使用的值。
  例如,下面的代码定义了一个全局数组,并用一组Fibonacci数初始化:
    int iArray[10]={1,1,2,3,5,8,13,21,34,55); //初始化
    void main()
    {

      //…
    }




  初始化数组的值的个数不能多于数组元素个数,初始化数组的值也不能通过跳过逗号的方式来省略,这在C中是允许的,但在C++中不允许。
  例如,下面的代码对数组进行初始化是错误的:
    int arrayl[5]={1,2,3,4,5,6}; //error: 初始化值个数多于数组元素个数
    int array2[5]={1,,2,3,4}; //error:初始化值不能省略
    int array3[5]={1,2,3,}; //error:初始化值不能省略
    int array4[5]={}; //error:语法格式错误
    void main()
    {

      //…
    }






  初始化值的个数可少于数组元素个数。当初始化值的个数少于数组元素个数时,前面的按序初始化相应值, 后面的初始化为0(全局或静态数组)或为不确定值(局部数组)。
  例如,下面的程序对数组进行初始化:
    //*
    //   ch7_2.cpp 
    //*












    #include

     cout <<"/nlocal static:/n";
     for(n=0; n<5; n++)
        cout <<" " <      cout <

    }




     1  0  0  0  0
    local:
     2 23567 23567 23567 23567
    local static:
     1  2  0  0  0




  例中,全局数组和全局静态数组的初始化是在主函数运行之前完成的,而局部数组和局部静态数组的初始化是在进入主函数后完成的。
  全局数组arrayl[5]对于初始化表的值按序初始化为1,2,3,还有两个元素的值则按默认初始化为0。
  全局静态数组array2[5]与全局数组的初始化情况一样,初始化表值(1)表示第1个元素的值,而不是指全部数组元素都为1。
  局部数组arrl[5]根据初始化表值的内容按序初始化, 由于初始化表值只有1个,所以还有4个元素的值为不确定。在这里均为数值23567。
  局部静态数组arr2[5]先根据初始化表按序初始化,其余3个数组元素的值默认初始化为0。

2.初始化字符数组

  初始化字符数组有两种方法,一种是:
    char array[10]={“hello”};
  另一种是:
    char array[10]={‘h’,’e’,’l’,’l’,’/0′};
  第一种方法用途较广,初始化时,系统自动在数组没有填值的位置用,’/0’补上。另外, 这种方法中的花括号可以省略,即能表示成:
    char array[10]=”hello”;
  第二种方法一次一个元素地初始化数组,如同初始化整型数组。这种方法通常用于输入不容易在键盘上生成的那些不可见字符。
  例如,下面的代码中初始化值为若干制表符:
    char chArray[5]={‘/t’,’/t’,’/t’,’/t’,’/0′)
  这里不要忘记为最后的,’/0’分配空间。如果要初始化一个字符串”hello”,那为它定义的数组至少有6个数组元素。
  例如,下面的代码给数组初始化,但会引起不可预料的错误:
    char array[5]=”hello”;
  该代码不会引起编译错误,但由于改写了数组空间以外的内存单元,所以是危险的。

3.省略数组大小

  有初始化的数组定义可以省略方括号中的数组大小。
  例如,下面的代码中数组定义为5个元素:
    int a[]={2,4,6,8,10};
  编译时必须知道数组的大小。通常,声明数组时方括号内的数字决定了数组的大小。有初始化的数组定义又省略方括号中的数组大小时,编译器统计花括号之间的元素个数,以求出数组的大小。
  例如,下面的代码产生相同的结果:
    static int a1[5]={1,2,3,4,5};
    static int a2[]={1,2,3,4,5};

  让编译器得出初始化数组的大小有几个好处。它常常用于初始化一个元素个数在初始化中确定的数组,提供程序员修改元素个数的机会。
  在没有规定数组大小的情况下,怎么知道数组的大小呢? sizeof操作解决了该问题。 例如,下面的代码用sizeof确定数组的大小:































    //*
    // ch7_3.cpp
    //*

    #include

    //*
    //   ch7_4.cpp  
    //*

    #include

     cout <<"size of array: " <
     cout <<"size of string: " <
    }

  运行结果为:
    size of array:12
    size of string:ll

  例中,数组大小为12,而字符串长度为11。
  省略数组大小只能在有初始化的数组定义中

  例如,下面的代码将产生一个编译错误:
    int a[];//error:没有确定数组大小
  在定义数组的场合,无论如何,编译器必须知道数组的大小。






 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/219659.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午10:11
下一篇 2026年3月17日 下午10:11


相关推荐

  • 1521端口已被占用解决方案

    1521端口已被占用解决方案1.先查看端口情况通过netstat-ano,查看1521端口是否被其他程序占用;如果被占用几下进程ID通过tasklist|findstr”进程ID”查找到程序名,KILLIT;2….

    2022年5月18日
    180
  • 文本分类常用算法比较

    文本分类常用算法比较本文对文本分类中的常用算法进行了小结,比较它们之间的优劣,为算法的选择提供依据。 一、决策树(DecisionTrees)优点: 1、决策树易于理解和解释.人们在通过解释后都有能力去理解决策树所表达的意义。 2、对于决策树,数据的准备往往是简单或者是不必要的.其他的技术往往要求先把数据一般化,比如去掉多余的或者空白的属性。 3、能够同时处理数据型和常规型属性。其他的

    2022年5月8日
    48
  • zabix配置报警机制

    zabix配置报警机制文章目录配置客户端配置 templates 配置邮件报警配置报警机制和邮件结合添加用户管理配置邮箱格式测试报警机制客户端 192 168 136 90 服务端 192 168 136 91 配置客户端配置代理端 如果服务器也需要被自己监控也需要安装 zabbix agent rpm ihttps repo zabbix com zabbix 4 0 rhel 7 x86 64 zabbix release 4 0 1 el7 noarch rpm 安装 zabbixyumins y

    2026年3月19日
    1
  • 自动化测试+性能面试题整理–个人最新【持续更新】「建议收藏」

    自动化测试+性能面试题整理–个人最新【持续更新】「建议收藏」写在前面公司要求招一名自动化测试,能力要求不高,1年左右自动化经验+部分性能经验即可,让我出一份题,我就百度+公司项目遇到的问题,出了一份,出题整体思路是:接口自动化问题+性能问题+规划的ui、app自动化+整体质量体系建设等多方面考虑。下面是正题自动化测试面试题1:基础篇目的:验证求职者是否在自动化测试岗位有实际应用于生产的工作经验1、使用什么测试框架做的上一个项目的自动化测试?说下怎么…

    2022年9月29日
    4
  • 谷歌地球Google Earth打不开的解决办法[通俗易懂]

    谷歌地球Google Earth打不开的解决办法[通俗易懂]从2020年11月20号左右,谷歌地球中国服务器全部关停,所有原来可以使用的hosts,全部不能使用了,导致原来可以在电脑上打开谷歌地球的,现在全部提示无网络,如下图:这个是谷歌地球的最新版,一样打不开:解决办法,尝试了,国内所有的有关谷歌地图的软件。唯一现在可以使用的:BIGEMAP如下图分下下载地址,大家可以安装来试一试,免费可用:http://download.bigemap.com/bmsetup.rar欢迎留言,提供更多谷歌地球的信息…

    2026年1月27日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号