C语言中的难点

  1. C语言把内存划分成四个区,它把一般的变量和数组等存在于内存中的栈区,全局变量在静态区
  2. 若指针没有被初始化,那么指针可能会指向任何内存位置,这样可能会导致程序崩溃或者行为不确定,野指针就是指针指向的位置是不可知的(随机的、不正确的、没有明确限制的)指针变量在定义时如果未初始化
  3. 多个指针指向同一个地址,这样使用没什么问题
  4. c++中有string类可以直接定义字符串,而c语言中不可以,只可以引入string.h包含处理字符串的函数,但是定义还是char[]数组类型
  5. 数据结构(尤其是栈)应该尽可能地在自然边界上对齐。 原因在
    于,为了访问未对齐的 内存,处理器需要作两次内存访问;而对齐的内访问仅需要一次访问。总体来说:结构体的内存对齐是拿空间来换取时间的做法。优点是提高了cpu访问性能。
  6. p+1就是a+1的值都代表a[1]的地址,两者是相等的
相关推荐
wWYy.11 分钟前
指针与引用区别
数据结构
你撅嘴真丑18 分钟前
第八章 - 贪心法
开发语言·c++·算法
wanghu202424 分钟前
AT_abc443_C~E题题解
c语言·算法
梵刹古音28 分钟前
【C语言】 浮点型(实型)变量
c语言·开发语言·嵌入式
历程里程碑28 分钟前
Linux 17 程序地址空间
linux·运维·服务器·开发语言·数据结构·笔记·排序算法
u01092727131 分钟前
模板元编程调试方法
开发语言·c++·算法
??(lxy)1 小时前
java高性能无锁队列——MpscLinkedQueue
java·开发语言
2401_838472511 小时前
C++图形编程(OpenGL)
开发语言·c++·算法
-dzk-1 小时前
【代码随想录】LC 203.移除链表元素
c语言·数据结构·c++·算法·链表
齐落山大勇1 小时前
数据结构——栈与队列
数据结构