5.2 作业

本文通过实例展示了C语言中的内存管理技巧,包括动态分配、局部变量、函数指针以及结构体操作,强调了栈与堆的区别,并提到了可能遇到的常见陷阱,如悬空指针和栈溢出。
摘要由CSDN通过智能技术生成

 

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
//1
void GetMemory_1(char* p){
    p = (char *)malloc(100);//值传递
}

void Test_1(void){
    char* str = NULL;
    GetMemory_1(str);
    strcpy(str, "hello world");//段错误
    printf(str);
}


//2
char* GetMemory_2(void){
    char p[] = "hello world";                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         
    return p;//返回局部变量的地址
}

void Test_2(void){
    char* str = NULL;
    str = GetMemory_2();//悬空指针
    printf(str);//段错误或其他垃圾数据
}

//3
void GetMemory_3(char** p, int num){
    *p = (char *)malloc(num);
}

void Test_3(void){
    char* str = NULL;
    GetMemory_3(&str, 100);
    strcpy(str, "hello");
    printf(str);//hello
}

//4
void Test_4(void){
    char* str = (char *)malloc(100);
    strcpy(str, "hello");
    free(str);//free指向已释放的内存区域
    if(str!=NULL){
        strcpy(str, "world");//段错误
        printf(str);
    }
}

//5
int a;//a
int* a;//b
int** a;//c
int a[10];//d
int* a[10];//e
int (*a)[10];//f
int (*a)(int);//g
int (*a[10])(int);//h
int (*(*a)[10])(int);//一个指向有十个函数指针的数组的指针

//6
char str[] = "Hello";//sizeof(str)=6
char* p = str;//sizeof(p)=2
int n = 10;//sizeof(n)=2

//7
void Func(char str[100]){
}
//sizeof(str)=2

//8
void* p = malloc(100);
//sizeof(p)=2

//9
int counter(int i){
    static int count = 0;
    count = count + i;
    return (count);
}

main(){
    int i, j;
    for(i = 0; i <= 5; i++)
        j = counter(i);
}
//b 15

//10
main(){
    struct node{
        int a;
        int b;
        int c;
    };//2+2+2=6
    struct node s = {3,5,6};
    struct node* pt = &s;
    printf("%d", *(int*)pt);
}
//a 3

//11
int foo(int x, int n){
    int val;
    val = 1;
    if(n>0){
        if(n%2==1)
            val = val*x;
        val = val*foo(x*x, n/2);
    }
    return val;
}
//a x^n

//12
main(){
    int a[5] = {1,2,3,4,5};
    int* ptr = (int*)(&a+1);
    printf("%d %d", *(a+1), *(ptr-1));
}
//c 2 5

//13
void foo(int [][3]);
main(){
    int a[3][3] = {{1,2,3},{4,5,6},{7,8,9}};
    foo(a);
    printf("%d", a[2][1]);
}

void foo(int b[][3]){
    ++b;//b->[0][1]
    b[1][1]=9;//b[1][1]=*(*(b+1)+1)=a[2][1]
}
//b 9

//14
main(){
    int a,b,c,d;
    a=3;
    b=5;
    c=a,b;
    d=(a,b);
    printf("c=%d", c);
    printf("d=%d", d);
}
//3 5 c

//15
main(){
    int a[][3] = {1,2,3,4,5,6};
    int (*ptr)[3] = a;
    printf("%d %d", (*ptr)[1], (*ptr)[2]);
    ++ptr;
    printf("%d %d", (*ptr)[1], (*ptr)[2]);
}
//2 3 5 6 a

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值