当前位置: 首页 > 编程日记 > 正文

面试题--特别是字节对齐

来源:http://www.cnblogs.com/Braveliu/archive/2013/01/04/2844757.html

【1】设置或者清除某位。

示例代码如下:

复制代码
 1 #include<iostream>
 2 using  namespace std;
 3 
 4 #define   BIT3  (0x1<<3)
 5 
 6 void Set_bit3(int &a)
 7 {
 8     a|=BIT3;
 9 }
10 
11 void Clear_bit3(int &a)
12 {
13     a&=~BIT3;
14 }
15 
16 void main()
17 {
18     int m=10;     //1010
19     Set_bit3(m);  
20     cout<<m<<endl;//1010 == 10
21     Clear_bit3(m);
22     cout<<m<<endl; //0010 == 2
23     
24     int n=7;
25     Set_bit3(n);
26     cout<<n<<endl; //1111 == 15
27     Clear_bit3(n);
28     cout<<n<<endl; //0111 == 7
29 }
30 /*
31 10
32 2
33 15
34 7
35  */
复制代码

【2】指针引用经典笔试题

(1)

复制代码
 1 #include<iostream.h>
 2 #include<malloc.h>
 3 #include<string.h>
 4 
 5 void GetMemory(char *p,int num)
 6 {
 7     p=(char *)malloc(sizeof(char)*num);
 8 }
 9 
10 void  main()
11 {
12     char *str = NULL;
13     GetMemory(str,100);
14     strcpy(str,"hello");
15 }
16 
17 //GetMemory函数仅仅只改变了p指针的指向,而str的指向不变
18 //类似于:
19 //char  *str=NULL;
20 //char  *p = str;
21 //p = (char *)malloc(sizeof(char)*num);
22 //那么这样的三行代码执行结果显然没有达到改变str的作用
复制代码

(2)

复制代码
 1 #include<iostream.h>
 2 #include<string.h>
 3 #include<malloc.h>
 4 
 5 void  GetMemory2(char **p,int num)
 6 {
 7     *p=(char *)malloc(sizeof(char)*num);
 8 }
 9 
10 void main()
11 {
12     char *str = NULL;
13     GetMemory2(&str,100);
14     strcpy(str,"hello");
15     cout<<str<<endl;
16     free(str);
17 }
18 
19 //GetMemory函数“隔山打牛”
20 //类似于:
21 //char  *str=NULL;
22 //char  **p=&str;
23 //*p=(char *)malloc(sizeof(char)*num);
24 //那么这样的三行代码执行结果显然达到改变str的作用
复制代码

(3)

复制代码
 1 #include<iostream.h>
 2 #include<malloc.h>
 3 #include<string.h>
 4 
 5 char * GetMemory3(int num)
 6 {
 7     char *p=(char *)malloc(sizeof(char)*num);
 8     return p;
 9 }
10 
11 void  main()
12 {
13     char *str=NULL;    
14     str=GetMemory3(100);
15     strcpy(str,"hello");
16     cout<<str<<endl;
17     free(str);
18 }
19 
20 //GetMemory函数功在当代,利在千秋
21 //尽管p变量在栈中,它当生则生,当死则死
22 //但是它在世的一瞬间,却创造了举世的成就,开天辟地!!
23 //p=(char *)malloc(sizeof(char)*num);一句足矣
24 //返回p的值,意义无量!
复制代码

(4)

复制代码
 1 #include<iostream.h>
 2 #include<string.h>
 3 #include<malloc.h>
 4 
 5 char *GetString()
 6 {
 7     char p[]="hello  world";
 8     return p;  //编译器警告!!!返回局部变量
 9 }
10 
11 void  main()
12 {
13     char *str=NULL;
14     str=GetString();
15     cout<<str<<endl; //垃圾
16 }
17 
18 //GetMemory函数山寨版
19 //p变量在栈中,当生则生,当死则死
20 //但是它在世的一瞬间,却目光短浅,于后世无功!
21 //返回p的值,一文不值!
复制代码

(5)

复制代码
 1 #include<iostream.h>
 2 #include<string.h>
 3 #include<malloc.h>
 4 
 5 char * GetString()
 6 {
 7     char *p="hello  world!";
 8     return p;
 9 }
10 
11 void  main()
12 {
13     char *str=NULL;
14     str=GetString();
15     cout<<str<<endl;
16 }
17 
18 //GetMemory函数正版
19 //p变量在栈中,当生则生,当死则死
20 //但是它在世的一瞬间,却赋予了一份常量,不随它的消失而泯灭!
复制代码

(6)

复制代码
 1 #include<iostream>
 2 #include<string>
 3 #include<malloc.h>
 4 using namespace std;
 5 
 6 void GetString(char *&p)
 7 {
 8     p=(char *)malloc(sizeof(char)*10);
 9 }
10 
11 void  main()
12 {
13     char *str=NULL;
14     GetString(str);
15     strcpy(str,"hello");
16     cout<<str<<endl;
17     free(str);
18     str=NULL;
19 }
复制代码

以上几种例子是面试时遇到的最频繁的试题,在此特意备份,以便学习。

【3】这道题是最典型的数组越界示例:

复制代码
 1 #include<iostream.h>
 2 #define MAX  255
 3 void main()
 4 {
 5     unsigned char A[MAX];
 6     for(int i = 0; i <= MAX; i++)
 7     {
 8         A[i] = i;
 9     }
10 }
复制代码

无限循环.......

【4】求最大字段和

示例代码如下:

复制代码
 1 #include<iostream>
 2 using namespace std;
 3 
 4 inline int Max(int a,int b)
 5 {
 6     return a > b ? a : b; 
 7 }
 8 
 9 int MaxSubSum(int br[],int n)
10 {
11     int data= 0,max= 0;
12     for(int i=0 ;i<n ;++i)
13     {
14         data = Max(0,br[i]);       
15         max = Max(data+max,max);   
16     }
17     return max;
18 }
19 
20 void main()
21 {
22     int ar[] = {1,-4,-2,-1,7,-3,9};
23     int result1 = MaxSubSum(ar,7);
24     cout<<result1<<endl;  //17
25 }
复制代码

【5】字节对齐

示例代码:

复制代码
  1 #include<iostream.h>
  2 class A
  3 {
  4 public:
  5   int i;
  6 };
  7 class  B
  8 {
  9 public:
 10   char  ch;
 11 };
 12 class C
 13 {
 14 public:
 15     int i;
 16     short j;
 17 };
 18 class D
 19 {
 20 public:
 21     int i;
 22     short j;
 23     char ch;
 24 };
 25 class E
 26 {
 27 public:
 28     int i;
 29     int ii;
 30     short j;
 31     char ch;
 32     char chr;
 33 };
 34 class F
 35  {
 36 public:
 37     int i;
 38     int ii;
 39     int iii;
 40     short j;
 41     char ch;
 42     char chr;
 43 };
 44 class G
 45 {
 46 public:
 47     int i;
 48     int ii;
 49     short j;
 50     char ch;
 51     char chr;
 52     int iii;
 53 };
 54 class H
 55 {
 56 public:
 57     int i;
 58     int ii;
 59     char ch;
 60     char chr;
 61     int iii;
 62     short j;
 63 };
 64 class I
 65 {
 66 public:
 67     int i;
 68     char ch;
 69     int ii;
 70     char chr;
 71     int iii;
 72     short j;
 73 };
 74 void  main()
 75 {
 76     cout<<"sizeof(int): "<<sizeof(int)<<endl;
 77     cout<<"sizeof(short): "<<sizeof(short)<<endl;
 78     cout<<"sizeof(char): "<<sizeof(char)<<endl;
 79     cout<<endl;
 80     cout<<"sizeof(A): "<<sizeof(A)<<endl;
 81     cout<<"sizeof(B): "<<sizeof(B)<<endl;
 82     cout<<"sizeof(C): "<<sizeof(C)<<endl;
 83     cout<<"sizeof(D): "<<sizeof(D)<<endl;
 84     cout<<"sizeof(E): "<<sizeof(E)<<endl;
 85     cout<<"sizeof(F): "<<sizeof(F)<<endl;
 86     cout<<"sizeof(G): "<<sizeof(G)<<endl;
 87     cout<<"sizeof(H): "<<sizeof(H)<<endl;
 88     cout<<"sizeof(I): "<<sizeof(I)<<endl;
 89 }
 90 
 91 //Out   put:
 92 /*
 93 sizeof(int): 4
 94 sizeof(short): 2
 95 sizeof(char): 1
 96 
 97 sizeof(A): 4
 98 sizeof(B): 1
 99 sizeof(C): 8
100 sizeof(D): 8
101 sizeof(E): 12
102 sizeof(F): 16
103 sizeof(G): 16
104 sizeof(H): 20
105 sizeof(I): 24
106 */
复制代码

【6】大小端判断

题目:请写一个C函数,若处理器是Big_endian的,则返回0;若是Little_endian的,则返回1

分析:
为什么会有大小端模式之分呢?这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为 8bit。

但是在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器),

另外,对于位数大于 8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。

因此就导致了大端存储模式和小端存储模式。

例如一个16bit的short型x,在内存中的地址为0x0010,x的值为0x1122,那么0x11为高字节,0x22为低字节。

对于大端模式,就将0x11放在低地址中,即0x0010中,0x22放在高地址中,即0x0011中。

小端模式,刚好相反。我们常用的X86结构是小端模 式,而KEIL C51则为大端模式。

嵌入式开发对大小端都比较敏感。所谓的大端模式是指:

数据的低位(就是权值较小的后面那几位)保存在内存的高地址中,而数据的高位,保存在内存的低地址中。

这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放;

所谓的小端模式是指:数据的低位保存在内存的低地址中,而数据的高位保存在内存的高地址中,

这种存储模式将地址的高低和数据位权有效地结合起来,高地址部分权值高,低地址部分权值低,和我们的实际逻辑方法一致。

示例代码如下:

复制代码
 1 #include<iostream>
 2 using namespace std;
 3 
 4 int CheckCpu()
 5 {
 6     union w
 7     {
 8         int a;
 9         char b;
10     }c;
11     c.a=1;
12     return (c.b==1);
13 }
14 
15 void main()
16 {
17     cout<<CheckCpu()<<endl;   //1   //说明是小端模式
18 }
复制代码

总结:

其实大小端的问题很简单的,就是因为数据在同样的内存可以有两种存储模式。

简单记住:低低小,低高大。

也就是说:低位数据存入低地址小端;低位数据存入高地址大端。

【7】求整型数组中的最小以及次小项

示例代码如下:

复制代码
 1 #include<iostream>
 2 using namespace std;
 3 
 4 void  select(int ar[],int n)
 5  {
 6      int m1, m2;
 7      m1 = m2 = 0xffff;
 8      int x1, x2;
 9      x1 = x2 = 0;
10      for(int j = 0; j < n ;j++)    
11      {    
12          if (ar[j] < m1)
13          {
14              m2 = m1;    //暂存次小
15              x2 = x1;    //暂存次小索引
16              m1 = ar[j]; //暂存最小
17              x1 = j;     //暂存最小索引
18          }
19          else if(ar[j] < m2 )
20          {
21              m2 = ar[j]; //保存次小
22              x2 = j;     //保存次小索引             
23          }
24      }
25      cout<<x1<<"   "<<m1<<endl;   //输出最小
26      cout<<x2<<"   "<<m2<<endl;   //输出次小
27  }
28  void  main()
29  {
30      int ar[5] = {1, 7, 5, 4, 2};
31      select(ar,5);
32  }
33 
34  /*运行结果:
35  0   1
36  4   2
37  */
复制代码

转载于:https://www.cnblogs.com/heyonggang/archive/2013/04/15/3021926.html

相关文章:

vim基础入门

一. vim的三种模式在Linux操作系统下&#xff0c;我们一般会使用vim进行文本编辑&#xff0c;它相当于Windows下的记事本&#xff0c;但是它比记事本的功能强大的多。vim一般有三种模式分别是普通模式&#xff0c;编辑模式和命令模式。普通模式和编辑模式可以来回的切换&#x…

python html解析查找字符串_用python的BeautifulSoup分析html

序言之前用python爬取网页的时候&#xff0c;一直用的是regex或者自带的库sgmllib里的SGMLParser。但是遇到复杂一点的情况时&#xff0c;SGMLParser往往就不那么给力了&#xff01;(哈&#xff0c;难道说我 too native了&#xff1f;毕竟beautifulSoup是继承sgmlparser的么~)所…

ejb 3中bean的种类

会话bean(session bean) 主要用来编写业务逻辑和对数据库进行操作&#xff0c;Session Bean用于实现业务逻辑&#xff0c;它分为有状态bean和无状态bean。每当客户端请求时&#xff0c;容器就会选择一个Session Bean来为客户端服务。Session Bean可以直接访问数据库&#xff0…

Android学习 —— 数据的存储与访问方式一: 文件存取

笔记摘要&#xff1a; 在Android中主要提供了四种数据存储与访问的方式&#xff0c;文件、SharedPreference&#xff08;偏好参数保存&#xff09;、SOLite数据库、内容提供者&#xff08;Content provider&#xff09;和网络&#xff0c; 本篇文章先介绍使用文件的方式进行数据…

react的安装使用

react的重要思想是通过组件来开发应用&#xff0c;而组件就是能够完成某个特定功能而独立、可复用的代码。 react是可以像JQuery那样直接下载引入使用&#xff0c;也可以直接引用官网提供的CDN的地址&#xff1a; <script src"https://unpkg.com/react16/umd/react.dev…

锐捷交换机配置snmp版本_snmp交换机配置

华为交换机1、查询交换机当前是snmp配置命令dis cur2、进入全局模式 int ethernet1/0/7 shutdown 关 undoshutdown 激活sys3、进入SNMP配置snmp-agent4、配置只读字符串snmp-agent community read abcd5、配置写字符串snmp-agent community write abcd6、开启snmp版本支持功能 …

Linux命令find的35个实例

注&#xff1a;本文内容参考《35 Practical Examples of Linux Find Command》 网址&#xff1a;http://www.tecmint.com/35-practical-examples-of-linux-find-command/ Linux 查找命令是Linux系统中最重要和最常用的命令之一。查找用于根据与参数匹配的文件指定的条件来搜索…

PHP使用APNS的 feedback service

http://blog.csdn.net/gnicky/article/details/7544202 1. URL是不一样的&#xff0c;端口是2196 2. 使用同样的Certificate&#xff0c;建立安全连接&#xff0c;接受数据&#xff0c;直到数据不存在&#xff0c;类似table select操作 3.每条纪录是一个token&#xff0c;serve…

洛谷——P2341 [HAOI2006]受欢迎的牛//POJ2186:Popular Cows

P2341 [HAOI2006]受欢迎的牛/POJ2186:Popular Cows 题目背景 本题测试数据已修复。 题目描述 每头奶牛都梦想成为牛棚里的明星。被所有奶牛喜欢的奶牛就是一头明星奶牛。所有奶 牛都是自恋狂&#xff0c;每头奶牛总是喜欢自己的。奶牛之间的“喜欢”是可以传递的——如果A喜 欢…

学习使用Bing Maps Silverlight Control(五):离线使用和自定义地图模式

6 离线使用 在笔记第一部分的时候就提到如果要使用Bing Maps Silverlight Control 进行开发&#xff0c;需要申请一个key&#xff0c;不让会显示一个错误提示出来。但是在实际开发或使用过程中&#xff0c;使用环境和地图数据可能不是在线的&#xff0c;但控件因为验证失败仍然…

python123第k序元素查找_Python实现折半查找并用matplotlib实现动态过程可视化

折半查找是算法中减治策略的基本例子&#xff0c;实现起来也很简单&#xff0c;但是在网上看到的图片教程不觉得很乾巴麽&#xff1f;&#xff1f;在这里插入图片描述这是一个简单的实现&#xff1a;def Reduction(lists, k):""":param lists: 元素列表:param k…

vim进阶技巧

本篇博文是在之前的《vim基础入门》的基础之上写的&#xff0c;不懂的同学可以先看之前的分享 1. 视觉范围的选择 普通模式下&#xff0c;按v键确定范围起点&#xff0c;然后移动光标&#xff0c;光标所在位置为范围的终点&#xff0c;然后按操作键完成其他操作&#xff0c;之…

Flex Air程序打包成独立的exe安装文件

2019独角兽企业重金招聘Python工程师标准>>> 开发背景&#xff1a; FlexBuilder3.2开发生成的Air程序需要能够独立安装&#xff0c;事先不需要安装AdobeAir运行环境 实现方法&#xff1a; 1)用winrar打开xx.air文件爱能&#xff0c;并将它解压在D:\airapp目录中。 2…

《C++primer》第一章--开始

之前开始读《Cprimer》&#xff0c;想着读书不动笔不如不读书&#xff0c;于是就想做一个读书笔记的内容&#xff0c;于是就想起了写一个《Cprimer读思录》的一个专栏。一是为了给自己平时读书做笔记&#xff0c;方便自己随时查看。二是为了督促自己每天学习。三是为了知识的分…

对于计算机网络的整体框架的概括(转载) 个人感觉很好

作者&#xff1a; 阮一峰 日期&#xff1a; 2012年5月31日 我们每天使用互联网&#xff0c;你是否想过&#xff0c;它是如何实现的&#xff1f; 全世界几十亿台电脑&#xff0c;连接在一起&#xff0c;两两通信。上海的某一块网卡送出信号&#xff0c;洛杉矶的另一块网卡居然就…

Centos修改系统语言

使用man page帮助时&#xff0c;发现居然是中文的&#xff0c;不过想想即便英语再水&#xff0c;也要逼着自己去适应。于是百度找了一下修改系统语言的方法。 首先使用 locale 命令查看当前的系统语言 然后修改时一般有两种方法&#xff0c;一是临时修改&#xff0c;立即生效&a…

tp3 普通模式url模式_Thinkphp 3.2.3 url 路由访问模式

Thinkphp 3.2.3 url 的4中路由模式&#xff1a;// 0 (普通模式)http://网址/index.php?m模块&c控制器&a方法http://localhost/index.php?mHome&cindex&aindex//1 (PATHINFO 模式) 默认为PATHINFO 模式http://网址/index.php/模块/控制器/方法http://localhos…

Mysql 基于 Amoeba 的 读写分离(2)

<?xml version"1.0" encoding"gbk"?> <!DOCTYPE amoeba:configuration SYSTEM "amoeba.dtd"> <amoeba:configuration xmlns:amoeba"http://amoeba.meidusa.com/"><proxy><!-- service class must implem…

Linux驱动之LCD驱动编写

在Linux驱动之内核自带的S3C2440的LCD驱动分析这篇博客中已经分析了编写LCD驱动的步骤&#xff0c;接下来就按照这个步骤来字尝试字节编写LCD驱动。用的LCD屏幕为tft屏&#xff0c;每个像素点为16bit。对应与红绿蓝分别为565。 1、分配一个fb_info结构 2、设置fb_info结构 3、硬…

《C++primer》第二章--变量和基本内置类型

基本内置类型 如何选择类型的几点建议 当明确知晓数值不能为负数时&#xff0c;选用无符号类型使用int进行整数运算。因为short一般表示的范围比较小&#xff0c;而long一般和int有相同的范围。如果表示的范围超过了int就使用long long算术运算时尽量不要使用char和bool&…

【入门】等差素数组

题目描述 如果两个素数之和的一半仍然是一个素数&#xff0c;则这三个素数可以组成一个等差素数组&#xff0c;如&#xff08;37&#xff09;/25&#xff0c;则&#xff08;3&#xff0c;5&#xff0c;7&#xff09;为一个等差素数组&#xff0c;编程求100以内的所有等差素数组…

flutter和webapp_Flutter全平台!迁移现有Flutter项目到WEB端

写在前面Flutter 是 Google推出并开源的移动应用开发框架&#xff0c;主打跨平台、高保真、高性能。开发者可以通过 Dart语言开发 App&#xff0c;一套代码同时运行在 iOS 、Android、web和桌面端。Flutter_web是Flutter代码兼容web的实现&#xff0c;可以将使用Dart编写的现有…

使用正则表达式构造定制的HTML5输入框

为什么80%的码农都做不了架构师&#xff1f;>>> 正则表达式&#xff08;点此在线编辑测试&#xff09;是一个功能强大的灵活而简洁的匹配文本字符串的工具&#xff0c;比如匹配特定的字符、单词等。正则表达式通过一个语言规则来书写&#xff0c;通过正则表达式处理…

idea dubbo jar error:cvc-complex-type.2.4.c: 通配符的匹配很全面, 但无法找到元素 'dubbo:application' 的声明...

声明&#xff1a; 出现这个错误的情形是&#xff0c;在idea开发环境里面运行是没有问题的&#xff0c;使用哦idea自带的打包工具生成jar之后&#xff0c;运行jar的时候报的这个错误&#xff0c;如果不是这个情况&#xff0c;这篇文章可能不适用。 主要的原因是spring.schemas、…

lwip可以用于发udp_LWIPUDP一对多

最近在STM32F767的开发板上移植了LWIP UDP的代码&#xff0c;开发板的资料里面有介绍LWIP移植的文档&#xff0c;介绍了几种网络通信方式&#xff0c;如TCP server&#xff0c;TCP client&#xff0c;UDP&#xff0c;按照文档里面的介绍也很容易实现。这里我选择的是基于ucos2操…

奇淫怪巧之给Delphi的PrintDialog增加一个页码选定范围打印的Edit

在Delphi中使用PrintDialog打印对话框的时候&#xff0c;这个控件有三个选项&#xff0c;就是PrintRang那个属性的三个选项&#xff0c;其中有一个选项三&#xff0c;让我们自定义选择页码范围来打印。但是比较蛋疼的是&#xff0c;这个地方选中了之后啥子效果都没有。无法制定…

进程管理(图文)

进程的图文形象表示 阮一峰–进程与线程的一个简单解释 多进程实质 现在&#xff0c;多核CPU已经非常普及了&#xff0c;但是&#xff0c;即使过去的单核CPU&#xff0c;也可以执行多任务。由于CPU执行代码都是顺序执行的&#xff0c;那么&#xff0c;单核CPU是怎么执行多任…

拿到WP官方主题Twenty Ten就是一顿nofollow伺候

2019独角兽企业重金招聘Python工程师标准>>> 今天2012-07-03&#xff0c;我的个人cn域名申请下来了&#xff0c;于是网站搬迁&#xff0c;暂时没有选择一个好的WordPress主题&#xff0c;只有用默认的Twenty Ten&#xff0c;不过这个主题对SEO方面还有一些欠缺&…

Qt分析:Qt中的两种定时器

QTimer类的定时器 QTimer类定时器是QObject类定时器的扩展版或者说升级版&#xff0c;因为它可以提供更多的功能。比如说&#xff0c;它支持单次触发和多次触发。 使用QTimer类定时器的步骤&#xff1a; &#xff08;1&#xff09;创建一个QTimer定时器实例&#xff1a;QTimer …

uestc 1012 饭卡

饭卡(card) Time Limit: 1000 ms Memory Limit: 65535 kB Solved: 253 Tried: 2169 Submit Status Best Solution Back Description 电子科大本部食堂的饭卡有一种很诡异的设计&#xff0c;即在购买之前判断余额。如果购买一个商品之前&#xff0c;卡上的剩余金额大于或等…