- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图了解 memmove 是如何工作的。我举一个例子,我以这种方式在内存中保存数据。
Start at 0
First Memory Block(A) of size 10
Hence A->(0,10) where 0 being where it starts and 10 it's length.
Thus B-> (10,20)
C-> (30,50)
D-> (80,10)
假设我们有一个变量 X,它记录下一个可以插入的位置,在上面给出的示例中为 90。现在如果我想删除B,那么我想将C和D移动到B占用的空间。输入是输入数组。因此,输入数组看起来前 10 个字符属于 block A,接下来的 20 个字符属于 block B,等等。我认为这可以使用 memmove 来完成,如下所示:
memmove(input+start(B),input+start(B)+length(B),X-(start(B)+length(B))
现在我想尝试逆序。
So we start from behind
Start at 100
First memory block(A) of size 10
A-> (100,10) 100 is where it starts and 10 it's length
B-> (90,20)
C-> (70,50)
D-> (20,10)
与第一个示例类似,假设我们有一个变量 X,用于记录接下来可以插入的位置。对于示例中的相反顺序,这将是 10。
现在,如果我想删除 block B,那么我希望 C 和 D 在 B 的空间中重叠。这将以相反的顺序进行 memmove。我认为可以通过以下方式完成:
memmove(input+start(B)-(start(B)-length(B)-X),input+X,start(B)-length(B)-X)
根据 Alex 的评论,我认为我没有保持正确的数据顺序。数据就像这样,
A->(90,10)
B->(70,20)
C->(40,30)
D->(20,20)
and X which would be D's starting address i.e at 20
Now if we want to delete B,memmove would look something like this.
memmove(input+X+length(B), input+X,start(B)-X)
有更好的方法吗?
请注意,这不是家庭作业。
最佳答案
C
和 D
总共占据 50+10=60,那么为什么 memmove(input+start(B), input+start(B) 中的 20 是 20 +长度(B),20)
?
至于其他部分,在 C 中对象并不从最后一个字节开始(第一个字节位于最低地址,最后一个字节位于最高地址)。这部分令人困惑。
关于c - 这是逆序 memmove 的正确方法吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12598014/
序 大家好呀,我是summo,这次来写写我在上班空闲(摸鱼)的时候做的一个小网站的事。去年阿里云不是推出了个活动嘛,2核2G的云服务器一年只要99块钱,懂行的人应该知道这个价格在业界已经是非常良心了
我尝试根据给定的级别顺序(BFS 顺序)构造 BST。我知道这是可能的,但我不知道我该怎么写。问题是我必须使用 BFS 序列。所以,我不能在这里使用递归,我必须迭代地编写我的程序......我发现这有
我是一名优秀的程序员,十分优秀!