流程控制

顺序结构、选择结构、循环结构

1、顺序结构

程序默认是顺序执行的。

2、选择结构

if选择语句

  第一种情况

  if(条件)//条件成立执行下面语句

  {

    //语句

  }

  第二种情况

  if(条件)//条件成立执行下面语句,否则执行else里面的语句

  {

    //语句

  }

  else

  {

    //语句

  }

    第三种情况

  if(条件1)//条件1成立执行下面语句,否则执行下面else if 里面的语句

  {

    //语句1

  }

  else if(条件2)//条件2成立执行下面语句,否则执行else if 里面的语句

  {

    //语句2

  }

  else if(条件3)//条件3成立执行下面语句,否则执行else里面的语句

  {

    //语句3

  }

  else//如果上面的语句都没执行,最后会执行这个

  {

    //语句4

  }

switch结构

switch(表达式)//表达式执行结果满足下面的哪个数值就执行哪一段,否则执行default语句

{

  case 数值1:语句1

    break;

  case 数值2:语句2

    break;

  case 数值3:语句3

    break;

  default:语句4

    break;

 }

3、循环结构

while 循环

do while循环

for 循环

  1、while 循环

  while(条件)//判断条件,成立则执行语句,然后再判断条件,成立则执行语句,不成立就结束循环

  {

    语句;

  }

  continue 和 break区别

  continue是结束本次循环,进入下一次循环。

  break是结束整个循环。

  2、do while循环

  do

  {

    语句;

  }while(条件);//先执行语句判断条件,至少执行一次

  3、for循环

  for(语句1;条件;语句2)

  {

    循环体;

  }

  语句1:执行一次,初始化语句

  语句2:增量语句,判断条件后执行循环体,然后执行语句2,再次判断条件

注意:循环可嵌套

  for(;;)

  {

    for(;;)

    {

      while()

      {}

    }

  }

无意间看到静态局部变量的使用,复习一下吧。

  静态局部变量与全局变量共享全局数据区,但静态局部变量只在定义它的函数中可见。静态局部变量与局部变量在存储位置上不同,使得其存在的时限也不同,导致对这两者操作 的运行结果也不同。

 #include <stdio.h>
static int Gloable = ;//静态全局变量 void Test()
{
//静态局部变量,分配在静态存储去,只在函数内部可见
static int a = ;//,内存地址只会分配一次,数值操作累加
int b= ;//局部变量,每次都是重新分配
b ++;
a ++;
printf("静态局部变量:%d\n",a);
printf("局部变量:%d\n",b);
}
int main(void) {
// your code goes here
int i;
for( i = ; i < ;i++)
{
Gloable++;
Test();
}
printf("静态全局变量:%d",Gloable); return ;
}

注意事项: 
(1) 静态局部变量在静态存储区内分配存储单元。在程序整个运行期间都不释放。而自动变量(即动态局部变量)属于动态存储类别,存储在动态存储区空间(而不是静态存储区空间),函数调用结束后即释放。 
(2) 为静态局部变量赋初值是在编译时进行值的,即只赋初值一次,在程序运行时它已有初值。以后每次调用函数时不再重新赋初值而只是保留上次函数调用结束时的 值。而为自动变量赋初值,不是在编译时进行的,而是在函数调用时进行,每调用一次函数重新给一次初值,相当于执行一次赋值语句。

(3) 如果在定义局部变量时不赋初值的话,对静态局部变量来说,编译时自动赋初值0(对数值型变量)或空字符(对字符型变量)。而对自动变量来说,如果不赋初 值,则它的值是一个不确定的值。这是由于每次函数调用结束后存储单元已释放,下次调用时又重新另分配存储单元,而所分配的单元中的值是不确定的。 
(4) 虽然静态局部变量在函数调用结束后仍然存在,但其他函数是不能引用它的,也就是说,在其他函数中它是“不可见”的。

关于类型转换

  int与float/double

  将浮点数(单双精度)转换为整数时,将舍弃浮点数的小数部分, 只保留整数部分。

  将整型值赋给浮点型变量,数值不变,只将形式改为浮点形式, 即小数点后带若干个0.

  float与double

  float 型数据只是在尾部加0延长为doub1e型数据参加运算,然后直接赋值。

  doub1e型数据转换为float型时,通过截尾数来实现,截断前要进行四舍五入操作。

  char 与 int

  int型数值赋给char型变量时,只保留其最低8位,高位部分舍弃。 

  char 类型转换成int类型,直接获取char内部表示的值。

    char c = 'a';//字符a对应ascii 为97

    int n = c; //故n为97

  自动类型转换

  int a = 10.55+10;//这里会对10.55进行自动类型转换

  强制类型转换

  强制类型转换是通过类型转换运算来实现的。其一般形式为: (类型说明符) (表达式) 其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。

  int a = (int)10.55 +10;//这里是强制类型转换

简单例子如下

#include <stdio.h>

int main(void) {
// your code goes here char c = 'a';
int n = ;
float f = 6.4f;
double d = 8.855234f; printf("char :%d\n",c);
printf("int :%d\n",n);
printf("float :%f\n",f);
printf("double :%f\n",d); printf("***************\n"); c = c + ;//int 转换char
printf("char :%c\n",c);
n = c;//char转换int
printf("int :%d\n",n);
n = n + f;//float转换int
printf("int :%d\n",n);
f = d + (double);//int转换double
printf("double :%f\n",d);
return ;
}

结果如下

char :97
int :1111
float :6.400000
double :8.855234
***************
char :c
int :99
int :105
double :8.855234

2015-4-9 今日如此,明日依旧。

ios开发学习笔记003-流程控制和类型转换的更多相关文章

  1. 李洪强iOS开发Swift篇—06_流程控制

    李洪强iOS开发Swift篇—06_流程控制 一.swift中的流程控制 Swift支持的流程结构如下: 循环结构:for.for-in.while.do-while 选择结构:if.switch 注 ...

  2. iOS开发学习笔记:基础篇

    iOS开发需要一台Mac电脑.Xcode以及iOS SDK.因为苹果设备都具有自己封闭的环境,所以iOS程序的开发必须在Mac设备上完成(当然,黑苹果应该也是可以的,但就需要花很多的精力去折腾基础环境 ...

  3. ios开发学习笔记(1)

    objective-c基础总结 第一二章 1.application:didiFinishLauchingWithOptions:程序启动后立即执行 2.启动界面代码格式:self.window = ...

  4. 【原】Java学习笔记005 - 流程控制

    package cn.temptation; public class Sample01 { public static void main(String[] args) { // 程序的流程控制(流 ...

  5. Python学习笔记 - day4 - 流程控制

    Python流程控制 Python中的流程控制主要包含两部分:条件判断和循环. Python的缩进和语法 为什么要在这里说缩进和语法,是因为将要学习的条件判断和分支将会涉及到多行代码,在java.c等 ...

  6. PYTHON 学习笔记2 流程控制工具以及函数定义、匿名函数

    前言 在上一节的学习中.已经介绍了几种基本类型.包括字符串的定义,以及字符串中索引.切片.字符串拼接的使用方法.以及基本的整形数据运算.一些之前都没有了解过的运算符.比如 ** 乘方 //整数除法等. ...

  7. C#学习笔记_04_流程控制

    04_流程控制 程序的执行结构: 顺序结构 分支结构 循环结构 可以通过某些特定的控制语句来控制代码的执行结构 分支流程控制 if else 基本语法 可以只有if没有else,但是不能没有if只有e ...

  8. JavaSE学习笔记03流程控制

    Java流程控制 1.顺序结构 java的基本结构就是顺序结构,除非特别指明,否则就按照顺序一句一句往下执行. 顺序结构是最简单的算法结构,它是任何一个算法都离不开的一种基本算法结构. 2. 选择结构 ...

  9. ios开发学习笔记(这里一定有你想要的东西,全部免费)

    1,Search Bar 怎样去掉背景的颜色(storyboard里只能设置background颜色,可是发现clear Color无法使用). 其实在代码里还是可以设置的,那就是删除背景view [ ...

随机推荐

  1. hihoCoder hiho一下 第二周 #1014 : Trie树(Trie树基本应用)

    思路: 完全看题目中的介绍就行了.还有里面的input写道:不保证是英文单词,也有可能是火星文单词哦.比赛结束后的提交是不用考虑26个字母之外的,都会AC,如果考虑128种可能的话,爆了内存.步骤就是 ...

  2. LeetCode OJ 3Sum 3个整数之和

    题意:给一个vector<int>容器,要求每当找到3个元素之和为0时就将这3个数按大小顺序记下来,用一个二维vector返回.也就是vector< vector<int> ...

  3. WORD窗体保护密码清除

    Word 2003破解方法如下:1.用Word打开已设置有密码的“保护文档”(原始DOC文件):2.菜单中选择“文件”→“另存为Web页”,保存为HTML文件然后关闭Word:3.用文本编辑器(如:记 ...

  4. IOS Quarzt2D 手动的释放

    - (void)drawRect:(CGRect)rect { // 1.获取上下文 CGContextRef ctx = UIGraphicsGetCurrentContext(); // 2.绘制 ...

  5. UVA 215 Spreadsheet Calculator (模拟)

    模拟题.每个单元格有表达式就dfs,如果有环那么就不能解析,可能会重复访问到不能解析的单元格,丢set里或者数组判下重复. 这种题首先框架要对,变量名不要取的太乱,细节比较多,知道的库函数越多越容易写 ...

  6. hdu-2680 Choose the best route---dijkstra+反向存图或者建立超级源点

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2680 题目大意: 给你一个有向图,一个起点集合,一个终点,求最短路 解题思路: 1.自己多加一个超级 ...

  7. 【洛谷2051】[AHOI2009] 中国象棋(烦人的动态规划)

    点此看题面 大致题意: 让你在一张\(N*M\)的棋盘上摆放炮,使其无法互相攻击,问有多少种摆法. 辟谣 听某大佬说这是一道状压\(DP\)题,于是兴冲冲地去做,看完数据范围彻底懵了:\(N≤100\ ...

  8. Web前端学习流程

  9. linux怎么进home目录下

    可以使用cd命令,cd命令的功能是切换到指定的目录: 命令格式:cd [目录名] 有几个符号作为目录名有特殊的含义: “/”代表根目录.“..”代表上一级目录.“~”代表HOME目录.“-”代表前一目 ...

  10. 复习C++_指针、动态分配内存

    注意:++i指的是先计算i+1,然后将其赋给i cout<<str[7]<<endl; //输出a 注:交换失败 注意:delete释放之后,变为迷途指针. 注:n--> ...