波奇学c:如何找到一个变量?指针

目录

指针是地址,指针变量存放变量。

指针大小

不同指针类型意义

存放不同类型指针,但指针大小一样

访问字节数不一样,通过指针改变的字节数不同

指针步长不同

野指针

空指针:NULL

指针运算

指针加减整数:指向下一个步长的地址

指针减指针:两指针间的元素个数

特别的:在c语言,不允许和指向第一个元素前的内存的指针比较,但允许和指向最后一个的元素后内存的比较。(只是比较,不访问)

二级指针:存放一级指针地址的变量

数组指针:指向数组的指针

如何区分数组地址和首元素地址?

指针数组:数组里面放着指针

使用一维数组模拟二维数组:在一维数组里放一维数组指针。


指针是地址,指针变量存放变量。

通俗上:指针是存放地址的变量。

把指针当成两个变量(方块)之间的线,更容易理解。

指针大小

一个内存单元默认是一个字节。(1byte=8bit)每个内存单元有个编号叫做地址,取地址取的是第一个字节(内存单元)的地址,较小的地址。

int a=0;
&a

 

32位机器地址4个字节。

64位机器地址8个字节。

指针大小代表能访问的空间大小

不同指针类型意义

存放不同类型指针,但指针大小一样

int*存放int变量指针
int**存放int*变量指针
char*存放char变量指针

访问字节数不一样,通过指针改变的字节数不同

char*型只访问一个字节

int*型访问4个字节。

double*型访问8个字节
int a=0x11223344;
char* b=(char*)&a;
*b=0x44;
//机器小端存储
地址由低变高 44 33 22 11 

指针步长不同

char*+1跳过一个字节
int*+1跳过4个字节
int**+1跳过4/8个字节

野指针

指向不明确的,不确定的指针。

产生野指针的原因

指针变量不初始化,指向的变量就是随机值,变成野指针。

越界访问:超出数组范围也变成野指针。

指针指向的空间被释放。

eg:变量是在自定义函数的变量内,函数结束后那个变量已经被销毁,指针变成野指针。

空指针:NULL

p=NULL;//(NULL= (void*)0)初始化指针。

空指针不能解引用。

检测指针可用性,是否为NULL。

if(p!=NULL)

指针运算

指针加减整数:指向下一个步长的地址

int arr[10]={0};
int*a=arr;
a+1=&arr[1];

*(a++):arr[0],a=&arr[1]
*(++a):arr[1],a=&arr[1]

指针减指针:两指针间的元素个数

	int arr[10] = { 0 };
	int* a = arr;
	int* b = &arr[2];
	int c = b - a;//2
    //a-b:-2

前提:两块指针指向同一块空间,比如数组内。

特别的:在c语言,不允许和指向第一个元素前的内存的指针比较,但允许和指向最后一个的元素后内存的比较。(只是比较,不访问)

int* a = arr;
int* b = &arr[-1];
//b-a:报错
int* a = arr;
int* b = &arr[10];
//b-a:正常

二级指针:存放一级指针地址的变量

int a=0;
int*b=a;
int**c=&b;
//访问b:*c
访问a:**c;

数组指针:指向数组的指针

int arr[2];
&arr:int(*)[2]
&arr[0]:int*

*数组指针(数组的地址)和首元素的地址相同。

如何区分数组地址和首元素地址?

地址加1如果跳过一整个数组的空间:数组地址

跳过一个元素的空间:首元素地址

指针数组:数组里面放着指针

int* arr[3]={&a,&b,&c};
//&arr[0]:int**
//&arr:int*(*)[]

访问元素a

**a;

使用一维数组模拟二维数组:在一维数组里放一维数组指针。

//访问元素
*(*(p+m)+n)或p[m][n];

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要证明函数cos(x)/x的反常积分在区间0到4π上发散,可以使用极限比较测试法。 具体来说,我们可以考虑比较函数f(x) = cos(x)/x和一个已知的发散的函数g(x) = 1/x,当x趋近于无穷大时,两个函数的极限都等于零,即: lim x->∞ f(x)/g(x) = lim x->∞ x*cos(x) = ∞ 因此,根据极限比较测试法,如果一个函数在某一点x0处与一个发散的函数g(x)的比值趋近于无穷大,则该函数的反常积分也会在该点处发散。 由于f(x)和g(x)在区间[0,4π]上都是非负的,我们可以考虑比较它们在该区间上的积分,即: ∫[0,4π] f(x) dx / ∫[0,4π] g(x) dx 其中,第一个积分是f(x)在[0,4π]上的反常积分,而第二个积分是g(x)在[0,4π]上的反常积分,它等于: ∫[0,4π] g(x) dx = ∫[0,4π] 1/x dx = ∞ 因此,我们只需要证明第一个积分也是发散的即可。 由于f(x)在x=0处有一个可去的奇点,我们可以将其分为两部分,即: ∫[0,4π] f(x) dx = ∫[0,δ] f(x) dx + ∫[δ,4π] f(x) dx 其中,δ是一个小正数,使得f(x)在区间[0,δ]上是有界的。因此,第一个积分是有限的,可以忽略。 对于第二个积分,我们可以使用分部积分法,令u = 1/x,dv = cos(x) dx,则du = -1/x^2 dx,v = sin(x),有: ∫[δ,4π] f(x) dx = ∫[δ,4π] cos(x)/x dx = [sin(x)/x]δ^4π - ∫[δ,4π] sin(x)/x^2 dx = sin(δ)/δ - sin(4π)/4π - ∫[δ,4π] sin(x)/x^2 dx 当δ趋近于零时,sin(δ)/δ趋近于1,因此第一个项是有限的。而第二个项可以使用同样的方法继续分部积分,并得到: ∫[δ,4π] sin(x)/x^2 dx = [-cos(x)/x]δ^4π + ∫[δ,4π] 2cos(x)/x^3 dx = cos(δ)/δ + cos(4π)/4π + 2∫[δ,4π] cos(x)/x^3 dx 同

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值