实力剖析一个经典笔试题
昨天群里有個(gè)同學(xué)發(fā)了這樣一個(gè)題目過來,這個(gè)題目應(yīng)該是嵌入式筆試經(jīng)典題目了,如果是校招的話,筆試不考這個(gè)題目,都覺得有點(diǎn)說不過去。
#include <stdio.h>int main() {int a[5] = {1,2,3,4,5};int *ptr1 = (int *)(&a +1);int *ptr2 = (int *)(a +1);printf("%x,%x \n",ptr1[-1],*ptr2);return (0); }這個(gè)輸出我相信很多人都能看出來是什么了吧,之前我記得在文章里面也有分析過這個(gè)題目。
好了,我稍微修改下這個(gè)題目,改成下面這樣的
#include <stdio.h>int main() {int a[5] = {1,2,3,4,5};int *ptr1 = (int *)(&a +1);int *ptr2 = (int *)((int)a +1);printf("%x,%x \n",ptr1[-1],*ptr2);return (0); }大家好好看題目哈 我把
(int *)(a+1);改成了
(int *)((int)a +1);我們知道,a 代表的是數(shù)組的首元素的地址,它如果加1 的話,那么應(yīng)該是
&a[0] + sizeof(int)這里偏移的應(yīng)該是一個(gè) a[0] 的長(zhǎng)度,因?yàn)?a 是代表的 數(shù)組元素,這個(gè)數(shù)組元素是 int
但是
(int *)((int)a +1);這個(gè)加1的話,就不一樣了,a 被強(qiáng)制轉(zhuǎn)換成了 int,這個(gè)時(shí)候加1,就是簡(jiǎn)單的數(shù)學(xué)運(yùn)算增加1。所以這個(gè)值應(yīng)該是
&a[0] +1我們看看兩個(gè)截圖看到?jīng)]有,跟我們上面的預(yù)測(cè)一樣
再看看下面的這個(gè),就真的只是增加1而已。
&a[0] + sizeof(int)所以,我們上面說的這段代碼
#include <stdio.h>int main() {int a[5] = {1,2,3,4,5};int *ptr1 = (int *)(&a +1);int *ptr2 = (int *)((int)a +1);printf("%x,%x \n",ptr1[-1],*ptr2);return (0); }最終輸出什么呢?這個(gè)就涉及我們之前討論的一個(gè)問題,大小端了,先貼出輸出結(jié)果我寫了個(gè)小程序來說明為什么是這個(gè)結(jié)果,我先說下,我們PC默認(rèn)的是小端模式
b的值就是我們ptr2 指向的數(shù)據(jù),他們的內(nèi)存組合是一樣的,因?yàn)镈ev C++ 對(duì)內(nèi)存顯示還不是非常完美,不能直接看到內(nèi)存,如果用VC來調(diào)試就更加清晰了。
看了這個(gè)圖,我是不是應(yīng)該什么都不需要說了,可能有人想問我,怎么找到VC6.0的安裝包,我就是不告訴你們,等你們來找我。
掃碼或長(zhǎng)按關(guān)注
回復(fù)「?籃球的大肚子」進(jìn)入技術(shù)群聊
總結(jié)
以上是生活随笔為你收集整理的实力剖析一个经典笔试题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Python 定时任务的几种实现方式
- 下一篇: 上海富勒wms_【3PL | 多家三方物