C-class Week2.Day9 & test2 summary

指针

指针数组和数组指针:
指针数组:

​ 是由指针组成的数组,里面都是指针,它的成员都是指针变量。

​ 类型 *arr[长度]; int *arr[10];

数组指针:

​ 专门指向数组的指针

​ 类型 (*arr)[长度];

#include<stdio.h>

int main(int argc,const char* argv[])
{
    int arr[10]={0,1,2,3,4,5,6,7,8,9};

    /*int* arrp[10];
    for(int i=0;i<10;i++)
    {
        arrp[i] = &arr[i];
        printf("%d %d\n",arr[i],*arrp[i]);
    }
    return 0;*/
    
    int *p1 =(int*)(&arr+1);
    printf("%d\n",*(p1-1));

    int (*p2)[10]=&arr;
    for(int i=0;i<5;i++)
    {   
        printf("%d\n",(*p2)[i]);
    }   
    //int (*arrp)[10] = &arr;
    //printf("%u %u\n",&arr,&arr+1);
    //printf("%p %p %p %p\n",arrp,&arr,arr,&arr[0]);
    return 0;
}
指针与数组名:

​ 数组名是一种特殊的指针,它是常量,不能修改他的值, 它与数组内存是映射关系,没有自己空间。

​ 数组名 == &数组名 == &数组[0]

​ 指针变量有自己的储存空间,如果它储存的是数组的首地址,指针可以当做数组使用,数组名也可以当做指针使用。

​ 数组名[i] == *(数组名+i);

​ *(指针名+i) == 指针名[i];

​ 数组作为函数参数传递时,就会变成指针,所以长度丢失。

int arr[5] = {0,1,2,3,4};
int *p1 =arr;
int *p2 = &arr[0];
for(int i=0;i<5;i++)
{
	printf("%d ",p[i]);
    printf("%d ",*(p2+i));
    printf("%d ",*(arr+i));
}
二级指针:

​ 二级指针就是指向指针的指针。里面储存的指针变量的地址。

定义:

​ 类型** 变量名_pp;

赋值:

​ 变量名_pp = 地址;

​ 变量名_pp = &指针变量;

解引用:

​ *变量名_pp == 一级指针变量 p

​ **变量名_pp == 普通变量的值

注意:

​ 当函数之间需要共享指针变量时,必须传递二级指针

//数组指针就是二级指针
int arr[5]={0,1,2,3,4};
int (*pp)[5] = &arr;
printf("%d\n",**pp);

void swap(int **pp1,int **pp2)
{
    int *temp = NULL;
    temp = *pp1;
    *pp1 = *pp2;
    *pp2 = temp; 
}

int main()
{
	int num1 =1234,num2 = 5678;
    int *p1 = &num1,*p2 = &num2;
    printf("原版---%d %d\n",num1,num2);
    printf("原版指针----%d %d\n",*p1,*p2);

    swap(&p1,&p2);
    printf("交换后---%d %d\n",num1,num2);
    printf("交换后指针----%d %d\n",*p1,*p2);
	//结果为 num1与num2位发生改变、*p1 与 *p2 交换了值
}
函数指针:

​ 函数返回值 (*函数指针名p)(参数列表);

	int scanf(const char *format,...);

​ 函数名就是个地址(整数),它代表了函数在代码段中的位置。可以通过函数指针,来指向某个函数。

储存的就是函数在代码段中的位置。

​ 可以通过函数指针,把函数作为参数传递给另一个函数,这叫回调。

堆内存

什么是堆内存:

​ 是进程中的一个内存段(text data bss heap stack),由程序员手动管理。

​ 特点是足够大,缺点使用较为麻烦。

为什么要使用堆内存:

​ 1、随着程序的复杂、数据会越来越多。

​ 2、其他的内存段的申请和释放都不受控制,堆内存的申请和释放都受程序员控制

如何使用堆内存:

​ 在C语言中没有控制堆内存的语句,只能使用C标准库中提供的函数来使用堆内存。

#include<stdlib.h> 头文件
void malloc(size_t size);
	void *malloc(size_t size);
	int *p = malloc(4)

功能:从堆内存中申请size个字节的内存,申请的内存中存储的内容是不确定的

size: 表示要申请的字节数大小

返回值:成功时返回成功申请到的内存的首地址,失败时返回NULL

void free(void *ptr);与malloc捆绑使用
    void free(void *ptr);
	free(p);
	p = NULL;

功能:释放一块内存,NULL可以释放,但是不能连续释放和释放非法地址。

ptr: 要释放的堆内存的首地址。

注意:堆内存不要连续释放,释放后及时置空,空指针可以连续释放。

​ 释放的只是使用权、不会专门去清理全部数据

void *calloc(size_t nmemb, size_t size);
	void *calloc(size_t nmemb, size_t size);
	int *p =calloc(10,sizeof(int));

功能:从堆内存中申请nmemb块大小为size字节的内存,申请到的内存块会被初始化为0。

​ 特点 速度慢、

注意:申请到的依然是一块连续内存

void *realloc(void *ptr, size_t size);
	void *realloc(void *ptr, size_t size);

功能:改变已有的内存大小

ptr: 要改变大小的内存的首地址

size:你要想改变之后的大小,会在原有的内存上添加或者删除内存空间。因为后面连续的内存可能会被他人使用,

会拷贝当前空间 到后面未使用空间从新定义一个空间新的首地址来实现你所需要的空间大小。

返回值:返回调整后的内存块的首地址。

考试总结:

1.以后再看到0开头或者0x开头的数字一定要转成 八进制,或者十六进制

2.数组越界的后果

​ 1、可能一切正常

​ 2、可能段错误

​ 3、可能产生脏数据

3.sizeof( )只会猜测括号内字节数最多的类型,并不会计算括号内的算式。

4.把float类型数赋值给int类型数组会导致小数点和后面的数据被抹除 ,但是成功运行。

5.无符号和有符号数一起计算 结果为无符号

6.text 代码段中存放二进制文件,常量。

7.const如果修饰 被初始化过的全局变量 会被放在代码段

8.代码阅读题 需要结合代码进行分析,不要脱离代码谈理论。

9.static 延长了生命周期,导致第二次程序运行时,初始化语句失效

10.time(NULL)

	yyyy-mm-dd-hh-mm-ss;

	ss = sec%60;

	mm = sec/60%60;

	hh = sec/3600%24;
	
	bool is_leap(int year)
	{
		return ~
	}
	
	void dtd(day)
	{
		int year = 1970;
		while(day>=365)
		{
			day -= (365+is_leap(year));
			year++;
		}
	
	int month[12]={31,28,30,31,30,31,30,31,31,30,31,30,31};
	
	month[1] +=28 is_leap(year);
	int month = 1;
	for(int i=0;month[i]<day;i++)
	{
		day -= month[i];
		month++;
		}
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要停止命令&quot;nohup python -u main.py &gt; test2.log 2&gt;&amp;1 &amp;&quot;,可以使用以下步骤: 1. 首先,要找到正在运行该命令的进程的PID(进程ID)。可以使用命令&quot;ps -ef | grep &#39;python -u main.py&#39;&quot;来查找相关进程的信息。其中,&quot;ps -ef&quot;命令将显示当前正在运行的所有进程,而&quot;grep &#39;python -u main.py&#39;&quot;命令将过滤出包含&quot;python -u main.py&quot;的相关进程信息。 2. 一旦找到了相关进程的PID,可以使用命令&quot;kill PID&quot;来停止该进程。其中,&quot;PID&quot;是进程的实际ID。例如,如果找到的PID是1234,那么可以使用命令&quot;kill 1234&quot;来停止该进程。 3. 如果进程没有立即停止,可以尝试使用带有&quot;-9&quot;选项的命令&quot;kill -9 PID&quot;来强制停止进程。这将发送一个SIGKILL信号给进程,强制终止它。 请注意,停止进程可能需要管理员权限。如果你没有足够的权限来停止进程,你可能需要联系系统管理员或拥有相应权限的用户来执行这个操作。&lt;span class=&quot;em&quot;&gt;1&lt;/span&gt;&lt;span class=&quot;em&quot;&gt;2&lt;/span&gt;&lt;span class=&quot;em&quot;&gt;3&lt;/span&gt; #### 引用[.reference_title] - *1* *2* [nohup python -u &times;&times;&times;.py > &times;&times;&times;.log 2>&amp;1 &amp;的作用](https://blog.csdn.net/weixin_44492824/article/details/122373054)[target=&quot;_blank&quot; data-report-click={&quot;spm&quot;:&quot;1018.2226.3001.9630&quot;,&quot;extra&quot;:{&quot;utm_source&quot;:&quot;vip_chatgpt_common_search_pc_result&quot;,&quot;utm_medium&quot;:&quot;distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2&quot;}}] [.reference_item style=&quot;max-width: 50%&quot;] - *3* [nohup和&amp;的使用/2&gt;&amp;1是什么意思/怎么关闭nohup挂起的程序](https://blog.csdn.net/weixin_43479398/article/details/105877244)[target=&quot;_blank&quot; data-report-click={&quot;spm&quot;:&quot;1018.2226.3001.9630&quot;,&quot;extra&quot;:{&quot;utm_source&quot;:&quot;vip_chatgpt_common_search_pc_result&quot;,&quot;utm_medium&quot;:&quot;distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2&quot;}}] [.reference_item style=&quot;max-width: 50%&quot;] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值