本文主要是介绍linux下c语言-day7,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
可以存储地址的变量称为指针,但是知道变量P是一个指针是不够的,更重要的是,编译器必须知道它所指的变量类型,char,int,long所指的类型都不一样。
通过间接运算符*可以访问指针所指的变量值。这个运算符也可以称为取消引用运算符,因为它用于取消对指针的引用。而且声明指针时,一定要初始化他们。使用未初始化的指针存储数据项是很危险的。在使用指针存储一个值时,谁也不知道会覆盖什么内容。
指针是一个变量,他的值是给定类型的另一个变量或常量的地址。使用指针可以在不同的时间访问不同的变量,只要他们的类型相同即可。数组和指针的区别:可以改变指针包含的地址,但不能改变数组名称引用的地址。
而在多维数组中时,用数组名称和一个索引值访问这个二维数组时,例如board【0】,就是在引用一个子数组的地址。仅使用二维数组名称,就是引用该二维数组的开始地址,他也是第一个子数组的开始地址。
内存的使用:
在程序执行期间分配内存时,内存区域中的这个空间称为:堆。还有另一个内存区域,称为堆栈,其中的空间分配给函数的参数和本地变量。在执行完该函数后,存储参数和本地变量的内存空间就会释放
动态分配内存:malloc()函数
使用这个函数时,需要在程序中包含头文件<stdlib.h>。使用malloc()函数需指定要分配的内存字节数作为参数。这个函数返回所分配内存的第一个字节的地址。因为反悔的是一个地址,所以这里可以使用指针。
举个栗子:int *pNumber = (int *)malloc(100);
这条语句请求100个字节的内存,并把这个内存块地址赋予pNumber。只要不修改它,任何时间使用这个变量pNumber,他都会指向所分配的100个字节的第一个int的位置。这个内存块能保存25个int值,每个int占4个字节。
如果因某种原因而不能分配请求的内存,malloc()会返回一个NULL指针。这个指针等于0.最好先用if语句检查请求动态分配的内存是否已分配,在使用它。就如同money,每money又想花钱,会带来灾难性的后果。所以最好写一句话:
if(pNumber == NULL)
{
*/code to deal with no memory allocated */
}
下面就来看一看使用sizeof运算符来分配内存用来显现多个质数的例子,下面是代码片:
#include#include#includeint main()
{
unsigned long *primes = NULL;
unsigned long trial = 0;
bool found = false;
size_t total =0;
size_t count = 0;
int i =0;
printf("How many primes would you like - you will get at least 4 ? ");
scanf("%u",&total);
total = total<4U ? 4U:total;
primes = (unsigned long *)malloc(total*sizeof(unsigned long));
if(primes == NULL)
{
printf("\n Not enough memory .Baby.\n");
return 1;
}
*primes = 2UL;
*(primes + 1) = 3UL;
*(primes + 2) = 5UL;
count = 3U;
trial = 5U;
while(count < total)
{
trial += 2UL;
for(i = 0; i < count ;i ++)
if(!(found = (trial % *(primes+i))))
break;
if(found)
*(primes+count++) = trial;
}
for(i = 0 ; i < total; i++)
{
if(!(i%5U))
printf("\n");
printf("%12lu",*(primes + i));
}
printf("\n");
return 0;
}
这篇关于linux下c语言-day7的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!