c语言赋值互换
⑴ 将c语言中的char语句和赋值语句交换位置后会怎么样
C语言必须先定义变量再使用变量(比如赋值、取值等)
如
char A;
A='A';
如果违反这个规定的话,编译器将会报错导致编译无法继续进行。
⑵ c语言 将变量A和B的值进行互换 的程序
代码如下:#include<stdio.h>
#include <stdlib.h>
void swap1(int& a,int& b)//使用中间变量交换两个值
{
int temp = a;
a = b;
b = temp;
}
void swap2(int& a, int& b) //只用加法、减法、乘法也可以交换两个值
{
a = a + b;
b = a - b;
a = a - b;
}
void swap3(int& a, int& b) //使用位运算也可以交换两个值
{
a = a^b;
b = a^b;
a = a^b;
}
void main1mianshiti7()
{
int a1 = 1, b1 = 2;
int a2 = 10, b2 = 15;
int a3 = 78, b3 = 90;
int a = 2147483647, b = 1;
printf("a1=%p,b1=%p", &a1, &b1);
swap1(a1, b1);
swap2(a2, b2);
swap3(a3, b3);
printf("swap after~~~~~~~~~~~~~
");
printf("a1=%d,b1=%d
", a1, b1);
printf("a2=%d,b2=%d
", a2, b2);
printf("a3=%d,b3=%d
", a3, b3);
swap2(a, b);
printf("a=%d,b=%d
", a, b);
system("pause");
}
源代码截图:
C语言是一门通用计算机编程语言,广泛应用于底层开发。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。
尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台。
二十世纪八十年代,为了避免各开发厂商用的C语言语法产生差异,由美国国家标准局为C语言制定了一套完整的美国国家标准语法,称为ANSI C,作为C语言最初的标准。[1]目前2011年12月8日,国际标准化组织(ISO)和国际电工委员会(IEC)发布的C11标准是C语言的第三个官方标准,也是C语言的最新标准,该标准更好的支持了汉字函数名和汉字标识符,一定程度上实现了汉字编程。
C语言是一门面向过程的计算机编程语言,与C++,Java等面向对象的编程语言有所不同。
其编译器主要有Clang、GCC、WIN-TC、SUBLIME、MSVC、Turbo C等。
⑶ C语言中为什么可以不增加新变量将两个变量的值互换
C语言中为什么可以不增加新变量将两个变量的值互换。
纯粹的数学转换而已,没有任何值得称道的地方。实际编程中没有人会这样做。
这里考察的只是你对于基础数学逻辑的掌握。与程序而言,并无益处,只是提高了程序的逻辑复杂度。
⑷ c语言中三个整型数a b c怎么进行值的互换
二个变量值的交换一般需借助于一个辅助变量来完成的。
int
a=3,b=4,t;
通过以下的三个语句就能把a,b的值互换(这种操作有点像把二个瓶里的液体交换时,要借助于一个空瓶):
t=a;
a=b;
b=t;
不太清楚什么是“a
b
c值的互换”。如果是要把a=1,b=2,c=3“轮换”为a=2,b=3,c=1的话,
那就用下面的语句实现:
t=a;
a=b;
b=c;
c=t;
如果是要把任意大小顺序的三个变量,通过交换变为从小到大排列,可以采用以下的程序段:
int
a,b,c,t;
scanf("%d
%d
%d",&a,&b,&c);
if(a>b){t=a;
a=b;
b=t;}
if(a>c){t=a;
a=c;
c=t;}
if(b>c){t=b;
b=c;
c=t;}
printf("从小到大的排列是:%d
%d
%d\n",a,b,c);
⑸ C语言之 两个值的互换
这跟等不等没有关系
c语言中
=
的意思是把右边的书的值给左边的数
执行c=a;a=b;b=c
就是把a
的值给c
c的值就没有了
变成a
的值了,
其余的也是这样,
就像两杯水
要让他们换过来,
就要把其中的一杯倒到另一只空杯子里
把另一杯倒到刚空出来的杯子里
然后再把第三只杯子里的水倒到第一只杯子里的道理是一样的
⑹ c语言如何 把结构体内的变量的值互换
同类型结构体间可以直接赋值
struct phoneinfor s1,s2,temp;
temp=s1;
s1=s2;
s2=temp;
你这个不行:
if(strcmp(phonebook[j].name,phonebook[j+1].name)>0)
{
phonebook3=phonebook[j];
//phonebook3是phoneinfor3类型的,你得把它定义为phoneinfor类型的
phoneinforphonebook[j]=phonebook[j+1];
phonebook[j+1]=phonebook3;
}
⑺ c语言结构体成员之间的值怎么对换
structzombiet;
t=z[j];
z[j]=z[j+1];
z[j+1]=t;
这样可以整体赋值。
⑻ c语言怎么实现两个数据交换
将两个数进行互换的方法有两种形式:
1、借助中间变量完成,此方法直观,易理解,使用最多
2、不需要中间变量,通过变量身的运算完成交换。
⑼ 在C语言中的各种赋值是如何转换的
关于赋值操作,你可以查看一下博客的内容,初学者不用理解底层汇编的实现机制,有点晦涩,随着自己的进步可以进一步的深入底层查看其实现原理
1 代码案例
iint main()
{
int n,m;
char ch;
float f = 12.12;
double d=121.111;
n = f; //单精度浮点赋值给整数
m =d; //双精度浮点赋值给整数
ch = n; //整数赋值给字符值
ch = f; //浮点赋值给字符值
f = d; //整数变量赋值给浮点变量;
return 0;
}
2 以上代码调试运行对应的汇编代码分析
101: float f = 12.12; //单精度浮点赋值:占用4个字节,需要1条汇编指令实现
源代码对应1条汇编指令:
00401C78 mov dword ptr [ebp-10h],4141EB85h
102: double d=121.111; //双精度浮点赋值:占用8个字节,需要2条汇编指令实现
源代码对应2条汇编指令:
00401C7F mov dword ptr [ebp-18h],9FBE76C9h
00401C86 mov dword ptr [ebp-14h],405E471Ah
103: n = f; //单精度浮点赋值给整数
源代码对应3条汇编指令:
00401C8D fld dword ptr [ebp-10h]
00401C90 call __ftol (004232cc)
00401C95 mov dword ptr [ebp-4],eax
104: m =d; //双精度浮点赋值给整数
源代码对应3条汇编指令:实际的类型转换通过调用内部C运行时接口函数__ftol来实现类型转换。
00401C98 fld qword ptr [ebp-18h]
00401C9B call __ftol (004232cc) //调用__ftol函数(对应15条汇编指令,见下面3描述)
00401CA0 mov dword ptr [ebp-8],eax
105: ch = n; //整数赋值给字符值
源代码对应2条汇编指令:
00401CA3 mov al,byte ptr [ebp-4]
00401CA6 mov byte ptr [ebp-0Ch],al
106: ch = f; //浮点赋值给字符值
源代码对应3条汇编指令:
00401CA9 fld dword ptr [ebp-10h]
00401CAC call __ftol (004232cc)
00401CB1 mov byte ptr [ebp-0Ch],al
107: f = d; // 整数转换为浮点数,源代码对应2条汇编指令:
00401CB4 fld qword ptr [ebp-18h]
00401CB7 fstp dword ptr [ebp-10h]
3 赋值涉及的__ftol函数对应的汇编指令:
__ftol 函数对应以下16条指令:
004232CC push ebp
004232CD mov ebp,esp
004232CF add esp,0F4h
004232D2 wait
004232D3 fnstcw word ptr [ebp-2]
004232D6 wait
004232D7 mov ax,word ptr [ebp-2]
004232DB or ah,0Ch
004232DE mov word ptr [ebp-4],ax
004232E2 fldcw word ptr [ebp-4]
004232E5 fistp qword ptr [ebp-0Ch]
004232E8 fldcw word ptr [ebp-2]
004232EB mov eax,dword ptr [ebp-0Ch]
004232EE mov edx,dword ptr [ebp-8]
004232F1 leave
004232F2 ret
4 C运行库(Run-Time Library)存在的原因
4.1 定义(摘自《软件调试》,张银奎)
当编译器在将高级语言编译到第几语言的过程是,因为高级语言中的某些比较负责的运算符(如不同的类型转换)要对应比较多的低级语言指令(如汇编、机器指 令),为了防止这样的指令段多次重复出现在目标代码中(造成目标码过大),编译器通常将这些指令段封装为函数,然后将高级语言的某些操作翻译为函数调用。
C标准定义了标准C函数,C++标准定义了C++标准类库,这些库通常被称为支持库,这些库是程序编译运行的必要条件,因此支持库也称为运行库(Run-Time Library).
VC提供了C和C++运行库。
4.2 例子
1)如上面例子,VC编译器通常将 n =f( n :整数,f:浮点数)这样的赋值编译为调用__ftol函数;
2)VC编译器也将new ,delete 操作符编译为对malloc和free函数调用(可以通过单步调试运行,反汇编单步跟着call 指令观察分析验证!)
5 总结
1)通过以上分析,不同类型变量转换,是编译程序在编译程序过程中,将操作转换编译成调用运行库函数来实现的。
2)一般程序设计过程中,不是必要情况下,不要频繁使用不同类型互相转换的操作,特别是涉及到循环运算、性能的优化的程序!
⑽ C语言中如何交换两个指针变量的的值
1、首先,就是最基本的知识,写头文件、函数声明、定义变量。