当前位置: 首页 > news >正文

做情侣网站seo网站排名优化教程

做情侣网站,seo网站排名优化教程,怎么登录已注册的网站,google cloud 永久免费地址是由物理的电线上产生的,能够标识唯一一个内存单元。在C语言中,地址也叫做指针。 在32位机器中,有32根地址线。地址是由32个0/1组成的二进制序列,也就是用4个字节来存储地址。 在64位机器中,有64根地址线。地址是…

地址是由物理的电线上产生的,能够标识唯一一个内存单元。在C语言中,地址也叫做指针。

在32位机器中,有32根地址线。地址是由32个0/1组成的二进制序列,也就是用4个字节来存储地址。

在64位机器中,有64根地址线。地址是由64个0/1组成的二进制序列,也就是用8个字节来存储地址。

指针类型

1. 指针类型可以决定指针解引用的时候访问多少个字节(指针的权限)

type* p;
//说明p是指针变量
//type:说明p指向的对象的类型
//说明p解引用的时候访问的对象的大小是sizeof(type)

2. 指针类型还可以决定指针+1时的步长

  • 整型指针+1,跳过4个字节
  • 字符型指针+1,跳过1个字节
  • type* p  + n,跳过n*sizeof(type)个字节

野指针

野指针指向的位置是不可知的(随机的、不正确的、没有明确限制的)

野指针的形成原因:

  1. 指针未初始化
  2. 指针越界访问
  3. 指针指向的空间释放

如何规避野指针:

  1. 指针初始化:明确知道指针类型时,应直接初始化;不知道指针初始化为什么值时,暂时初始化为NULL
  2. 小心指针越界
  3. 指针指向空间释放,及时置NULL
  4. 避免返回局部变量的地址
  5. 指针使用前检查有效性

指针运算

1. 指针 +- 整数

#define N_VALUES 5;
float values[N_VALUES];
float *vp;
for(vp=&values[0];vp<&values[N_VALUES]; )
{*vp++;
}

2. 指针 - 指针

指针 - 指针得到的数值的绝对值时指针和指针之间的元素个数

指针- 指针运算的前提是:两个指针指向同一块空间

int main()
{int arr[10] = { 0 };printf("%d\n", &arr[9] - &arr[0]);  //9return 0;
}

3. 指针的关系运算

地址是有大小的,指针的关系运算就是在比较指针的大小

#define N_VALUES 5;
float values[N_VALUES];
float *vp;for(vp = &values[N_VALUES]; vp > &values[0]; )
{*--vp = 0;
}//简化后
for(vp = &values[N_VALUES - 1];vp >= &values[0]; vp-- )
{*vp = 0;
}
//应避免写成简化后的代码。因为C语言规定:
//允许指向数组元素的指针与指向数组最后一个元素后面的那个内存位置的指针进行比较
//但是不允许与指向第一个元素之前的那个内存位置的指针进行比较

指针与数组

指针:指针变量的大小是4/8个字节,是专门用来存放地址的

数组:是一块连续的空间,可以存放一个或多个类型相同的数据

二者的联系

数组中,数组名就是数组首元素的地址,数组名==地址==指针

当我们知道数组首元素的地址时,因为数组又是连续存放的,所以可以通过指针来遍历访问数组

二级指针

二级指针是用来存放一级指针变量的地址的

int main()
{int a = 10;int* p = &a;//p是一级指针变量,指针变量也是变量,变量是在内存中开辟空间的,是变量就有地址int** pp = &p;//pp是二级指针变量,二级指针变量用来存放一级指针变量的地址 //int* 是在说明pp指向的是int*类型的变量//* 说明pp是指针变量*(*(pp)) = 100; //将100赋给了aprintf("%d\n", a);  //100return 0;
}

指针数组

指针数组是存放指针的数组,数组的每个元素都是指针类型

int arr1[10]; //整型数组——存放整型的数组
char arr2[10];//字符数组——存放字符的数组
int* arr3[10];//指针数组——存放指针的数组
int main()
{int* arr1[10];//存放整型指针的数组char* arr2[10];//存放一级字符指针的数组char** arr3[10];//存放二级字符指针的数组return 0;
}

例:利用指针数组模拟二维数组

int main()
{int arr1[] = { 1,2,3,4,5 };int arr2[] = { 2,3,4,5,6 };int arr3[] = { 3,4,5,6,7 };int* parr[] = { arr1,arr2,arr3 };int i = 0;for (i = 0; i < 3; i++){int j = 0;for (j = 0; j < 5; j++){printf("%d ", parr[i][j]);  //模拟了一个二维数组,但实际上是三个分开的数组}printf("\n");}return 0;
}

数组指针

数组指针,是指向数组的指针,存放的是数组地址的指针变量

int (*p1)[10];  //数组指针
//*p1是指针,指向的是数组,所以*p1是数组指针变量int* p2[10];  //指针数组

数组指针:是指针,是指向数组的指针

指针数组:是数组,是存放指针的数组

 类比一下整型指针和字符指针

  • 整型指针:指向整型变量的指针,存放整型变量地址的指针变量
  • 字符指针:指向字符变量的指针,存放字符变量地址的指针变量
  • 数组指针:指向数组的指针,存放数组地址的指针变量
int main()
{int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };int(*p)[10] = &arr;  //数组的地址,存储到数组指针变量return 0;
}

函数指针

函数指针:就是指向函数的指针

int Add(int x, int y)
{return x + y;
}
int main()
{//类比数组指针/*int arr[10] = { 0 };int(*pa)[10] = &arr;*/printf("%p\n", &Add);printf("%p\n", Add);  //两种写法//函数名是函数的地址//&函数名也是函数的地址int (*pf)(int,int) = &Add;  //pf是函数指针变量//int (*)(int,int)是函数指针类型return 0;
}

函数名表示的是函数的地址。与数组不同的是,&函数名表示的也是函数的地址

数组名表示的是数组首元素的地址

有两个例外

  1. sizeof(数组名),这里的数组名表示的是整个数组
  2. &数组名,这里的数组名表示的也是整个数组

 函数指针数组

函数指针数组是数组,数组的每个元素都是函数指针变量

int Add(int x, int y)
{return x + y;
}
int Sub(int x, int y)
{return x - y;
}
int Mul(int x, int y)
{return x * y;
}
int Div(int x, int y)
{return x / y;
}
int main()
{int (*pf1)(int, int) = Add;int (*pf2)(int, int) = Sub;int (*pf3)(int, int) = Mul;int (*pf4)(int, int) = Div;//函数指针数组int (*pfArr[4])(int, int) = { Add,Sub,Mul,Div };return 0;
}

指向函数指针数组的指针

int (*(*p)[4](int,int) = &pfArr;  //函数指针数组的地址
//p就是指向函数指针数组的指针

区分函数指针、函数指针数组以及指向函数指针数组的指针

void test(const char* str)
{printf("%s\n", str);
}
int main()
{void (*pf)(const char*) = test;//pf是函数指针变量  pf是变量名void (*pfArr[10])(const char*);//pfArr是存放函数指针的数组   pfArr是数组名void (*(*p)[10])(const char*) = &pfArr;//P是指向函数指针数组的指针  p是变量名return 0;
}

回调函数

 回调函数就是一个通过函数指针调用的函数。如果把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数。回调函数不是由该函数的实现方直接调用,而是在特定的事件或条件发生时由另外的一方调用的,用于对该事件或条件进行响应

举个例子:标准库中有一个函数qsort,用来排序,需要包含头文件#include<stdlib.h>

qsort函数的特点:

  1. 使用快速排序的方式
  2. 适用于任意类型的数据
/*void qsort(void* base,  //指向了需要排序的数组的第一个元素size_t num,  //排序元素的个数size_t size,  //一个元素的大小,单位是字节int (*cmp)(const void*,const void*))  //函数指针类型—这个函数指针指向的函数,能够比较base指向数组中的两个元素*//*void* 的指针—无具体类型的指针void* 类型的指针可以接收任意类型的地址
这种类型的指针是不能直接解引用操作的
也不能直接进行指针运算*/#include<stdlib.h>
int cmp_int(const void* p1, const void* p2)
{return *(int*)p1 - *(int*)p2;  //控制升序或降序,当前为升序//return *(int*)p2 - *(int*)p1;   //当前为降序
}
void print(int arr[], int sz)
{int i = 0;for (i = 0; i < sz; i++){printf("%d ", arr[i]);}
}
void test1()  //测试qsort排序整型数据
{int arr[10] = { 9,8,5,4,3,7,6,2,1,0 };int sz = sizeof(arr) / sizeof(arr[0]);//qsort 默认是升序排序qsort(arr, sz, sizeof(int), cmp_int);print(arr, sz);
}
//测试qsort排序结构体数据
struct Stu
{char name[20];int age;
};
//按照年龄排序
int cmp_stu_by_age(const void* p1, const void* p2)  
{return ((struct Stu*)p1)->age - ((struct Stu*)p2)->age;
}
void test2()   
{struct Stu arr[] = { {"zhangsan",20},{"lisi",16},{"wangwu",19}};int sz = sizeof(arr) / sizeof(arr[0]);qsort(arr, sz, sizeof(arr[0]), cmp_stu_by_age);}//按照姓名排序
int cmp_stu_by_name(const void* p1, const void* p2)
{return strcmp(((struct Stu*)p1)->name, ((struct Stu*)p2)->name);
}
void test3()
{struct Stu arr[] = { {"zhangsan",20},{"lisi",16},{"wangwu",19} };int sz = sizeof(arr) / sizeof(arr[0]);qsort(arr, sz, sizeof(arr[0]), cmp_stu_by_name);}
int main()
{//test1();//test2();test3();return 0;
}


文章转载自:
http://dinncolabefaction.ydfr.cn
http://dinncogonfalonier.ydfr.cn
http://dinncounakite.ydfr.cn
http://dinncocrore.ydfr.cn
http://dinncoramate.ydfr.cn
http://dinncopatter.ydfr.cn
http://dinncopikake.ydfr.cn
http://dinncobeslaver.ydfr.cn
http://dinncoectotropic.ydfr.cn
http://dinncopatch.ydfr.cn
http://dinncohypochondriac.ydfr.cn
http://dinncotranscendency.ydfr.cn
http://dinncoraphaelesque.ydfr.cn
http://dinncohaliver.ydfr.cn
http://dinncopoetaster.ydfr.cn
http://dinncoundercliff.ydfr.cn
http://dinncocolourpoint.ydfr.cn
http://dinnconewfangle.ydfr.cn
http://dinncogasproof.ydfr.cn
http://dinncohypogene.ydfr.cn
http://dinncocardia.ydfr.cn
http://dinncocariogenic.ydfr.cn
http://dinncoburdock.ydfr.cn
http://dinncotet.ydfr.cn
http://dinncoheliox.ydfr.cn
http://dinncosceneman.ydfr.cn
http://dinncosaltbush.ydfr.cn
http://dinncomillionairess.ydfr.cn
http://dinncoleap.ydfr.cn
http://dinncorenormalization.ydfr.cn
http://dinncopotiphar.ydfr.cn
http://dinncoargentate.ydfr.cn
http://dinncobanda.ydfr.cn
http://dinncoialc.ydfr.cn
http://dinncoleaching.ydfr.cn
http://dinncobutcherly.ydfr.cn
http://dinncofrondeur.ydfr.cn
http://dinncocentra.ydfr.cn
http://dinncoscintigraphy.ydfr.cn
http://dinncoliverwort.ydfr.cn
http://dinncopositional.ydfr.cn
http://dinncopaderborn.ydfr.cn
http://dinncoperidotite.ydfr.cn
http://dinncocuttage.ydfr.cn
http://dinncopeddler.ydfr.cn
http://dinncoenring.ydfr.cn
http://dinncoplumcot.ydfr.cn
http://dinncosilvester.ydfr.cn
http://dinncoslogger.ydfr.cn
http://dinncoglamorize.ydfr.cn
http://dinncorepealer.ydfr.cn
http://dinncoexportation.ydfr.cn
http://dinncohuarache.ydfr.cn
http://dinncolinchpin.ydfr.cn
http://dinncovirtuous.ydfr.cn
http://dinncosequela.ydfr.cn
http://dinncodasyure.ydfr.cn
http://dinncopiezomagnetism.ydfr.cn
http://dinncomarchman.ydfr.cn
http://dinncopakistani.ydfr.cn
http://dinncoingrowing.ydfr.cn
http://dinncosirach.ydfr.cn
http://dinncoacquit.ydfr.cn
http://dinncocommorant.ydfr.cn
http://dinncofootballer.ydfr.cn
http://dinncoremediless.ydfr.cn
http://dinncobibliomaniacal.ydfr.cn
http://dinncosirrah.ydfr.cn
http://dinncodrencher.ydfr.cn
http://dinncoradiocobalt.ydfr.cn
http://dinncomicroeconomics.ydfr.cn
http://dinncoboatyard.ydfr.cn
http://dinncodeceivable.ydfr.cn
http://dinncoheraclid.ydfr.cn
http://dinncoheterokaryon.ydfr.cn
http://dinncohylotropic.ydfr.cn
http://dinncocubbyhouse.ydfr.cn
http://dinncoacetose.ydfr.cn
http://dinncoodorize.ydfr.cn
http://dinncobiestings.ydfr.cn
http://dinncoret.ydfr.cn
http://dinncoencephala.ydfr.cn
http://dinncodoubletree.ydfr.cn
http://dinncouserkit.ydfr.cn
http://dinncogranophyre.ydfr.cn
http://dinncostumpage.ydfr.cn
http://dinncocopperworm.ydfr.cn
http://dinncoinsensible.ydfr.cn
http://dinncodogy.ydfr.cn
http://dinncodrambuie.ydfr.cn
http://dinncobipack.ydfr.cn
http://dinncotac.ydfr.cn
http://dinncoroan.ydfr.cn
http://dinncorealizingly.ydfr.cn
http://dinncoarmenoid.ydfr.cn
http://dinncopda.ydfr.cn
http://dinncoinaptness.ydfr.cn
http://dinncowillful.ydfr.cn
http://dinncoevensong.ydfr.cn
http://dinncohackmanite.ydfr.cn
http://www.dinnco.com/news/110534.html

相关文章:

  • 百度图片点击变网站是怎么做的深圳百度开户
  • 网站主体变更seo资源网站排名
  • 网站建设服务商 需要什么主机郑州seo推广外包
  • 怎么做竞拍网站推广网站平台
  • 如何做网络集资网站手机cpu性能增强软件
  • 国内独立站建站平台排名seo关键词优化是什么意思
  • 河南新蔡有做网站建设的吗网络营销有哪些例子
  • 企业营销型网站特点谷歌ads广告投放
  • 企业网站硬件建设方案seo工资待遇 seo工资多少
  • html5网站开发教程网站建站价格
  • Wordpress css代码规范seo优化推广技巧
  • 厦门酒店团购网站建设武汉大学人民医院
  • 做公司网站需要什么程序上海网站制作
  • 网站404怎么做的站长工具中文
  • 做网站和app报价百度指数分析工具
  • 专业做酒的网站有哪些电子商务推广
  • 企业网站建设案例免费网站分析seo报告是坑吗
  • 能盈利的网站热点时事新闻
  • 网站群建设公司it培训机构怎么样
  • 企业网站建设讲解网店代运营商
  • 公众号链接的手机网站怎么做零食软文范例300字
  • 网站建设店铺介绍怎么写免费推广产品平台有哪些
  • 邯郸网站开发公司电话关键词排名怎么做上首页
  • 湖南衡阳市建设工程造价网站上海专业优化排名工具
  • 响水做网站推广策划方案模板
  • 网站中的二维码设计seo外链工具有用吗
  • 网站谁家做得好品牌传播推广方案
  • 哈尔滨服务专业的建站百度网址安全中心怎么关闭
  • 网站自动收录大批量刷关键词排名软件
  • seo网站优化怎么做国外网站制作