• 2020.9.19 第三课 字符串格式化输出与输入


    2.4 sizeof关键字

    sizeof是c语言关键字,功能是求指定数据类型在内存中的大小,单位:字节

    int类型

    • int常量,变量
      int就是32位的一个二进制整数,在内存当中占据4个字节空间

    • printf输出int值
          %d,输出一个有符号的10进制整数,%u,代表输出一个无符号的10进制整数

    • printf输出八进制和十六进制
          %x,代表输出16进制数,%X,用大写字母方式输出16进制数
          %o代表输出八进制数

    • short,long,long long,unsigned int
          short意思为短整数,在32位系统下是2个字节,16个比特
          long意思为长整数,在32位的系统下,long都是4个字节的,在64位系统下,windows还是4个字节,unix下成了8个字节
          int不管是32位系统下,还是64位系统下,不论是windows还是unix都是4个字节的

    整数溢出

                计算一个整数的时候超过整数能够容纳的最大单位后,整数会溢出,溢出的结果是高位舍弃

      当一个小的整数赋值给大的整数,符号位不会丢失,会继承

    大端对齐与小端对齐

    对于arm,intel这种x86构架的复杂指令CPU,整数在内存中是倒着存放的,低地址放低位,高地址放高位,小端对齐

    int  x=0x12345678
       //12345678(16进制) int为4字节,一字节8位 12 34 56 78
                                     //转为2进制=每4位对应8421
                                      //(2进制) 0001 0010 0011 0100 0101 0110 0111 1000
       //int x=0x12345678;  
    ////   0001 0010 0011 0100   0101 0110   0111 1000 原码
    ////     FA61       FA60         FA59       FA58
       
       
       printf(“%#X”,&x);//&取首地址符   #显示几进制

    但对于unix服务器的CPU,更多是采用大端对齐的方式存放整数

    char类型

    1.char常量,变量

    char c;定义一个char变量

    ‘a’,char的常量

    char的本质就是一个整数,一个只有1个字节大小的整数

    2.printf输出char

    %c意思是输出一个字符,而不是一个整数

    3.不可打印char转义符

    a,警报

    退格

    换行

    回车

    制表符

    斜杠

    ’单引号

    ”双引号

    ?问号

    4.char和unsigned char

    char取值范围为-128到127

    unsigned char为0-255

     数据越界

     char x=127+2;
        printf(“%d”,x);
         129
    转为2进制 除余得到原码1000 0001(有符号)
                   反码=1111 1110
                   补码=1111 1111 输出-127 
       
       unsigned char x=255+10;
        printf(“%d”,x);
    265 =  256 128 64 32 16 8 4 2 1
        =   1   0   0  0  0 1 0 0 1(2进制)
        =1 0000 1001  (正数的原、反、补一致)
        =9 

    浮点float,double类型

    1.浮点常量,变量

    float在32位系统下是4个字节,double在32位系统下是8个字节

    小数的效率很低,避免使用,除非明确的要计算一个小数。

    2.printf输出浮点数

    %f,%lf

    %f是输出一个float

    float pi=3.14;
    printf(%10f,pi);//%f   %10f是以10个格子(位)显示   %0.2f是精确到小数后2位(可以四舍五入)

     

    %lf输出一个double

    3.类型限定

    • const

      • const是代表一个不能改变值的常量

    • volatile

      • 代表变量是一个可能被CPU指令之外的地方改变的,编译器就不会针对这个变量去优化目标代码

    • register

      • 变量在CPU寄存器里面,而不是在内存里面。但regist是建议型的指令,而不是命令型的指令

    字符串格式化输出与输入

    • 字符串在计算机内部的存储方式
      字符串是内存中一段连续的char空间,以''结尾
      ""(双引号)是c语言表达字符串的方式

    • printf函数,putchar函数

      printf格式字符

        字符          对应数据类型              含义
        d   int    接受整数值并将它表示为有符号的十进制整数
    hd short int       短整数
        hu   unsigned short int   无符号短整数
        o       unsigned int     无符号8进制整数
        u   unsigned int     无符号10进制整数
        x/X   unsigned int     无符号16进制整数 x对应小写,X对应大写
        f/lf   float或double    单精度浮点数或双精度浮点数
        e/E   double 科学计数法表示的数,'e'的大小写表示输入时的大小写
        c char 字符型,按照ASCII码转换成对应字符
        s/S char* / wchar_t *   字符串,输出字符串中的字符直到空字符('')
        p void* 以16进制形式输出指针
        %   % 输出一个百分号(%)
    //printf的附加格式
    字符 含义    
    l  附加在d,o,u,x前面,表示长整数
        -  左对齐
        m  数据的最小宽度
        0  将输出的前面补上0,直到占满指定列宽为止(不可以搭配'-'使用)
        N  宽度至少N位,不够以空格填充  

    putchar是显示一个字符的函数

    • scanf函数与getchar函数

      scanf通过键盘读取用户输入,放入变量中,记得参数一定是变量的地址(&)

       

          int a=0;
      int b=0;
      scanf("%d",&a);//一定要用&取变量的地址
      scanf("%d",&b);//一定要用&取变量的地址
      //scanf安全性解决方法:1  将scanf改为scanf_s
                         2  #define _CRT_SECURE_NO_WARNTINGS
                         3 多字符集  dsl    

       

      getchar得到用户键盘输入的字符

    char x;
    x=getchar();//得到的是ASCII字符编码表中的字符
    printf("%d ",x);
    printf("%c ",x);  abcd

    markdown  ctrl+shift+(-+)放大缩小

  • 相关阅读:
    算法问题实战策略 JUMPGAME 记忆化搜索
    算法问题实战策略 TRIANGLEPATH 动态规划入门题
    poj 2785 4 Values whose Sum is 0
    poj 3276 Face The Right Way 递推
    acwing 883. 高斯消元解线性方程组
    acwing 861. 二分图的最大匹配 模板
    Leetcode 42 接雨水 双指针 空间换时间
    LeetCode 1290. 二进制链表转整数
    LeetCode 1291. 顺次数
    <挑战程序设计竞赛> poj 3320 Jessica's Reading Problem 双指针
  • 原文地址:https://www.cnblogs.com/heerha/p/13702596.html
Copyright © 2020-2023  润新知