首页 > 其他分享 >初学C语言day03--数据类型及循环分支语句

初学C语言day03--数据类型及循环分支语句

时间:2023-07-19 21:00:20浏览次数:44  
标签:char day03 数据类型 unsigned long C语言 运算符 int 类型

一、数据类型
为什么要对数据进行分类?

1、现实中的数据就是自带类别属性的
2、对数据进行分类可以节约内存存储空间、提高运行速度

存储空间的单位:

Bit 比特 存储一个二进制位,只能存储0或者1,计算机存储数据的最小单位
Byte 字节 存储八个二进制位,计算机存储数据的基本单位
Kb 1024字节
Mb 1024Kb
Gb 1024Mb
Tb 1024Gb
Pb 1024Tb
C语言中数据分为两大类别:自建(程序员自己设计的)、内建(C语言自带的)
sizeof:可以计算类型/变量所占内存字节数

整型:

signed 有符号
二进制最高位作为符号位 0正数 1负数
类型名 字节数 数据范围
signed char 1 -128~127
signed short 2 -32768~32767
signed int 4 正负20亿
signed long 4(32位)/8(64位)
signed long long 8 正负9开头19位整数
注意:signed不加就代表加了
char == signed char

unsigned 无符号
二进制最高位作为数据位
类型名 字节数 数据范围
unsigned char 1 0~255
unsigned short 2 0~65535
unsigned int 4 0~40亿
unsigned long 4(32位)/8(64位)
unsigned long long 8 0~1开头的20位整数

注意:由于定义无符号数据时比较麻烦,标准库中把这些类型重新定义成了新的类型名
需要包含头文件<stdint.h>
uint8_t uint16_t uint32_t uint64_t
int8_t int16_t int32_t int64_t

浮点型:

float 4 单精度浮点型
double 8 双精度浮点型
long double 12(32位)/16(64位)
注意:采用科学计数法、在二进制与真实数据之间需要进行换算过程,因此浮点数的运算使用速度比整型要慢得多,所以编程时尽量使用整型
注意:大部分操作系统只对小数点后6位有效

模拟型:

字符型:char
字符就是图案或符号,字符在内存中依然存储成整数,需要显示成字符时,操作系统会根据ASCII码表中的对应关系把整数显示成对应的符号或图案
'\0' 0 特殊字符 空字符
'0' 48
'A' 65
'a' 97
char想要显示成整数时:%hhd
想要显示成字符时: %c
布尔型:bool
先有的C语言后有的bool类型,C语言中不可能有真正的布尔类型,都是在<stdbool.h>中对布尔类型使用整数进行模拟
bool true false

二、变量与常量
什么是变量:

在程序运行期间值可以发生变化的叫做变量,相当于存放数据的盒子
    定义:
    类型名 变量名;
    int num;
取名规则:
1、由字母、数字、下划线组成
2、不能以数字开头
3、不能与C语言32个关键字重名
4、见名知意(功能、类型、范围...)
* 注意:变量的初始值默认是随机的,为了安全起见,一般会在定义时初始化为0**
使用:
赋值: 变量名 = val;
参与运算: 变量名10;
变量的输入、输出:
int printf(const char *format, ...);
功能: 输出数据
format: "提示信息+占位符"
...: 变量名列表
返回值: 成功输出的字符个数
类型占位符: C语言通过占位符的方式传递变量的类型
signed char short int long long long
%hhd %hd %d %ld %lld
unsigned %hhu %hu %u %lu %llu
float %f double %lf long double %LF
int scanf(const char *format, ...);

  功能:                输入数据
format:           "占位符"
 ... :                     变量地址列表
 返回值:           成功输入的变量个数
    注意:scanf需要变量类型和地址
      变量地址 == &变量名

什么是常量:在程序运行期间数值不变化的叫做常量
    10                  默认int
    10l                 long
    10ll                long long
    10u                unsigned int
    10lu               unsigned long
    10llu              unsigned long long 
    3.14               默认double
    3.14f              float
    3.14l              long double
三、数据的格式化输出

%nd 显示n个字符宽度,不足时补空格,右对齐

%-nd 显示n个字符宽度,不足时补空格,左对齐

%0nd 显示n个字符宽度,不足时补0,右对齐

%n.mf 显示n个字符宽度(小数点也算一位),不足时补空格,右对齐,m表示小数点后显示的位数(四舍五入)

%g 不显示小数点后多余的0

四、运算符
自变运算符:

++/--: 让变量的值自动加1或减1
前自变:++/--num 立即有效
后自变:num++/-- 下一行语句才有效
注意: 不要在一行代码中多次出现自变运算符

算术运算符:

- * / %
整数/整数 只保留整数部分
/ % 除数不能为0,否则会在运行时出现浮点数例外(核心已转储)
% 不能对浮点数求余

关系运算符:

== !=     >     <     >=     <=
会得到比较结果是1(成立)或0(不成立),比较的结果还可以继续参与运算
int n = -10;
10 < n < 100; 与数学比较不一样,是永远为真
注意:建议常量放== != 的左边,防止少些一个=

逻辑运算符:

&&         ||         !
会先把运算对象转换成逻辑值:非零转为真,0转为假,然后再参与逻辑运算
A && B         一假即假
A || B           一真即真
!A 求反
&& 和 || 的短路特性:
当左边部分的值已经可以确定整个逻辑运算符的结果时,那么右边部分不执行
也可以借助短路特性,实现简单的单分支效果

三目运算符:

A ? B : C ;
判断A的值如果为真(非0)则执行B,否则执行C

赋值运算符:

= += -= *= ...
    a += b; a =a+b;
    注意:赋值运算符的运算结果是右边赋的数据

位运算符:

& | ~ ^ << >>

sizeof 也是一个运算符

注意:运算符是有优先级之分,如果记不住,那么多加小括号

五、类型转换问题

只有相同类型的数据才能进行运算,如果类型不相同的数据需要先转换成相同的类型才能运算
自动类型转换:
转换规则:以不丢失数据为基础,可以适当地牺牲一些空间
            1、字节少的向字节多的转
            2、有符号的向无符号的转
            3、整型向浮点型转
特殊特例:当运算对象类型只是 char或者short,且类型不同,编译器会做类型提升,提升为int再运算
强制类型转换:
(新类型名)数据;
有丢失数据的风险,但是需要使用时还是得用

六、if分支语句

if(表达式) // 单分支语句
{
// 表达式的值为真(非0),则执行此处代码
}

if(表达式) // 双分支语句
{
// 表达式的值为真(非0),则执行此处代码
}
else
{
// 表达式的值为假(0),则执行此处代码
}

if(表达式1) // 多分支语句
{
// 表达式1的值为真(非0),则执行此处代码
}
else if(表达式2)
{
// 表达式2的值为真,则执行此处代码
}
...
else
{
// 所有表达式都为假,最后执行此处代码
}

七、switch开关语句

switch(n) //n可以是数值、表达式,结果必须是整型
{
case val1: // val必须是常整数,如果n等于val,则打开执行开关
                break; // 关闭执行开关
        // swtich不可以与continue配合
case val2:
default: // 如果所有case都不打开,则最后打开此开关 // 无论位置在哪,都会最后执行
}

注意:
    case n1 ... n3:
        表示在范围[n1,n3]内,会打开case开关,但是这属于GNU编译器的特有语法,不建议使用

标签:char,day03,数据类型,unsigned,long,C语言,运算符,int,类型
From: https://www.cnblogs.com/bigflyny/p/17566726.html

相关文章

  • c语言学习7
    函数传参1、函数中定义的变量属于该函数,出了该函数就不能再被别的函数直接使用2、实参与形参之间是以赋值的方式进行传递数据的,并且是单向值传递3、return语句其实是把返回值数据放入公共区域内存中(调用者和被调用者都可以访问),调用者会从该区域获取返回值;如果不写return语句,......
  • 在C语言中嵌入python,未定义的符号。PyExc_ImportError
    本文是小编为大家收集整理的关于在C语言中嵌入python,未定义的符号。PyExc_ImportError的处理/解决方法,可以参考本文帮助大家快速定位并解决问题,中文翻译不准确的可切换到English标签页查看源文。中文English问题描述点击免费获取 CRMEB开源商城系统源码 ......
  • C语言内嵌Python import时提示undefined symbol错误及解决
    项目切gcc4.6版本时,C语言内嵌了python,运行bin文件import时出现importError错误,提示python-2.7.11/lib/python2.7/lib-dynload/_collections.so:undefinedsymbol:_Py_ZeroStruct. 基本代码如下: #include<Python.h>#include<stdio.h>#include<stdlib.h> intmain(......
  • 关于module:undefined symbol:PyExc_ImportError在C语言中嵌入Python时
    cimporterrormakefilemodulepython-2.7undefinedsymbol:PyExc_ImportErrorwhenembeddingPythoninC 我正在开发一个C共享库,该库可以调用python脚本。当我运行应用程序时,出现以下错误:12345678910Traceback (mostrecentcalllast): File"/home/ubuntu......
  • MySQL把choose表中的report改名为score,数据类型改为float; 将choose表的score默
    MySQL把choose表中的report改名为score,数据类型改为float;将choose表的score默认值设为0流程步骤步骤操作1.连接至MySQL数据库2.切换至对应数据库3.修改表结构,将report改名为score并更改数据类型4.设定score字段的默认值为0具体步骤与代码示例步骤......
  • C语言:数据类型之整形(一)
     什么是数据?记录一天各个时间的温度,那么这个温度就是数据.记录一个水库水位的变化值,那么这个值就是数据.什么是数据类型?1215是整数12.23是小数"helloworld"是一段话基本数据类型:数值类型:整形,浮点型。整形顾名思义就是整数,像:1,2,3,4,5就是整形整形在C语言的关键字是:int......
  • 初识C语言--2
    指针,指针的大小为4或8字节,取决于使用系统的地址线,32位为4字节。指针变量——用来存放地址取地址——int*p=&a;inta=10;//创建一个空间,此空间有一个地址名,空间存放的值为10int*p=&a;//创建一个空间,名字为p,里面存放的为a的地址*p=20;//*p的意义为p空间中存放的地址,其指......
  • C# 基础数据类型
    一. 在C#中,基础数据类型的取值范围和所占空间字节数如下:1.bool:-取值范围:true或false-空间字节数:12.byte:-取值范围:0到255-空间字节数:13.sbyte:-取值范围:-128到127-空间字节数:14.char:-取值范:Unicode字符集中的任意字......
  • C语言如何实现DES加密与解密
    C语言实现DES加密解密#include"des.h"//移位表staticTable_sizeconstshiftTable[NumberOfKeys]={1,1,2,2,2,2,2,2,1,2,2,2,2,2,2,1};//E扩展表staticTable_sizeconsteTable[des_key_pc2_standard]={ 32,1,2,3,4,5,4,5,6,7,......
  • c语言static关键字的用法
    今天的c语言学习中遇到了static关键字,由于对这个关键字的用法比较模糊,但是这个关键字的作用很大,以下是它的用法:一、修饰局部变量(1)用静态关键字static修饰的局部变量,在编译的过程中,会在数据区为该变量开辟空间,并对其进行初始化,如果代码中未对其进行初始化,则系统默认初始化......