C语言基础(十五)

news2025/1/25 9:06:24

指针的使用:

测试代码1:
 

#include <stdio.h>  
  
// 标准的 main 函数声明,包括可选的 envp 参数  
int main(int argc, char *argv[], char *envp[]) {  
    // argc 命令行参数的数量(包括程序名)  
    // argv 指向字符指针的指针数组,每个元素都是一个指向参数的字符串  
    // envp 指向环境变量的指针数组,每个元素都是一个指向环境字符串的指针 
    
    int time = getTime();
    // 打印程序名  
    printf("Program name: %s\n", argv[0]);  
  
    // 遍历命令行参数(除了程序名)  
    for (int i = 1; i < argc; i++) {  
        printf("Argument %d: %s\n", i, argv[i]);  
    }  
  
    // 通常不会在这里处理 envp,大多数程序中不是必需的。  
    // 如果需要访问环境变量 
    if (envp != NULL) {  
        for (int i = 0; envp[i] != NULL; i++) {  
            // 打印环境变量字符串,没有解析。 
            printf("Environment variable %d: %s\n", i, envp[i]);  
        }  
    }  
    return 0;  
}

运行结果如下:

 

测试代码2:

#include "date.h"
#include <stdio.h>  
  
int main() {  

    int time = getTime();
    int a = 10;  
    int b = 20;  
      
    // 定义两个整数指针  
    int *ptr1 = &a;  
    int *ptr2 = &b;  
      
    // 二级指针,初始时指向ptr1  
    int **pptr = &ptr1;  
    
    const char *ptr = "Hello";
    const char **ptr_ptr = &ptr;

    printf("Value of ptr: %s\n", ptr);
    printf("Value of ptr_ptr: %s\n", *ptr_ptr);

      
    printf("Before change: *ptr1 = %d, *ptr2 = %d\n", *ptr1, *ptr2);  
      
    // 通过pptr改变ptr1的值,让它指向ptr2所指向的地址  
    *pptr = ptr2;  
      
    // ptr1现在指向的是ptr2所指向的地址  
    printf("After change: *ptr1 = %d, *ptr2 = %d\n", *ptr1, *ptr2);  
      
    return 0;  
}

运行结果如下:

 

测试代码3:

#include "date.h" 
#include <stdio.h>  
#include <stdlib.h>  
#include <string.h> 
// 二级指针 
int main() {  
    int time = getTime();
    // 存储3个字符串  
    int numStrings = 3;  
    char **strings = (char **)malloc(numStrings * sizeof(char *));  
  
    // 检查malloc是否成功  
    if (strings == NULL) {  
        perror("Failed to allocate memory for strings");  
        return 1;  
    }  
  
    // 为每个字符串分配内存  
    for (int i = 0; i < numStrings; i++) {  
        strings[i] = (char *)malloc(50 * sizeof(char)); // 每个字符串最多49个字符加上一个'\0'  
        if (strings[i] == NULL) {  
            perror("Failed to allocate memory for a string");  
            // 释放之前分配的内存  
            for (int j = 0; j < i; j++) {  
                free(strings[j]);  
            }  
            free(strings);  
            return 1;  
        }  
    }  
  
    // 填充字符串  
    strcpy(strings[0], "Hello");  
    strcpy(strings[1], "World");  
    strcpy(strings[2], "C Programming");  
  
    // 通过二级指针访问和打印字符串  
    for (int i = 0; i < numStrings; i++) {  
        printf("%s\n", *(strings + i)); // 或者 strings[i]  
    }  
  
    // 释放内存  
    for (int i = 0; i < numStrings; i++) {  
        free(strings[i]);  
    }  
    free(strings);  
  
    return 0;  
}

运行结果如下:

 

测试代码4:

#include "date.h" 
#include <stdio.h>  

int add(int a, int b) {  
    return a + b;  
}  
  
int main() {  
    int time = getTime();
    // 基本数据类型的指针
    int var = 20;  
    int *ptr = &var;  
    printf("基本数据类型的指针: Value of var: %d, Value of *ptr: %d\n", var, *ptr);  
    *ptr = 22;  
    printf("修改后: Value of var: %d\n", var);  
  
    // 数组指针
    int arr[] = {10, 20, 30, 40, 50};  
    int *arrPtr = arr;  
    printf("数组指针: Value of arr[0]: %d, Value of arrPtr[0]: %d\n", arr[0], arrPtr[0]);  
    for (int i = 0; i < 5; i++) {  
        printf("arr[%d] = %d\n", i, *(arrPtr + i));  
    }  
  
    // 函数指针 
    int (*funcPtr)(int, int) = add;  
    int result = funcPtr(10, 20);  
    printf("函数指针: Result: %d\n", result);  
  
    // 二级指针(指针的指针)
    int var2 = 3000;  
    int *ptr2 = &var2;  
    int **pptr = &ptr2;  
    printf("二级指针: Value of var2: %d, Value of **pptr: %d\n", var2, **pptr);  
    **pptr = 4000;  
    printf("修改后: New value of var2: %d\n", var2);  
  
    return 0;  
}

运行结果如下:

 

测试代码5:

#include "date.h" 
#include <stdio.h>  
#include <stdlib.h>  
#include <string.h>  
  
// 函数声明  
int countSubstring(const char *str, const char *substr);  
  
int main() {  
    int time = getTime();
    char *inputStr = NULL; // 使用NULL初始化指针  
    char *searchStr = NULL; // 使用NULL初始化指针  
    int length, capacity = 1024; // 设置初始容量  
    int count;  
  
    // 分配内存给主串  
    inputStr = (char *)malloc(capacity * sizeof(char));  
    if (inputStr == NULL) {  
        perror("内存分配失败");  
        return 1;  
    }  
  
    // 分配内存给子串  
    searchStr = (char *)malloc(capacity * sizeof(char));  
    if (searchStr == NULL) {  
        free(inputStr);  
        perror("内存分配失败");  
        return 1;  
    }  
  
    // 输入主串  
    printf("请输入主串: ");  
    fgets(inputStr, capacity, stdin);  
    // 去除fgets读取的换行符  
    inputStr[strcspn(inputStr, "\n")] = 0;  
  
    // 输入子串  
    printf("请输入子串: ");  
    fgets(searchStr, capacity, stdin);  
    // 去除fgets读取的换行符  
    searchStr[strcspn(searchStr, "\n")] = 0;  
  
    // 检查输入是否为空  
    if (strlen(inputStr) == 0 || strlen(searchStr) == 0) {  
        printf("输入不能为空!\n");  
        free(inputStr);  
        free(searchStr);  
        return 1;  
    }  
  
    // 统计子串在主串中出现的次数  
    count = countSubstring(inputStr, searchStr);  
    printf("'%s' 在 '%s' 中出现了 %d 次。\n", searchStr, inputStr, count);  
  
    // 释放内存  
    free(inputStr);  
    free(searchStr);  
  
    return 0;  
}  
  
// 统计子串在主串中出现的次数  
int countSubstring(const char *str, const char *substr) {  
    int count = 0;  
    const char *tmp = str;  
    while ((tmp = strstr(tmp, substr)) != NULL) {  
        count++;  
        tmp++; // 移动到下一个字符,可能会错过重叠的子串  
        // 如果需要计算重叠子串,可以注释掉上面这行
    }  
    return count;  
}

运行结果如下:

 

 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2069630.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

github源码指引:一个自制代码生成器(嵌入式脚本语言)

初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github&#xff1a;codetoys&#xff0c;所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的&#xff0c;可以在任何平台上使用。 源码目录&#xff1a;CodeTemp…

Global Illumination_Reflective Shadow Maps Deep Optimizations

之前写过一篇Global Illumination_Reflective Shadow Maps&#xff08;RSM&#xff09;、Virtual Point Light&#xff08;VPL&#xff09;&#xff0c;近期重拾传统GI技术的实际工程场景中的应用&#xff0c;于是从效率方面对RSM、LPV、VCT技术进行效率优化&#xff0c;后续逐…

HTML 全解析:从基础到实战

一、简介 HTML&#xff08;HyperText Markup Language&#xff09;即超文本标记语言&#xff0c;是用于创建网页的标准标记语言。它通过各种标签来定义网页的结构和内容&#xff0c;使得浏览器能够正确地显示网页。HTML 文档由 HTML 元素组成&#xff0c;这些元素通过标签来表…

桌面整理大师 - Mac(苹果电脑)桌面整理工具软件

桌面整理大师 与 DeskWidgets 来自同一开发者&#xff0c;是一款专为 macOS 打造的桌面分区整理工具。 与 DeskWidgets 的文件分区组件相比&#xff0c;桌面整理大师拥有更加强大的功能&#xff0c;支持调整分区的大小和样式、可快速查看非桌面目录的文件…… 桌面整理大师的宗…

【Docker】Docker学习02 | docker-cli的基本命令

本文首发于 ❄️慕雪的寒舍 简单了解一下docker client的常用命令&#xff0c;更多命令可以查看完整命令列表。不同命令之间的关系&#xff0c;可以查看下图。 如果你看不到图片&#xff0c;不用担心&#xff0c;后面对每个命令进行介绍的时候&#xff0c;会提到它们的作用的。…

内存之RAM、SRAM、DRAM、ROM、FLASH、SDRAM、DDR*(一篇文章就懂)

内存之RAM、SRAM、DRAM、ROM、FLASH、SDRAM、DDR* 内存 内存&#xff08;Memory&#xff09;指的是内存存储器&#xff0c;又称为主存&#xff0c;是CPU用来直接寻址和存储的空间&#xff0c;它相当于一座桥梁&#xff0c;用以负责诸如硬盘、主板、显卡等硬件上的数据与处理器…

高性价比开放式运动耳机有哪些?五大高性价比开放式耳机分享

作为一名数码爱好者&#xff0c;从93年入坑耳机、音响等各类电子产品以来&#xff0c;一直在测试不同品牌、不同价位的产品。现在开放式耳机比较热门&#xff0c;我自然也是不能错过的&#xff0c;开放式耳机拥有很多优点&#xff0c;很多采用人体工学设计&#xff0c;能够更加…

UE5打包iOS运行查看Crash日志

1、查看Crash 1、通过xCode打开设备 2、选择APP打开最近的日志 3、选择崩溃时间点对应的日志 4、选择对应的工程打开 5、就能看到对应的Crash日志 2、为了防止Crash写代码需要注意 1、UObject在RemoveFromRoot之前先判断是否Root if (SelectedImage && Selecte…

fl studio mobile2024最新官方版V4.6.8安卓版+iOS苹果版

fl studio mobile&#xff0c;一款非常好用的音乐制作软件。该软件具有丰富多样的音乐类型让大家选择&#xff0c;内置多个好用的编辑工具、渲染工具、特效工具等可以使用。用户可以自由使用软件中的任何道具&#xff0c;直接在手机上编曲&#xff0c;进行音乐创作&#xff0c;…

买超声波清洗机什么牌子好?好用的超声波清洗机推荐

尽管超声波清洗机对不少人而言较为新鲜&#xff0c;尤其是对非眼镜佩戴者&#xff0c;但它其实并不陌生&#xff0c;常现身于眼镜店作为专业清洁工具。有人或许认为&#xff0c;拂去眼镜尘埃仅需一擦即可&#xff0c;实际上&#xff0c;长时间佩戴后&#xff0c;镜片与框架累积…

【日常总结】阿里云:windows server 过一段时间登录不进去,或提示:出现身份验证错误。 无法连接到本地安全机构

场景 阿里云 : ESC系统&#xff1a;windows server 2022 问题 无法登录&#xff0c;或者登录浸提提示密码已过期 原因 密码设置了过期时间 解决方案 修改密码策略&#xff1a;密码设置永不过期 打开“本地安全策略”编辑器&#xff1a;运行 secpol.msc。 导航至“账户…

leetcode 2461.长度为k子数组的最大和

目录 题目描述 示例1&#xff1a; 示例2&#xff1a; 提示&#xff1a; 解题思路 滑动窗口法 概念 应用场景及特点&#xff1a; 思路 流程展示 代码 复杂度分析 题目描述 给你一个整数数组nums和一个整数k。请你从nums中满足下述条件的全部子数组中找出最大子数组…

开放式耳机别人能听到吗?不堵耳、不入耳的设计才舒服

开放式耳机的设计允许空气自由流通&#xff0c;这通常意味着它们在播放音乐时会有声音泄露到外部环境。因此&#xff0c;与封闭或半封闭的入耳式耳机相比&#xff0c;开放式耳机在一定程度上是可以让周围的人听到你正在播放的音乐的。声音泄露的程度取决于多种因素&#xff0c;…

【卡码网C++基础课 11.句子缩写】

目录 题目描述与分析一、字符大小的比较二、代码编写三、函数的使用四、形参和实参五、引用 题目描述与分析 题目描述&#xff1a; 输出一个词组中每个单词的首字母的大写组合。 输入描述&#xff1a; 输入的第一行是一个整数n&#xff0c;表示一共有n组测试数据。&#xff0…

[数据集][目标检测]电力场景输电线悬垂线夹检测数据集VOC+YOLO格式2538张2类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;2538 标注数量(xml文件个数)&#xff1a;2538 标注数量(txt文件个数)&#xff1a;2538 标注…

照片逼真肖像动画的音频驱动合成——AniPortrait翻译与调试

文章目录 AniPortrait翻译AbstractIntroduction2 Method2.1 Audio2Lmk2.2 Lmk2Video 3 Experiments3.1 Implementation Details3.2 Results 代码调试1 下载github项目2 配置环境3 下载包4 下载权重5 推断 AniPortrait翻译 AniPortrait&#xff1a;照片逼真肖像动画的音频驱动合…

解决使用matplotlib不显示中文的问题

某季度某城市某天11点到12点气温变化图 import random x range(60) y_BeiJing [random.uniform(15,18) for i in x] plt.figure(figsize(20,8),dpi80) plt.plot(x,y_BeiJing) x_label ["11点{}分".format(i) for i in x] plt.xticks(x[::5],x_label[::5]) plt.yt…

【网络】网络层协议-IP协议

网络层协议-IP协议 文章目录 IP协议1.网络层 & IP协议基本概念2.IP协议格式2.1报头各字段简介2.2IP如何将报头与有效载荷进行分离&#xff1f;2.3IP如何决定将有效载荷交付给上层的哪一个协议&#xff1f;2.4源IP与目的IP2.5八位生存时间2.6分片与组装 3.网段划分3.1IP地址…

嵌入式Qt移植前期准备-思维导图-学习笔记-基于正点原子阿尔法开发板

嵌入式Qt移植前期准备 概述 Qt官方在哪些平台/系统有支持&#xff1f; Windows Ubuntu IOS 为什么要进行Qt移植? 自制系统&#xff0c;如BusyBox简易系统&#xff0c;希望能运行Qt 厂家提供的Qt库太大&#xff0c;太全&#xff0c;占空间 版本升级&#xff0c;想用其它…

蒙特卡洛应用:RTX 光线追踪算法 ReSTIR 原理

接上文&#xff1a;蒙特卡洛方法相关论文&#xff1a;《Spatiotemporal reservoir resampling for real-time ray tracing with dynamic direct lighting: 2020》 ReSTIR 算法全称为 GIalgorithm based on Spatiotemporal Reservoir Resampling&#xff0c;是一种在实时路径追…