c语言赋值是什么?
C语言中的结构体变量可以用另一个变量对其进行赋值或初始化。
简单结构体(不包含指针成员)直接赋值没有问题。但是稍微复杂一点的结构体里面会有指针成员,那么以上的浅拷贝则会有问题。
赋值会直接将结构体的指针变量被赋值,赋值之前其所指向的内存单元丢失,赋值之后若该指针指向的内存单元被其它指针释放掉,那么继续使用该成员指针的话则有可能导致内存泄漏。
概述:
在C语言中,结构体(struct)指的是一种数据结构,是C语言中聚合数据类型(aggregate data type)的一类。结构体可以被声明为变量、指针或数组等,用以实现较复杂的数据结构。
结构体同时也是一些元素的集合,这些元素称为结构体的成员(member),且这些成员可以为不同的类型,成员一般用名字访问。
C++提供了许多种基本的数据类型(如int、float、double、char等)供用户使用。但是由于程序需要处理的问题往往比较复杂,而且呈多样化,已有的数据类型显得不能满足使用要求。
C语言中怎么给一个结构体用scanf进行赋值?
结构体数组指针作为函数参数,通过数组的首地址与偏移量对结构体数组进行scanf的赋值,在函数中通过指针间接访问到其指向的内存。
举例:编写函数,输入5个学号(int),5个姓名(字符串),5个成绩数组(每组三个成绩)(int[3]),依次调用函数
#include stdio.h
#include stdlib.h
struct student //建立结构体,学号,姓名,3门课的分数
{
int num;
char name[10];
int score[3];
}Stu[5]; //初始化,一共5个学生的数据
void getScore(struct student * p) //函数:向结构体读取分数,一共三门课
{
int i, j;
for (i = 0; i 5; i++)
for (j = 0; j 3; j++)
scanf_s(“%d”, ((p+i)-score[j]));
}
void getNum(struct student * p) //函数:向结构体读取学号
{
int i;
for (i = 0; i 5;i++)
scanf_s(“%d”, (p + i)-num);
}
void getName(struct student * p) //函数:向结构体读取姓名
{
int i;
for (i = 0; i 5; i++)
scanf(“%s”, (p + i)-name);
}
int main()
{
int i, j, average[3] = { 0 }; //average数组储存每门课的平均分
getNum(Stu); //函数调用
getName(Stu);
getScore(Stu);
for (j = 0; j 3; j++)
{
for (i = 0; i 5; i++)
average[j] += Stu[i].score[j];
}
for (i = 0; i 5; i++)
{
printf(“num = %d name = %s Score:”, Stu[i].num, Stu[i].name); //依次打印学号 姓名
//printf(“%d %d %d”, Stu[0].score[0],Stu[0].score[1],Stu[0].score[2]);
for (j = 0; j 3; j++) //打印三门课的分数
printf(” %d”, Stu[i].score[j]);
printf(“\n”);
}
printf(“average:”);
for (i = 0; i 3; i++)
printf(“%f “, (float)average[i]/5); //打印三门课平均分
printf(“\n”);
system(“pause”);
return 0;
}
如:
scanf(“%c%c%c”,a,b,c);
输入为:
d e f
则把’d’赋予a, ‘ ‘(空格)赋予b,’e’赋予c。因为%c 只要求读入一个字符,后面不需要用空格作为两个字符的间隔,因此把’ ‘作为下一个字符送给b。
只有当输入为:def(字符间无空格) 时,才能把’d’赋于a,’e’赋予b,’f’赋予c。
扩展资料:
1、函数原型
int scanf(const char * restrict format,…);
函数 scanf() 是从标准输入流stdin [1] (标准输入设备,一般指向键盘)中读内容的通用子程序,可以说明的格式读入多个字符,并保存在对应地址的变量中。
函数的第一个参数是格式字符串,它指定了输入的格式,并按照格式说明符解析输入对应位置的信息并存储于可变参数列表中对应的指针所指位置。每一个指针要求非空,并且与字符串中的格式符一一顺次对应。
2、返回值
scanf函数返回成功读入的数据项数,读入数据时遇到了“文件结束”则返回EOF。如:
scanf(“%d %d”,a,b);函数返回值为int型。如果a和b都被成功读入,那么scanf的返回值就是2;
如果只有a被成功读入,返回值为1;如果a和b都未被成功读入,返回值为0;如果遇到错误或遇到end of file,返回值为EOF。end of file为Ctrl+z 或者Ctrl+d。
例:使用scanf函数输入数据。
#include stdio.h
int main(void)
{
int a,b,c;
printf(“Give me the value of a,b,c seperated with whitespaces:\n”);
scanf(“%d%d%d”,a,b,c);
printf(“a=%d,b=%d,c=%d\n”,a,b,c);
return 0;
}
注意:a,b,c中的是寻址操作符,a表示对象a在内存中的地址,是一个右值。变量a,b,c的地址是在编译阶段分配的(存储顺序由编译器决定)。
如果scanf中%d是连着写的如“%d%d%d”,在输入数据时,数据之间不可以用逗号分隔,只能用空白字符(空格或tab键或者回车键)分隔——“2 (空格)3(tab) 4” 或 “2(tab)3(回车)4”等。若是“%d,%d,%d”,则在输入数据时需要加“,”,如“2,3,4”。
参考资料:
百度百科——scanf(计算机语言函数)
c语言结构体函数指针怎么赋值
指针就是指向内存的某个地址的一个变量。
结构体指针就是这个指针变量的值必须指向存放该结构体的内存位置。
当这个指针没有任何指向时,可以赋值为null值,但是改指针不可使用,程序中应该做判断。下面是一些赋值演示。
struct student{
int id;
int score;
} aaa;
struct student *p = null;//结构体指针p初始化赋值为null
struct student *p2=aaa;//p2指向aaa
struct student *p3=(struct student *)malloc(sizeof(struct student));//内存中申请一个结构体空间,并将地址强制转换为结构体指针变量赋值给p3
C语言,结构体中的数组怎么赋值,?
intmain(void){
structstudentsbao={};
printf(“%d,%s\n”,bao.id,bao.name);//输出是4224528,空(应该是null)
//structstudentsbao={3,”123″};可以。第一种赋值方法
//strcpy(bao.name,”bao”);//可以,
//printf(“%d,%s\n”,bao.id,bao.name);
//bao.name=”bao”;错误“stray’\351’inprogram”其他是乱码,
//bao.name[0]=’a’;
//bao.name[0]=’/0′;
//printf(“%d,%s\n”,bao.id,bao.name);
/*这样可以,*/
//chararr[10]=”baobao”;
////bao.name=arr;//error”assignmenttoexpressionwitharraytype”
//scanf(“%s”,bao.name);//可以,
//printf(“%d,%s\n”,bao.id,bao.name);
//所以scanf那一类函数都可以。
//还有就是memcpy函数也是可以
return0;}
扩展资料:
选择结构:
顺序结构的程序虽然能解决计算、输出等问题,但不能做判断再选择。对于要先做判断再选择的问题就要使用选择结构。选择结构的执行是依据一定的条件选择执行路径,而不是严格按照语句出现的物理顺序。
选择结构的程序设计方法的关键在于构造合适的分支条件和分析程序流程,根据不同的程序流程选择适当的选择语句。选择结构适合于带有逻辑或关系比较等条件判断的计算,设计这类程序时往往都要先绘制其程序流程图,然后根据程序流程写出源程序。
这样做把程序设计分析与语言分开,使得问题简单化,易于理解。程序流程图是根据解题分析所绘制的程序执行流程图。
参考资料来源:百度百科-c语言
c语言结构体数组赋值
(1)用字符常量逐个初始化数组。例如:
char a[8]={‘i’,’l’,’o’,’v’,’e’,’y’,’o’,’u’};
把8个字符依次分别赋给c[0]~c[7]这8个元素。
如果在定义字符数组时不进行初始化,则数组中各元素的值是不可预料的。如果花括号中提供的初值个数(即字符个数)大于数组长度,则出现语法错误。
如果初值个数小于数组长度,则只将这些字符赋给数组中前面那些元素,其余的元素自动定为空字符(即’\0’)。
如果提供的初值个数与预定的数组长度相同,在定义时可以省略数组长度,系统会自动根据初值个数确定数组长度。
例如:char c[]={‘c’,‘’,‘p’,‘r’,‘o’,’g’,’r’,’a’,’m’};
这时c数组的长度自动定为9。也可以定义和初始化一个二维字符数组,例如:
char diamond[5][5]={{”,”,’#’},{”,’#’,”,’#’},{‘#’,”,”,”,’#’},
{”,’#’,”,’#’},{”,”,’#’}};用它代表一个菱形的平面图形。
(2)字符串常量初始化数组。例如:
char c[]={‘c’,‘’,‘p’,‘r’,‘o’,’g’,’r’,’a’,’m’};
可写为:char c[]={“C program”};
或去掉{}写为:char c[]=”C program”;
注意:此时数组c的长度不是9,而是10。因为字符串常量的最后由系统加上一个’\0’。上面的初始化与下面的初始化等价。
char c[]={‘c’,‘’,‘p’,‘r’,‘o’,’g’,’r’,’a’,’m’,’\0′};
扩展资料:
其定义的一般形式是:char数组名[数据长度]
例如:
char c[10];
c[0]=’I’;c[1]=”;c[2]=’l’;c[3]=’o’;c[4]=’v’;c[5]=’e’;c[6]=”;c[7]=’y’;c[8]=’o’;c[9]=’u’;
以上定义了c为字符数组,包含10个元素。
由于字符型数据是以整数形式(ASCII代码)存放的,因此也可以用整型数组来存放字符数据,例如:
int c[10];
但这时每个数组元素占2个字节的内存单元,浪费存储空间。
字符数组也可以是二维或多维数组,例如:
char c[5][10];
即为二维字符数组。
初始化
字符数组的初始化与数值型数组初始化没有本质区别。但它除了可以逐个给数组元素赋予字符外,也可以直接用字符串对其初始化。
输入输出
字符数组的输入
(1)用getchar()或scanf()的’%c’格式符对数组进行字符赋值。例如,对于数组a[10]:用getchar()赋值:
for(i=0;ilt;10;i++)
alt;igt;=getchar();
用scanf()赋值:
for(i=0;ilt;10;i++)
scanf(“%c”,alt;igt;);
(2)用scanf()的’%s’格式对数组赋值。还是对于数组a[10]:
scanf(“%s”,a);
或
scanf(“%s“,a[0]);
输入”C program“并回车时,a数组会自动包含一个以”\0“结尾的字符串”C program“。
字符数组的输出
(1)用putchar()或printf()的‘%c’格式符对数组进行字符赋值。例如,对于数组a[10]:用putchar()赋值:
for(i=0;ilt;10;i++)
alt;igt;=putchar();
用printf()赋值:
for(i=0;ilt;10;i++)
printf(“%c”,alt;igt;);
输出结果为:
c program
(2)用printf()的’%s’格式对数组赋值。还是对于数组a[10];
printf(“%s”,a);
输出结果为:
c program
参考资料:
百度百科——字符数组
在C语言中.结构体变量之间可以相互赋值吗
结构体变量直接赋值,就是其本身内存地址空间,按照地址分布直接赋值。
所以两个一样的结构变量可以直接赋值。
但是如果结构成员中有指针,且指针指向的地址大小不一样,是不能直接赋值的。