c最难是~~~~~~~~~~

xtss 2002-11-21 02:49:00
我现在学到了指针了,感到有些难呀!!

最近也不是常来这里了。我得学习。

真的好想你们呀,只有一个星期来一次了

问一下指针和FOR哪一个难学呀。在上机考试中那一个出题占的多一些呀
...全文
50 25 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
25 条回复
切换为时间正序
请发表友善的回复…
发表回复
一闻 2002-11-22
  • 打赏
  • 举报
回复
指针多看点经典例题学习就很快了,看看
《C Primer Plus》中文第四版中的指针说明,篇幅很少,但讲得很清楚
zm_speed 2002-11-22
  • 打赏
  • 举报
回复
指针难理解点吧,比较抽像,下面是找来的!


--------------指针----------------
int a=10;
int *p=&a;

-------------指针的指针-----------
int b=20;
int *p=&b;
int **p2p=&p;

-------------简单数组-----------------
int c[10];//整数数组,含有10个整数元素
file://也就是说每一个元素都是整数

--------------指针数组--------------------
int *p[10];//指针数组,含有10个指针元素
file://也就是说每一个元素都是指针

--------------数组指针--------------------
int (*p)[10];//数组指针,这个指针可以用来指向
file://含有10个元素的整数数组

上面这些简单的形式是我们必须要首先理解,这个是基本的知识。
同时我们从上面也要得出一个很重要的知识提示:c++语言层面上
关于变量声明的部分,后缀结合变量的优先级比前缀要高的。
看我们上面的例子的最后两个就明白了,我们为了实现数组指针的
声明我们不得不变通一下。我们采用()来实现优先级的改变,实现了
数组指针的声明。

################################
# #
# 进一步提高知识 #
# #
################################

数组,数组的指针,指针的数组,概念太多了。我接受概念一多的
时候,我就想把这些复杂的东西简单一下。因为我太懒了,概念简化
一下,记住更容易一点。所以我们这里要认识一下上面这些概念本质。
这样可以简化概念,减少记忆的难度。

先看一段程序。
#include <iostream>
#include <typeinfo>
using namespace std;
int main()
{
int vInt=10;
int arr[2]={10,20};

int *p=&vInt;
int **p2p=&p;

int *parr[2]={&vInt,&vInt};
int (*p2arr)[2]=&arr;

cout<<"Declaration [int vInt=10] type=="<<typeid(vInt).name()<<endl;
cout<<"Declaration [arr[2]={10,20}] type=="<<typeid(arr).name()<<endl;
cout<<"Declaration [int *p=&vInt] type=="<<typeid(p).name()<<endl;
cout<<"Declaration [int **p2p=&p] type=="<<typeid(p2p).name()<<endl;
cout<<"Declaration [int *parr[2]={&vInt,&vInt}] type=="<<typeid(parr).name()<<endl;
cout<<"Declaration [int (*p2arr)[2]=&arr] type=="<<typeid(p2arr).name()<<endl;

return 0;
}

运行的结果如下:(我在前面加了行号#XX)
#01 Declaration [int vInt=10] type==int
#02 Declaration [arr[2]={10,20}] type==int *
#03 Declaration [int *p=&vInt] type==int *
#04 Declaration [int **p2p=&p] type==int * *
#05 Declaration [int *parr[2]={&vInt,&vInt}] type==int **
#06 Declaration [int (*p2arr)[2]=&arr] type==int (*)[2]

现在我们来分析一下结果。因为我们已经具有了第一部分的基本知识,我们现在
可以很明确区别出来我们声明的类型。这里主要有两个很重要的部分,我们不过
是就事讲事情,编译器是如何实现的原理不在这里讨论之列。

--------#02:数组------------

现在看#02,想到了什么没有呀?在编译器看来数组只是相对应类型的指针类型。
当我们把数组传递给函数作为参数的时候,传递的是指针,所以我们可以利用
参数来修改数组元素。这个转化是编译器自动完成的。

void f(int[]);
int a[2]={10,20};
f(a);//这行等价于编译器完成的函数转化f(int *p)

也就是说这里编译器自动完成了int[]类型到int *的转化,
注意是编译器完成的,也可以说是语言本身实现的,我们
对此只有接受的份了。

-------#05:指针数组---------------

指针数组的编译器内部表示也是对应类型的指针。

------#06:数组指针----------------
数组指针的编译器内部表示就是有一点特别了。
编译器(或者说是语言本身)有数组指针这个内部表示。
由于c++语言的类型严格检查的语言(当然还有一些是存在隐式类型转化的)

所以我们下面的写法是不能编译通过的。
{
file://---------编译不能通过--------------
int arr[3]={10,20};//注意是3个元素数组
int (*p2arr)[2]=&arr;//注意是指向2个元素数组的指针
file://---------编译不能通过--------------
}

################################
# #
# 初步小结 #
# #
################################

通过上面两个小节的内容,大家应该基本明白了,
数组,指针,指针数组,数组指针到底是怎么一回事情了吧。

-----------补充开始-----------------------
关于数组和指针的转化,以及我们使用指针(++,--)等来操作数组,
是基于数组在内存中是连续分布的。

但是我们使用“迭代器”的时候,情况是不一样的。
这个问题本文不讨论。

-----------补充结束---------------------

不过c++语言本身有很多诡异的地方(因为c++要考虑到跟c语言以及旧的c++版本兼容)。
内建类型的这些性质特征到了函数部分会有一点小的变化,不过如果你了解了编译器做了
什么以后的话,你也就不会太奇怪了。不过关于函数部分的内容我下次再说了。

现在回到上面的内容。我们这里还是讲一下内建类型。显然一样类型的变量是可以互相赋值。
不过当然还有一些其他情况也是可以的,比如类型的宽化,关于类的继承体系问题等等。

当然了,不一样的类型一般来说是不能互相赋值,当然这里的例外就是强制转化,
类的继承体系等情况了。

看到这里就会明白下面的程序为什么会运行的了。
我这里也把下面的程序作为今天内容的总结:

#include <iostream>
using namespace std;
int main()
{
int a[2]={10,20};
int *p=a;//根据上面说明,由于编译器的参与,两者类型转化后一致

int vInt=10;
int *parr[2]={&vInt,&vInt};
int **p2p=parr;//上面分析,类型一致

return 0;
}
elvahuang 2002-11-22
  • 打赏
  • 举报
回复
好象是什么:世上无难事,只怕有心人
zhengguoshan 2002-11-22
  • 打赏
  • 举报
回复
这两个比我觉得指针更难一些。。。。
Crystal_arrow 2002-11-22
  • 打赏
  • 举报
回复
加油!
yoyodd 2002-11-21
  • 打赏
  • 举报
回复
都挺简单
assembly 2002-11-21
  • 打赏
  • 举报
回复
有空去编几段汇编小程序,这几个概念就都搞定了
never2113 2002-11-21
  • 打赏
  • 举报
回复
指针最难,但是把指针、数组、函数结合起来的时候总会发晕
这是才是很难
gq00001 2002-11-21
  • 打赏
  • 举报
回复
是啊,很有趣又形象的回贴
alphapaopao 2002-11-21
  • 打赏
  • 举报
回复
那个抛弃来抛弃去的回贴很有意思
cwanter 2002-11-21
  • 打赏
  • 举报
回复
这是我关于指针的粗陋看法,希望对你有帮助:

指针就是指向内存中某个地址的一个变量。要分清指针变量和指针指向的内存地址的区别。int *p;定义了一个指针变量,这个变量(注意是这个变量,也就是p)的地址(不是它指向的地址)在堆栈上,跟int i一样,i的地址也是在堆栈上。但p指向的地址(注意是指向的地址)不定,也就是所说的野指针。int *p=new int[100];定义了一个指针变量p,在堆栈为p分配了内存,同时在堆上分配了100个int大小的内存,它的首地址放在p的地址内。如果看懂了这段话,你就可以大体理解了指针。
cyh01 2002-11-21
  • 打赏
  • 举报
回复
记住指针指向一个内存单元
bryan99 2002-11-21
  • 打赏
  • 举报
回复
把指针结合数组一起看,更容易了解...
一定要把指针这里弄明白...这样才算是真正的进入了C...
dengpan 2002-11-21
  • 打赏
  • 举报
回复
我认为c中的最难问题是如何解决与另几种语言的衔接问题,比如java c++之类,面向对象和面向过程根本不是两回事-----学c会染上思想根深蒂固的毛病,就很难学好oop了.不止大家看法如何.至于指针,那些是低层次的东西,不必多学------
Origianl 2002-11-21
  • 打赏
  • 举报
回复
不停的上机,没有好难的.
Bandry 2002-11-21
  • 打赏
  • 举报
回复
当然是指针最难,很多人学过一点就认为自己掌握了指针,呵呵,没那么容易,指针可是说变就变的,水平再高再小心的程序员遇到指针,他也得好好想想,否则一样死掉。
lbaby 2002-11-21
  • 打赏
  • 举报
回复
指针,数组,与参数传递
asvaboy1980 2002-11-21
  • 打赏
  • 举报
回复
c很简单,指针和结构体,还有函数,这是c的重点,你以后上<<数据结构>>的上机的时候就知道它们的重要性了
start550 2002-11-21
  • 打赏
  • 举报
回复
指针的爱情

1 指向变量的指针变量:
出身: int * point;
遭遇: 两人都另有新欢
心声: 你可以变心,我也可以爱别人,很公平。

2 指向常量的指针变量:
出身: const int * point;
遭遇: 抛弃对方
心声: 说过多少回了,我们之间已经结束了,你别再缠着我了,告诉你,我已经有了新的女朋友了

3 指向变量的指针常量:
出身: int * const point;
遭遇: 被对方抛弃
心声: 你怎么可以这样呢,你知道我的心里永远只有你一个,你怎么可以爱上别人呢

4 指向常量的指针常量:
出身: const int * const point;
遭遇: 两情相悦,天长地久
心声: 你是我的唯一,我是你的永远,钻石恒久远,怎即我俩情


原作者: delphisky
来 源: CSDN
badtou 2002-11-21
  • 打赏
  • 举报
回复
指针
加载更多回复(5)
“1-考试报名系统1”项目是一个数据结构课程设计,旨在创建一个考试报名系统。该项目由汪明杰同学在软件学院软件工程专业,同济大学进行,指导教师为张颖。 本文档详细阐述了项目的分析、设计、实现和测试过程。首先,项目背景指出考试报名系统对学校教务管理的重要性,特别是在处理大量考试人员时的挑战。接着,项目需求分析部分明确了系统应具备的功能,包括用户友好性、数据处理能力等。 在项目要求中,功能要求详细列出了系统应具备的各个功能,如: 1.3.1 功能要求:这可能包括考生注册、考试选择、报名、取消报名、查询考试信息等功能。 1.3.2 输入格式:可能涉及考生信息输入的格式规范,如姓名、学号、选择的考试科目等。 1.3.3 输出格式:可能涉及打印报名成功通知、查询结果展示等输出信息的格式。 项目设计部分讨论了数据结构和类的设计: 2.1 数据结构设计:可能使用数据结构如链表来存储和管理考生信息和考试数据。 2.2 类设计:包括结点类(ListNode)、双向链表类(List)以及数据库类(DataBase),用于构建系统的核心结构。 在项目实现章节,详细描述了各个功能的实现逻辑和代码,包括: 3.1 项目主体功能:涵盖系统的整体流程和代码实现。 3.2 项目初始化:如何加载初始数据,包括读取文件和手动输入。 3.3 插入数据:添加新的考生信息或考试报名。 3.4 删除数据:取消考生的报名。 3.5 修改数据:更新考生信息或考试选择。 3.6 查询数据:根据特定条件查找考生信息或考试详情。 3.7 统计数据:可能包括统计报名人数、考试科目选择情况等。 最后,项目测试部分涵盖了各种测试用例,确保系统的正确性和稳定性,如: 4.1 项目初始化测试:验证数据加载功能。 4.2 插入、删除、查找、修改和统计测试:分别检查各功能是否正常工作。 4.7 边界测试:测试特殊情况,如插入已存在的考生、删除不存在的考生等。 这个“1-考试报名系统1”项目涵盖了软件开发的完整生命周期,从需求分析到设计、实现和测试,体现了软件工程中的核心原则,特别是数据结构的应用和系统功能的实现。
根据提供的文件信息,本知识点将围绕“postprocess_swan”笔记本集合及其相关的SWAN数值模型后处理过程展开。 标题中的“postprocess_swan”指出这是一个专门用于后处理SWAN(Simulating Waves Nearshore)数值模型结果的笔记本集合。SWAN模型是一个广泛应用于近岸海域的波浪模拟工具,它可以模拟和分析波浪传播、生成、折射、反射、叠加以及破碎等现象。SWAN模型结果的后处理是整个模拟过程中的重要环节,它能够帮助研究人员分析波浪的特征,预测波浪对海岸线和海洋工程结构的影响。后处理包括数据可视化、数据统计、结果验证和解释等多个方面。 描述中提到的“后处理天鹅”,可能是对“postprocess_swan”的一种形象描述,但应该是指对SWAN模型输出结果的处理过程,而不是指某种生物或实体。 由于文件信息中未提供具体的标签内容,我们无法从这个角度提供相关的知识点。然而,“postprocess_swan-master”文件名暗示了这可能是一个开源项目,通常以“-master”结尾的文件名称表示这是一个包含源代码、数据文件、说明文档等资源的仓库主分支。 现在,让我们探讨几个与“postprocess_swan”相关的具体知识点: 1. SWAN模型简介: - SWAN全称为“Simulating Waves Nearshore”,是一种用于计算近岸波浪的数值模型。 - 它基于波浪运动的物理原理,包括波浪能量平衡方程。 - SWAN模型可以模拟波浪的成长、衰减、折射、绕射、反射和底摩擦等物理过程。 - 该模型适用于海浪、风浪、以及与海浪相关的波浪动力学问题的研究。 2. SWAN模型的应用: - 风暴潮和极端天气事件下波浪高度和周期的模拟。 - 海岸线工程的波浪载荷分析,如防波堤、海堤和人工岛的波浪作用评估。 - 环境影响评估,比如石油平台、海上风电场以及港口的建设和运营对波浪场的影响。 - 海洋资源开发,例如海底油气管道铺设和维护过程中的波浪条件预测。 3. SWAN模型后处理的重要性: - 通过后处理可以验证SWAN模型的准确性,确保模拟结果的可靠性。 - 后处理过程包括数据的提取、整理和分析,有助于更好地理解模型输出。 - 数据可视化是后处理中不可或缺的一部分,可以直观地展现波浪场的分布特征。 - 结果解释和验证通常需要与现场观测数据或其他模型预测结果对比。 4. 后处理过程中的常见操作: - 绘制波浪玫瑰图、等值线图和波高分布图等。 - 计算波浪的方向谱、频率谱和波浪能量分布。 - 使用统计分析工具,如计算波浪的平均周期、有效波高和波浪方向。 - 提取特定区域或时间点的波浪数据,进行局部细节分析。 5. SWAN模型后处理工具和方法: - 后处理工具可能包括SWAN自带的分析模块、Matlab、Python或R语言中的数据处理脚本。 - 对于可视化,可能会使用专业的数据可视化软件,如Surfer、QGIS、ArcGIS或者其他开源工具。 - 模型结果通常需要与测量数据(如ADCP数据、水位计数据)或其他模拟结果进行对比验证。 6. 开源项目“postprocess_swan”的特点和功能: - 可能提供了一套完整的后处理流程模板,便于研究人员直接使用。 - 包含了多种数据分析和可视化的方法,提高了工作效率。 - 作为一个开源项目,它可能具备良好的社区支持,方便用户提出问题和改进意见。 - 随着项目的发展,还可能包含用于处理SWAN模型不同版本输出结果的适应性调整功能。 通过以上知识点的阐述,我们可以看到“postprocess_swan”笔记本集合对于SWAN模型结果后处理的重要性和实用性。对于海洋工程、海岸工程以及海洋环境研究领域的科研人员来说,一个功能完善的后处理工具是他们进行数据分析和科学发现的关键支持。
【正文】 电脑主板型号修改软件v1.1是一款专门针对计算机主板信息进行调整的工具,主要功能在于修改主板的品牌、型号、序列号以及BIOS版本等信息。在IT行业中,这种软件的应用通常与硬件测试、系统优化或者修复某些特定问题有关。然而,需要注意的是,非法篡改这些信息可能涉及法律问题,因此在使用时应遵循合法合规的原则。 主板是计算机的核心部件,负责连接各个硬件组件并提供数据交换的平台。主板的品牌和型号决定了其兼容性和性能,而序列号则是主板的身份标识,用于区分每块主板的独特性。BIOS(基本输入输出系统)则是主板上的一段固件,负责引导操作系统启动和管理硬件资源。 该软件允许用户自定义这些信息,有以下几个可能的用途: 1. **硬件测试**:在开发或测试新硬件时,制造商可能需要模拟不同类型的主板环境。通过修改主板信息,可以快速创建多种测试场景,以确保新硬件在各种配置下都能正常工作。 2. **系统优化**:某些应用程序或游戏可能会对特定主板型号有优化,修改主板信息可能有助于提升性能或解决兼容性问题。不过,这并不总是有效,也可能导致其他问题。 3. **故障排除**:在某些情况下,错误的主板信息可能导致驱动程序安装失败或系统运行异常。修改这些信息有时可以帮助诊断和解决问题。 4. **安全风险**:值得注意的是,非法修改主板信息也可能被用于欺骗目的,如逃避保修期限制或进行非法活动。因此,使用此类软件需谨慎,并且要清楚可能带来的法律风险。 在使用"电脑主板型号修改软件v1.1.exe"前,用户应确保具备一定的电脑硬件知识,理解操作可能带来的后果。同时,备份重要的数据是必要的,因为不正确的修改可能会导致系统不稳定甚至无法启动。在执行修改前,了解主板的原始信息,并在必要时咨询专业人士的建议,是非常重要的。 这款软件为特定的IT任务提供了便利,但也提醒我们在使用时要遵守法律,尊重知识产权,并充分了解潜在风险。谨慎操作,合理利用,才能充分发挥这类工具的效用,同时避免不必要的麻烦。

70,024

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧