C/C++面试题

来源:互联网 发布:淘宝造物节图片 编辑:程序博客网 时间:2024/06/04 18:50

最近因找工作,收集了很多C言方面方面的面试题以及答案。在新工作搞定了,决定把出来,送有需要的朋友,免得再象我一在辛苦。

布之前先申明两点:
    1
所有料来自网(主要是CSDN),本人只是收集和转发
    2
所有问题解答(尤其是代)只是参考,不保正确。

基本问题,再发编问题..........

想成嵌入式程序员应知道的0x10个基本问题:
预处理器(Preprocessor

1 . 预处理指令#define 声明一个常数,用以表明1年中有多少秒(忽略问题
         #define SECONDS_PER_YEAR (60 * 60 * 24 * 365)UL
我在想看到几件事情:
1) #define
法的基本知(例如:不能以分号束,括号的使用,等等)
2)
懂得预处理器将算常数表达式的,因此,直接写出你是如何算一年中有多少秒而不是算出实际,是更清晰而没有代价的。
3)
个表达式将使一个16位机的整型数溢出-因此要用到整型符号L,诉编译个常数是的整型数。
4)
如果你在你的表达式中用到UL(表示无符号整型),那么你有了一个好的起点。住,第一印象很重要。

2 . 写一个""MIN 个宏入两个参数并返回小的一个。
        #define MIN(A,B)
((A <= (B) ? (A) : (B))
测试下面的目的而的:

1)
标识#define在宏中用的基本知是很重要的。因  嵌入(inline)操作符 变为标C的一部分之前,宏是方便生嵌入代的唯一方法,于嵌入式系了能达到要求的性能,嵌入代码经常是必的方法。
2)
三重条件操作符的知个操作符存在C言中的原因是它使得编译器能生比if-then-else化的代,了解个用法是很重要的。
3)
懂得在宏中小心地把参数用括号括起来
4)
我也用问题开始讨论宏的副作用,例如:当你写下面的代码时生什么事?
        least = MIN(*p++, b);

3. 预处理器标识#error的目的是什么?
如果你不知道答案,看参考文献1这问题对区分一个正常的伙和一个呆子是很有用的。只有呆子才会C本的附去找出象问题的答案。当然如果你不是在找一个呆子,那么应试者最好希望自己不要知道答案。


死循Infinite loops

4. 嵌入式系常要用到无限循,你怎么C写死循呢?
问题用几个解决方案。我首的方案是:

while(1)
{

}

一些程序更喜如下方案:

for(;;)
{

}

实现方式为难,因为这法没有确切表达到底怎么回事。如果一个应试个作方案,我将用个作一个机会去探究他们这样做的基本原理。如果他的基本答案是:"我被教着这样做,但从没有想到过为什么。"我留下一个坏印象。

第三个方案是用 goto
Loop:
...
goto Loop;
应试者如出上面的方案,这说明或者他是一个汇编语言程序是好事)或者他是一个想入新域的BASIC/FORTRAN程序


数据声明(Data declarations

5. a出下面的定
a)
一个整型数(An integer
b)
一个指向整型数的指 A pointer to an integer

c)
一个指向指的的指,它指向的指是指向一个整型数( A pointer to a pointer to an intege
r
d)
一个有10个整型数的数 An array of 10 integers

e)
一个有10个指的数是指向一个整型数的。(An array of 10 pointers to integers

f)
一个指向有10个整型数数的指 A pointer to an array of 10 integers

g)
一个指向函数的指函数有一个整型参数并返回一个整型数(A pointer to a function that takes an integer as an argument and returns an integer

h)
一个有10个指的数指向一个函数,函数有一个整型参数并返回一个整型数( An array of ten pointers to functions that take an integer argument and return an integer

答案是:
a) int a; // An integer
b) int *a; // A pointer to an integer
c) int **a; // A pointer to a pointer to an integer
d) int a[10]; // An array of 10 integers
e) int *a[10]; // An array of 10 pointers to integers
f) int (*a)[10]; // A pointer to an array of 10 integers
g) int (*a)(int); // A pointer to a function a that takes an integer argument and returns an integer
h) int (*a[10])(int); // An array of 10 pointers to functions that take an integer argument and return an integer

们经常声称里有几个问题是那种要翻一下才能回答的问题,我同意法。当我写篇文章了确定法的正确性,我的确了一下。但是当我被面候,我期望被问题(或者相近的问题)。因在被面时间里,我确定我知道问题的答案。应试者如果不知道所有的答案(或至少大部分答案),那么也就没有为这次面做准,如果者没有为这次面做准,那么他又能什么出准呢?

Static

6. static的作用是什么?
简单问题很少有人能回答完全。在C言中,关static有三个明的作用:
1)
在函数体,一个被声明量在一函数被程中持其
2)
在模内(但在函数体外),一个被声明量可以被模内所用函数访问,但不能被模外其它函数访问。它是一个本地的全局量。
3)
在模内,一个被声明的函数只可被一模内的其它函数用。那就是,个函数被限制在声明它的模的本地范内使用。

大多数应试者能正确回答第一部分,一部分能正确回答第二部分,同是很少的人能懂得第三部分。是一个应试者的重的缺点,因然不懂得本地化数据和代的好和重要性。

Const

7.关const有什么含意?
我只要一听到被面"const意味着常数",我就知道我正在和一个余者打交道。去年Dan Saks在他的文章里完全概括了const的所有用法,因此ESP(者:Embedded Systems Programming)的每一位应该非常熟悉const能做什么和不能做什么.如果你从没有到那篇文章,只要能const意味着""就可以了。尽管个答案不是完全的答案,但我接受它作一个正确的答案。(如果你想知道更详细的答案,仔细读一下Saks的文章吧。)
如果应试者能正确回答问题,我将他一个附加的问题
下面的声明都是什么意思?

const int a;
int const a;
const int *a;
int * const a;
int const * a const;

/******/
前两个的作用是一a是一个常整型数。第三个意味着a是一个指向常整型数的指(也就是,整型数是不可修改的,但指可以)。第四个意思a是一个指向整型数的常指(也就是,指指向的整型数是可以修改的,但指是不可修改的)。最后一个意味着a是一个指向常整型数的常指(也就是,指指向的整型数是不可修改的,同也是不可修改的)。如果应试者能正确回答问题,那么他就我留下了一个好印象。顺带提一句,也你可能会,即使不用关 const,也是能很容易写出功能正确的程序,那么我什么要如此看重关const呢?我也如下的几下理由:

1)
const的作用是为给读你代的人达非常有用的信息,实际上,声明一个参数常量是了告了用户这个参数的用目的。如果你曾花很多时间清理其它人留下的垃圾,你就会很快学会感谢这点多余的信息。(当然,懂得用const的程序很少会留下的垃圾让别人来清理的。)
2)
过给优化器一些附加的信息,使用关const生更凑的代
3)
合理地使用关const可以使编译器很自然地保那些不希望被改的参数,防止其被无意的代修改。而言之,这样可以减少bug的出


Volatile

8. volatile有什么含意?出三个不同的例子。
一个定义为volatile量是说这变量可能会被意想不到地改这样编译器就不会去假设这量的了。精确地就是,化器在用到每次都小心地重新量的,而不是使用保存在寄存器里的份。下面是volatile量的几个例子:
1)
并行设备的硬件寄存器(如:状寄存器)
2)
一个中断服子程序中会访问到的非自动变(Non-automatic variables)
3)
线用中被几个任共享的

回答不出问题的人是不会被雇佣的。我认为这是区分C程序和嵌入式系程序的最基本的问题。搞嵌入式的家伙们经常同硬件、中断、RTOS等等打交道,所有些都要求用到volatile量。不懂得volatile的内容将会来灾
被面者正确地回答了问题怀疑是否会是这样),我将稍微深究一下,看一下家伙是不是直正懂得volatile完全的重要性。
1)
一个参数既可以是const可以是volatile?解释为什么。
2);
一个指可以是volatile ?解释为什么。
3);
下面的函数有什么错误

int square(volatile int *ptr)
{
        return *ptr * *ptr;
}

下面是答案:
1)
是的。一个例子是只的状寄存器。它是volatile它可能被意想不到地改。它是const程序不应该试图去修改它。
2);
是的。尽管并不很常。一个例子是当一个中子程序修一个指向一个buffer的指针时
3)
段代有点变态段代的目的是用来返指*ptr指向的平方,但是,由于*ptr指向一个volatile型参数,编译器将似下面的代

int square(volatile int *ptr)
{
    int a,b;
    a = *ptr;
    b = *ptr;
    return a * b;
}

由于*ptr可能被意想不到地该变,因此ab可能是不同的。果,段代可能返不是你所期望的平方!正确的代如下:

long square(volatile int *ptr)
{
    int a;
    a = *ptr;
    return a * a;
}

位操作(Bit manipulation

9. 嵌入式系统总是要用户对变量或寄存器行位操作。定一个整型a,写两段代,第一个abit 3,第二个清除a bit 3。在以上两个操作中,要保持其它位不
对这问题有三种基本的反
1)
不知道如何下手。被面者从没做任何嵌入式系的工作。
2)
bit fieldsBit fields是被扔到C言死角的西,它保你的代在不同编译器之是不可移植的,同也保了的你的代是不可重用的。我最近不幸看到 Infineon的通信芯片写的驱动程序,它用到了bit fields因此完全我无用,因我的编译器用其它的方式来实现bit fields的。从道德:永不要一个非嵌入式的家伙粘实际硬件的
3)
#defines bit masks 操作。是一个有极高可移植性的方法,是应该被用到的方法。最佳的解决方案如下:

#define BIT3 (0x1 << 3)
static int a;

void set_bit3(void)
{
    a |= BIT3;
}
void clear_bit3(void)
{
    a &= ~BIT3;
}

一些人喜欢为设置和清除而定一个掩一些明常数,也是可以接受的。我希望看到几个要点:明常数、|=&=~操作。


访问固定的内存位置(Accessing fixed memory locations

10. 嵌入式系统经常具有要求程序访问某特定的内存位置的特点。在某工程中,要求置一绝对地址0x67a9的整型量的值为0xaa66编译器是一个粹的ANSI编译器。写代去完成一任
问题测试你是否知道访问绝对地址把一个整型数转换typecast一指是合法的。问题实现方式随着个人格不同而不同。典型的似代如下:
    int *ptr;
    ptr = (int *)0x67a9;
    *ptr = 0xaa55;

 A more obscure approach is:
一个的方法是:

    *(int * const)(0x67a9) = 0xaa55;

即使你的品味更接近第二种方案,但我建你在面试时使用第一种方案。

中断(Interrupts

11. 中断是嵌入式系中重要的成部分,这导致了很多编译商提供一种让标C支持中断。具代表事是,生了一个新的关 __interrupt。下面的代就使用了__interrupt字去定了一个中断服子程序(ISR)请评论一下段代的。

__interrupt double compute_area (double radius)
{
    double area = PI * radius * radius;
    printf("/nArea = %f", area);
    return area;
}

个函数有太多的错误了,以至人不知从何起了:
1)ISR
不能返回一个。如果你不懂个,那么你不会被雇用的。
2) ISR
不能传递参数。如果你没有看到一点,你被雇用的机会等同第一
3)
多的理器/编译器中,浮点一般都是不可重入的。有些理器/编译器需要让额处的寄存器入,有些理器/编译器就是不允ISR中做浮点运算。此外,ISR应该是短而有效率的,在ISR中做浮点运算是不明智的。
4)
与第三点一脉相承,printf()常有重入和性能上的问题。如果你掉了第三和第四点,我不会太为难你的。不用,如果你能得到后两点,那么你的被雇用前景越来越光明了。


例子(Code examples

12 . 下面的代码输出是什么,什么?

void foo(void)
{
    unsigned int a = 6;
    int b = -20;
    (a+b > 6) ? puts("> 6") : puts("<= 6");
}
问题测试你是否懂得C言中的整数自动转换,我发现有些开者懂得极少西。不管如何,无符号整型问题的答案是出是 ">6"。原因是当表达式中存在有符号型和无符号所有的操作数都自动转换为无符号型。因此-20成了一个非常大的正整数,所以表达式算出的果大于6一点繁用到无符号数据型的嵌入式系是丰常重要的。如果你答问题,你也就到了得不到份工作的边缘

13. 价下面的代片断:

unsigned int zero = 0;
unsigned int compzero = 0xFFFF;
/*1's complement of zero */

于一个int型不是16位的理器为说,上面的代是不正确的。应编写如下:

unsigned int compzero = ~0;

问题真正能揭露出应试者是否懂得理器字的重要性。在我的经验里,好的嵌入式程序非常准确地明白硬件的细节和它的局限,然而PC机程序往往把硬件作一个无法避免的烦恼
到了段,应试者或者完全垂头丧气了或者信心满满志在必得。如果应试者不是很好,那么测试就在束了。但如果应试者做得不,那么我就扔出下面的追加问题问题是比较难的,我想仅仅非常秀的应试者能做得不。提出问题,我希望更多看到应试问题的方法,而不是答案。不管如何,你就当是娱乐...

动态内存分配(Dynamic memory allocation

14. 尽管不像非嵌入式算机那么常,嵌入式系统还是有从堆(heap)中动态分配内存的程的。那么嵌入式系中,动态分配内存可能生的问题是什么?
里,我期望应试者能提到内存碎片,碎片收集的问题量的持行时间等等。个主ESP志中被广泛地讨论过了(主要是 P.J. Plauger, 他的解释远远里能提到的任何解),所有回过头看一下志吧!让应试入一种虚假的安全感后,我拿出么一个小目:
下面的代片段的出是什么,什么?

char *ptr;
if ((ptr = (char *)malloc(0)) == NULL)
    puts("Got a null pointer");
else
    puts("Got a valid pointer");

是一个有趣的问题。最近在我的一个同事不意把0值传给了函数malloc,得到了一个合法的指之后,我才想到问题就是上面的代出是"Got a valid pointer"。我用个来开始讨论这样的一问题,看看被面者是否想到例程这样做是正确。得到正确的答案固然重要,但解决问题的方法和你做决定的基本原理更重要些。

Typedef
 
15 Typedef
C言中繁用以声明一个已存在的数据型的同字。也可以用预处理器做似的事。例如,思考一下下面的例子:

#define dPS struct s *
typedef struct s * tPS;

以上两种情况的意都是要定dPS tPS 一个指向s。哪种方法更好呢?(如果有的什么?
是一个非常微妙的问题,任何人答对这问题(正当的原因)是当被恭喜的。答案是:typedef更好。思考下面的例子:

dPS p1,p2;
tPS p3,p4;

第一个

struct s * p1, p2;
.
上面的代p1一个指向构的指,p2一个实际构,不是你想要的。第二个例子正确地定p3 p4 两个指。晦

16 . C言同意一些令人震惊的,下面的构是合法的,如果是它做些什么?

int a = 5, b = 7, c;
c = a+++b;

问题将做为这测验的一个愉快的尾。不管你相不相信,上面的例子是完全合乎法的。问题编译器如何理它?水平不高的编译作者实际上会争论这问题,根据最理原编译当能理尽可能所有合法的用法。因此,上面的代理成:

c = a++ + b;

因此, 段代持行后a = 6, b = 7, c = 12
如果你知道答案,或猜出正确答案,做得好。如果你不知道答案,我也不把个当作问题。我发现这问题的最大好是一个关于代码编格,代的可性,代的可修改性的好的话题

华为试题
1.
写出判断ABCD四个表达式的是否正确, 若正确, 写出经过表达式中 a(3
)
int a = 4;
(A)a += (a++); (B) a += (++a) ;(C) (a++) += a;(D) (++a) += (a++);
a = ?
答:C错误,左不是一个有效量,不能赋值,可改
(++a) += a;
改后答案依次9,10,10,11

2.32位系, C++程序,请计sizeof (5).
char str[] = “http://www.ibegroup.com/”
char *p = str ;
int n = 10;
请计

sizeof (str ) =
?(1
sizeof ( p ) =
?(2
sizeof ( n ) =
?(3
void Foo ( char str[100]){
请计
sizeof( str ) =
?(4
}
void *p = malloc( 100 );
请计
sizeof ( p ) =
?(5
答:(117 24 3 4 44 54

3. 回答下面的问题. (4)
(1).
文件中的 ifndef/define/endif 干什么用?预处

答:防止文件被重复引用
(2).
i nclude i nclude “filename.h” 有什么区
答:前者用来包含开发环境提供的库头文件,后者用来包含自己写的文件。
(3).
C++ 程序中用被 C 编译编译后的函数,什么要加 extern “C”声明?
答:函数和量被C++编译后在符号中的名字与C言的不同,被extern "C"
量和函数是按照C言方式编译接的。由于编译后的名字不同,C++程序不能直接
C 函数。C++提供了一个C 接交指定符号extern“C”来解决问题
(4). switch()
中不允的数据型是?
答:

4. 回答下面的问题(6)
(1).Void GetMemory(char **p, int num){
*p = (char *)malloc(num);
}
void Test(void){
char *str = NULL;
GetMemory(&str, 100);
strcpy(str, "hello");
printf(str);
}
请问运行Test 函数会有什么果?

答:“hello”
(2). void Test(void){
char *str = (char *) malloc(100);
strcpy(str, “hello”);
free(str);
if(str != NULL){
strcpy(str, “world”);
printf(str);
}
}
请问运行Test 函数会有什么果?

答:“world”
(3). char *GetMemory(void){
char p[] = "hello world";
return p;
}
void Test(void){
char *str = NULL;
str = GetMemory();
printf(str);
}
请问运行Test 函数会有什么果?

答:无效的指出不确定

5. strcat函数(6)
已知strcat函数的原型是
char *strcat (char *strDest, const char *strSrc);
其中strDest 是目的字符串,strSrc 是源字符串。

1)不C++/C 的字符串函数,请编写函数 strcat
答:

VC

char * __cdecl strcat (char * dst, const char * src)
{
char * cp = dst;
while( *cp )
cp++; /* find end of dst */
while( *cp++ = *src++ ) ; /* Copy src to end of dst */
return( dst ); /* return dst */
}
2strcat能把strSrc 的内容接到strDest什么char * 型的返回
答:方便赋值给其他

6.MFCCString型安全么?
答:不是,其它数据转换CString可以使用CString的成函数Format转换

7.C++什么用模板
答:(1)可用来动态和减小的数据
2)它是型无关的,因此具有很高的可复用性。
3)它在编译时而不是运行时检查数据型,保型安全
4)它是平台无关的,可移植性
5)可用于基本数据

8.CSingleLock是干什么的。
答:同步多个线一个数据的同时访问

9.NEWTEXTMETRIC 是什么。
答:物理字体构,用来置字体的高大小

10.程序什么应该使用线程,什么单线程效率高。
答:1.耗的操作使用线程,提高用程序响
2
.并行操作使用线程,如C/S架构的服器端并发线程响求。
3
.多CPU中,使用线程提高CPU利用率
4
.改善程序构。一个既又复程可以考多个线程,成几个独立或半独
立的运行部分,这样的程序会利于理解和修改。
其他情况都使用单线程。

11.Windows是内核级线程么。
答:下一

12.Linux有内核级线程么。
答:线程通常被定义为一个程中代的不同行路线。从实现方式上划分,线程有两
型:户级线内核级线 户线程指不需要内核支持而在用程序
实现线程,其不依于操作系核心,程利用线提供建、同步、
和管理线程的函数来控制用户线程。线程甚至在象 DOS 这样的操作系中也可实现
,但线程的度需要用程序完成,有些 Windows 3.x 作式多任。另外一
需要内核的参与,由内核完成线程的度。其依于操作系核心,由内核的内部
需求建和撤两种模型各有其好和缺点。用户线程不需要外的内核开支
,并且用户态线程的实现方式可以被定制或修改以适特殊用的要求,但是当一个线
程因 I/O 于等待状态时,整个程就会被度程序切换为等待状,其他线程得不
到运行的机会;而内核线没有各个限制,有利于发挥理器的并发优势,但却占
用了更多的系开支。
Windows NT
OS/2支持内核线程。Linux 支持内核的多线

13.C++中什么数据分配在或堆中,New分配数据是在近堆堆中?
答:: 存放局部量,函数用参数,函数返回,函数返回地址。由系管理
: 程序运行时动态new 和 malloc的内存就在堆上

14.使用线程是如何防止出大的波峰。
答:意思是如何防止同时产生大量的线程,方法是使用线程池,线程池具有可以同
度效率和限源使用的好线程池中的线程达到最大数,其他线程就会排
等候。

15函数模板与模板有什么区
答:函数模板的例化是由编译程序在理函数完成的,而模板的例化
由程序在程序中式地指定。

16一般数据若出日志了,会出什么情况,是否能使用?
答:只能查询操作,不能行更改,份等写操作,原因是任何写操作都要
日志。也就是基本上于不能使用的状

17 SQL Server是否支持行级锁,有什么好
答:支持,立封机制主要是操作行控制,扰进行封,保数据
的一致性和准确性,行确保在用取得被更新的行到行更新时间内不
被其它用所修改。因而行级锁即可保数据的一致性又能提高数据操作的迸性。

18如果数据库满了会出什么情况,是否能使用?
答:16

19 关于内存对齐问题以及sizof()
答:编译器自动对齐的原因:了提高程序的性能,数据构(尤其是应该尽可能

地在自然界上对齐。原因在于,访问对齐的内存,理器需要作两次内存访问
;然而,对齐的内存访问仅需要一次访问

20 int i=10, j=10, k=3; k*=i+j; k最后的是?
答:60,此考察实际写成: k*=(i+j);赋值运算符最低

21.数据的一行操作,另一行操作,如何实现?
答:将操作多个表的操作放入到事

22.TCP/IP 建立接的?(3-way shake)
答:在TCP/IP协议中,TCP协议提供可靠的接服,采用三次握手建立一个接。

  第一次握手:建立,客syn(syn=j)到服器,并SYN_SEND
,等待服器确
第二次握手:服器收到syn包,必SYNack=j+1),同自己也送一个
SYN
包(syn=k),即SYN+ACK包,此SYN_RECV
  第三次握手:客端收到服器的SYNACK包,向服送确ACK(ack=k+1)
,此包送完,客端和服ESTABLISHED,完成三次握手。

23.ICMP是什么协议,于哪一?
答:Internet控制协议于网络层IP

24.器怎么工作的?
答:触器主要是通事件行触而被行的,当某一表UPDATE
INSERT
DELETE 些操作,数据就会自动执行触器所定SQL 句,从而确保

据的理必符合由SQL 句所定规则

25.winsock建立接的主要实现?
答:服器端:socker()建立套接字,定(bind)并听(listen),用accept()

等待客接。
端:socker()建立套接字,接(connect)服器,接上后使用send()recv
),在套接字上写数据,直至数据交closesocket()套接字。
器端:accept()发现有客接,建立一个新的套接字,自身重新开始等待
接。生的套接字使用send()recv()写数据,直至数据交closesock
et()
套接字。

26.动态连的两种方式?
答:用一个DLL中的函数有两种方法:

1
时动态链接(load-time dynamic linking),模非常明确用某个出函数
,使得他就像本地函数一需要时链接那些函数所在DLL
提供了DLL所需的信息及DLL函数定位。
2
.运行时动态链接(run-time dynamic linking),运行可以通LoadLibrary
Loa
dLibraryEx
函数DLLDLL入后,模可以通过调GetProcAddressDLL函数的

出口地址,然后就可以通返回的函数指针调DLL函数了。如此即可避免文件了

27.IP播有那些好?
答:Internet生的多新的用,特是高带宽的多媒体用,来了带宽的急

消耗和网络拥挤问题播是一种允一个或多个送者(播源)一的数据包
到多个接收者(一次的,同的)的网播可以大大的省网络带宽,因
有多少个目地址,在整个网的任何一条路上只一的数据包。所以说组
的核心就是针对如何节约络资源的前提下保务质量。

1.static有什么用途?(至少明两种)
    1)
在函数体,一个被声明量在一函数被程中持其
    2)
在模内(但在函数体外),一个被声明量可以被模内所用函数访问,但不能被模外其它函数访问。它是一个本地的全局量。
    3)
在模内,一个被声明的函数只可被一模内的其它函数用。那就是,个函数被限制在声明它的模的本地范内使用

2.引用与指有什么区
    1)
引用必被初始化,指不必。
    2)
引用初始化以后不能被改,指可以改所指的象。
    3)
不存在指向空的引用,但是存在指向空的指

3.描述实时的基本特性
      
在特定时间内完成特定的任实时性与可靠性。

4.全局量和局部量在内存中是否有区?如果有,是什么区
     
全局存在静数据,局部量在堆

5.什么是平衡二叉
     
左右子都是平衡二叉 且左右子的深度差绝对值不大于1

6.溢出一般是由什么原因致的?
     
没有回收垃圾源。

7.什么函数不能声明虚函数?
      constructor
函数不能声明虚函数。

8.冒泡排序算法的时间度是什么?
     
时间度是O(n^2)

9.写出float x if句。
      if(x>0.000001&&x<-0.000001)

10.Internet采用哪种网络协议该协议的主要构?
      Tcp/Ip
协议
     
主要 /传输层/络层/数据/物理

11.Internet物理地址和IP地址转换采用什么协议
      ARP (Address Resolution Protocol)
(地址解析協議)

12.IP地址的编码部分?
     IP
地址由两部分成,网号和主机号。不是要和子网掩按位与上之后才能区分哪些是网位哪些是主机位。

13.户输M,N,从1N开始序循数数,每数到M,直至全部出。写出C程序。
    
环链表,用取余操作做
14.
不能做switch()的参数型是:
     switch
的参数不能为实型。

華為
1
、局部量能否和全局量重名?
    
答:能,局部会屏蔽全局。要用全局量,需要使用"::"
局部量可以与全局量同名,在函数内引用,会用到同名的局部量,而不会用到全局量。于有些编译器而言,在同一个函数内可以定多个同名的局部量,比如在两个循体内都定一个同名的局部量,而那个局部量的作用域就在那个循体内。

2、如何引用一个已义过的全局量?
    
答:extern
    
可以用引用文件的方式,也可以用extern字,如果用引用文件方式来引用某个在文件中声明的全局理,假定你将那个了,那么在编译报错,如果你用extern方式引用,假定你犯了同错误,那么在编译不会报错,而在接期间报错

3、全局量可不可以定在可被多个.C文件包含的文件中?什么?
   
答:可以,在不同的C文件中以static形式来声明同名全局量。
   
可以在不同的C文件中声明同名的全局量,前提是其中只能有一个C文件中,此时连接不会出

4for( 1 )有什么问题?它是什么意思?
   
答:无限循,和while(1)相同。

5do……whilewhile……do有什么区
   
答:前一个循一遍再判断,后一个判断以后再循

6写出下列代出内容
i nclude<stdio.h>
main()
{
int a,b,c,d;
a=10;
b=a++;
c=++a;
d=10*a++;
printf("b
cd%d%d%d"bcd
;
return 0;
}
答:1012120

1static全局量与普通的全局量有什么区static局部量和普通局部量有什么区static函数与普通函数有什么区
   
答:全局(外部)明之前再冠以static 就构成了静的全局量。全局量本身就是静方式, 全局量当然也是静方式。 两者在存方式上并无不同。两者的区别虽在于非静全局量的作用域是整个源程序, 当一个源程序由多个源文件,非静的全局量在各个源文件中都是有效的。 而静全局限制了其作用域, 即只在定义该变量的源文件内有效, 在同一源程序的其它源文件中不能使用它。由于静全局量的作用域局限于一个源文件内,只能为该源文件内的函数公用, 因此可以避免在其它源文件中引起错误
   
从以上分析可以看出, 把局部量改变为态变量后是改了它的存方式即改了它的生存期。把全局量改变为态变量后是改了它的作用域, 限制了它的使用范
    static
函数与普通函数作用域不同。在本文件。只在当前源文件中使用的函数应该说内部函数(static),内部函数应该在当前源文件中明和定于可在当前源文件以外使用的函数,应该在一个文件中明,要使用些函数的源文件要包含文件
    static
全局量与普通的全局量有什么区static全局量只初使化一次,防止在其他文件元中被引用;
    static
局部量和普通局部量有什么区static局部量只被初始化一次,下一次依据上一次

    static
函数与普通函数有什么区static函数在内存中只有一份,普通函数在每个被用中持一份拷

2、程序的局部量存在于(堆)中,全局量存在于(静 )中,动态数据存在于( 堆)中。

3有以下明和定
typedef union {long i; int k[5]; char c;} DATE;
struct data { int cat; DATE cow; double dog;} too;
DATE max;
则语 printf("%d",sizeof(struct date)+sizeof(max));果是:___52____
   
答:DATE是一个union, 量公用空. 里面最大的型是int[5], 占用20个字. 所以它的大小是
20
data
是一个struct, 每个量分开占用空. 依次
int4 + DATE20 + double8 = 32.
所以果是
20 + 32 = 52.
当然...在某些16编辑器下, int可能是2,那么果是 int2 + DATE10 + double8 = 20

4列和有什么区
   
列先先出,先出

5、写出下列代出内容
i nclude<stdio.h>
int inc(int a)
{
return(++a);
}
int multi(int*a,int*b,int*c)
{
return(*c=*a**b);
}
typedef int(FUNC1)(int in);
typedef int(FUNC2) (int*,int*,int*);

void show(FUNC2 fun,int arg1, int*arg2)
{
INCp=&inc;
int temp =p(arg1);
fun(&temp,&arg1, arg2);
printf("%d/n",*arg2);
}

main()
{
int a;
show(multi,10,&a);
return 0;
}
答:
110
7
找出下面代中的所以错误

明:以下代是把一个字符串倒序,如“abcd”倒序后变为“dcba”

1、#i nclude"string.h"
2
main()
3
{
4
char*src="hello,world";
5
char* dest=NULL;
6
int len=strlen(src);
7
dest=(char*)malloc(len);
8
char* d=dest;
9
char* s=src[len];
10
while(len--!=0)
11
d++=s--;
12
printf("%s",dest);
13
return 0;
14
}
答:

方法1
int main(){
char* src = "hello,world";
int len = strlen(src);
char* dest = (char*)malloc(len+1);//
/0分配一个空
char* d = dest;
char* s = &src[len-1];//
指向最后一个字符
while( len-- != 0 )
*d++=*s--;
*d = 0;//
尾部要加/0
printf("%s/n",dest);
free(dest);//
使用完,放空,以免造成内存泄露

return 0;
}
方法2
i nclude <stdio.h>
i nclude <string.h>
main()
{
char str[]="hello,world";
int len=strlen(str);
char t;
for(int i=0; i<len/2; i++)
{
t=str[i];
str[i]=str[len-i-1]; str[len-i-1]=t;
}
printf("%s",str);
return 0;
}
1.-1,2,7,28,,126
请问28126那个数是什么?什么?

第一的答案应该4^3-1=63
律是n^3-1(n偶数02
4)
      n^3+1(
n奇数13
5)
答案:
63
2.
用两个栈实现一个列的功能?要求出算法和思路!

2栈为A,B, 一开始均.

:
将新元素pushA;

:
(1)
判断B是否空;

(2)
如果不空,A中所有元素依次pop出并pushB
(3)
B栈顶元素pop出;

这样实现列入和出的平度都O(1), 比上面的几种方法要好。3.c函数中将一个字符转换成整型的函数是atool()个函数的原型是什么?
函数名: atol
: 把字符串转换整型数

: long atol(const char *nptr);
程序例
:
i nclude <stdlib.h>
i nclude <stdio.h>
int main(void)
{
long l;
char *str = "98765432";

l = atol(lstr);
printf("string = %s integer = %ld/n", str, l);
return(0);
}

2.于一个繁使用的短小函数,C言中用什么实现,C++用什么实现?
c
用宏定c++
inline
  3.
直接接两个信令点的一组链路称作什么
?
PPP
点到点

  4.
接入网用的是什么接口?
  5.voip
都用了那些协议
?
  6.
测试都有那些种
?
黑盒:针对功能的测试    白合:测试函数功能,各函数接口

  7.
确定模的功能和模的接口是在设计的那个段完成的?
概要设计阶

  8.enum string
    {
    x1,
    x2,
    x3=10,
    x4,
    x5,
    }x;
  
x= 0x8010050x8010f4  ;
  9.unsigned char *p1;
    unsigned long *p2;
    p1=(unsigned char *)0x801000;
    p2=(unsigned long *)0x810000;
   
请问
p1+5=  ;
        p2+5=  ;
.选择题
:
  1.Ethternet
接到Internet用到以下那个协议
?
  A.HDLC;B.ARP;C.UDP;D.TCP;E.ID
  2.
属于网络层协议的是
:
  A.TCP;B.IP;C.ICMP;D.X.25
  3.Windows
消息度机制是
:
  A.
指令;B.指令堆;C.消息;D.消息堆
;
  4.unsigned short hash(unsigned short key)
    {
      return (key>>)%256
    }
  
请问hash(16),hash(256)
:
  A.1.16;B.8.32;C.4.16;D.1.32
.错题
:
  1.
请问下面程序有什么错误
?
   int a[60][250][1000],i,j,k;
   for(k=0;k<=1000;k++)
    for(j=0;j<250;j++)
     for(i=0;i<60;i++)
      a[i][j][k]=0;
把循环语句内外一下

  2.#define Max_CB 500
    void LmiQueryCSmd(Struct MSgCB * pmsg)
     {
     unsigned char ucCmdNum;
     ......
   
     for(ucCmdNum=0;ucCmdNum<Max_CB;ucCmdNum++)
      {
      ......;
      }
死循
   3.
以下是求一个数的平方的程序,找出错误:
    #define SQUARE(a)((a)*(a))
    int a=5;
    int b;
    b=SQUARE(a++);
   4.typedef unsigned char BYTE
     int examply_fun(BYTE gt_len; BYTE *gt_code)
      { 
      BYTE *gt_buf;
      gt_buf=(BYTE *)MALLOC(Max_GT_Length);
      ......
      if(gt_len>Max_GT_Length)
        {
        return GT_Length_ERROR; 
        }
        .......
      }
.
:
   1.IP Phone
的原理是什么
?
IPV6
   2.TCP/IP
通信建立的程怎,端口有什么作用?

三次握手,确定是哪个用程序使用该协议
   3.1
号信令和7号信令有什么区,我国某前广泛使用的是那一种?
   4.
5种以上的电话业务

软亚洲技中心的面试题!!!
1
程和线程的差
线程是指程内的一个,也是程内的可.
程的区
:
(1)
度:线程作为调度和分配的基本位,程作为拥源的基本

(2)
性:不仅进程之可以并发执行,同一个程的多个线程之也可并发执
(3)
源:程是源的一个独立位,线程不有系统资源,但可以访问隶属于程的.
(4)
:在建或撤消,由于系都要之分配和回收源,致系的开大于建或撤消线的开

2.
测试方法
人工测试:个人复、抽和会

机器测试:黑盒测试和白盒测试

2Heapstack的差
Heap
是堆,stack
Stack
的空由操作系分配/放,Heap上的空分配/放。
Stack
有限,Heap是很大的自由存
C
中的malloc函数分配的内存空即在堆上,C++对应的是new操作符。
程序在编译对变量和函数分配内存都在,且程序运行程中函数参数的传递也在
3
Windows下的内存是如何管理的?
4
.介.Net.Net的安全性。
5
.客端如何访问.Net实现Web Service
6
C/C++编译器中虚表是如何完成的?
7
谈谈COM线程模型。然后讨论进程内/件的差
8
谈谈IA32下的分机制
(4K)模式,大(4M)
9
两个量,如何找出一个带环单链表中是什么地方出现环的?
一个增一,一个增二,他指向同一个接点就是的地方
10
.在IA32中一共有多少种法从用户态跳到内核
过调,从ring3ring0,中断从ring3ring0vm86等等
11
.如果只想序有一个例运行,不能运行两个。像winamp,只能开一个窗口,怎样实现
用内存映射或全局原子(互斥量)、找窗口句柄..
FindWindow
,互斥,写志到文件或注册表,共享内存。. 
 
12
.如何截取键盘的响所有的‘a’‘b’

键盘钩SetWindowsHookEx
 13ApartmentCOM中有什么用?什么要引入?

 14.存储过程是什么?有什么用?有什么点?
我的理解就是一堆sql的集合,可以建立非常复查询编译运行,所以运行一次后,以后再运行速度比SQL快很多
 15Template有什么特点?什么候用?
16
谈谈Windows DNA构的特点和点。


络编程中设计器,使用多 线 请问有什么区
1
程:子程是父程的复制品。子得父程数据空、堆和的复制品。
2
线程:相程而言,线程是一个更加接近与行体的概念,它可以与同程的其他线程共享数据,但有自己的有独立的行序列。
两者都可以提高程序的并度,提高程序运行效率和响应时间
线程和程在使用上各有缺点:线行开小,但不利于源管理和保;而程正相反。同线程适合于在SMP机器上运行,而可以跨机器迁移。

思科
1.
用宏定写出swapxy
#define swap(x, y)/
x = x + y;/
y = x - y;/
x = x - y;
2.
a[N],存放了1N-1个数,其中某个数重复一次。写一个函数,找出被重复的数字.时间度必须为oN)函数原型:
int do_dup(int a[],int N)
3
实现x是否2的若干次的判断
int i = 512;
cout << boolalpha << ((i & (i - 1)) ? false : true) << endl;
4.unsigned int intvert(unsigned int x,int p,int n)
实现对x转换,p起始化位,n需要转换,起始点在右.x=0b0001 0001,p=4,n=3转换x=0b0110 0001
unsigned int intvert(unsigned int x,int p,int n){
unsigned int _t = 0;
unsigned int _a = 1;
for(int i = 0; i < n; ++i){
_t |= _a;
_a = _a << 1;
}
_t = _t << p;
x ^= _t;
return x;
}

慧通:
什么是预编译
需要预编译
1、是使用不常改的大型代体。
2、程序由多个模块组成,所有模都使用一组标准的包含文件和相同的编译选项。在种情况下,可以将所有包含文件预编译为一个预编译头

char * const p;
char const * p
const char *p

上述三个有什么区
char * const p; //
常量指p不可以修改
char const * p
//指向常量的指,指向的常量不可以改
const char *p
//char const *p

char str1[] = "abc";
char str2[] = "abc";

const char str3[] = "abc";
const char str4[] = "abc";

const char *str5 = "abc";
const char *str6 = "abc";

char *str7 = "abc";
char *str8 = "abc";


cout << ( str1 == str2 ) << endl;
cout << ( str3 == str4 ) << endl;
cout << ( str5 == str6 ) << endl;
cout << ( str7 == str8 ) << endl;

果是:0 0 1 1
解答:str1,str2,str3,str4是数组变量,它有各自的内存空

str5,str6,str7,str8是指,它指向相同的常量区域。


12.
以下代中的两个sizeof用法有问题吗[C]
void UpperCase( char str[] ) //
str 中的小写字母转换成大写字母

{
    for( size_t i=0; i<sizeof(str)/sizeof(str[0]); ++i )
        if( 'a'<=str[i] && str[i]<='z' )
            str[i] -= ('a'-'A' );
}
char str[] = "aBcDe";
cout << "str
字符: " << sizeof(str)/sizeof(str[0]) << endl;
UpperCase( str );
cout << str << endl;

答:函数内的sizeof问题。根据法,sizeof如用于数,只能出静的大小,无法检测动态分配的或外部数大小。函数外的str是一个静的数,因此其大小6,函数内的str实际只是一个指向字符串的指,没有任何外的与数相关的信息,因此sizeof作用于上只将其当指看,一个指针为4个字,因此返回4

一个32位的机器,机器的指是多少位
是多少位只要看地址总线的位数就行了。80386以后的机子都是32的数据总线。所以指的位数就是4个字了。

main()
{
  int a[5]={1,2,3,4,5};
   int *ptr=(int *)(&a+1);

   printf("%d,%d",*(a+1),*(ptr-1));
}
出:
2,5
*(a+1
)就是a[1]*(ptr-1)就是a[4],果是2
5
&a+1
不是首地址+1,系认为加一个a的偏移,是偏移了一个数大小(本例是5int

int *ptr=(int *)(&a+1);
ptr实际&(a[5]),也就是a+5
原因如下:

&a
是数,其 int (*)[5];
而指1要根据指针类型加上一定的

不同型的指+1之后增加的大小不同
a
5int,所以要加 5*sizeof(int)
所以ptr实际
a[5]
但是prt(&a+1)型是不一(点很重要
)
所以prt-1只会减去
sizeof(int*)
a,&a
的地址是一的,但意思不一a是数首地址,也就是a[0]的地址,&a象(数)首地址,a+1是数下一元素的地址,即a[1],&a+1是下一个象的地址,即a[5].


1.
请问以下代有什么问题
int  main()
{
char a;
char *str=&a;
strcpy(str,"hello");
printf(str);
return 0;
}
没有str分配内存空,将会生异常
问题出在将一个字符串复制一个字符量指所指地址。然可以正确果,但因越界行内在写而致程序崩

char* s="AAA";
printf("%s",s);
s[0]='B';
printf("%s",s);
有什么

"AAA"
是字符串常量。s是指,指向个字符串常量,所以声明s候就有问题
cosnt char* s="AAA";
然后又因是常量,所以s[0]赋值操作是不合法的。

1、写一个宏,个宏入两个参数并返回小的一个。
.#define Min(X, Y) ((X)>(Y)?(Y):(X))//
尾没有;
2
、嵌入式系常要用到无限循,你怎么用C写死循

while(1){}
或者for(;;)
3
、关static的作用是什么?

态变
4
、关const有什么含意?
表示常量不可以修改的量。
5
、关volatile有什么含意?并出三个不同的例子?
提示编译象的可能在编译器未监测到的情况下改


int (*s[10])(int)
表示的是什么啊
int (*s[10])(int)
函数指,每个指指向一个int func(int param)的函数。


1.
有以下表达式:
int a=248; b=4;int const c=21;const int *d=&a;
int *const e=&b;int const *f const =&a;
请问下列表达式哪些会被编译器禁止?什么?
*c=32;d=&b;*d=43;e=34;e=&a;f=0x321f;
*c
是个什么东东,禁止
*d
了是const 禁止
e = &a
了是const 禁止
const *f const =&a;
禁止
2.
两个量的,不使用第三个量。即a=3,b=5,之后a=5,b=3;
有两种解法, 一种用算算法, 一种用^(异或
)
a = a + b;
b = a - b;
a = a - b;
or
a = a^b;//
只能
int,char..
b = a^b;
a = a^b;
or
a ^= b ^= a;
3.c
c++中的struct有什么不同?

c
c++struct的主要区c中的struct不可以含有成函数,而c++中的struct可以。c++structclass的主要区在于默的存取限不同,struct认为public,而class认为private
4.
i nclude <stdio.h>
 
i nclude <stdlib.h>
  void getmemory(char *p)
  {
    p=(char *) malloc(100);
    strcpy(p,"hello world");
  }
  int main( )
  {
    char *str=NULL;
    getmemory(str);
    printf("%s/n",str);
    free(str);
    return 0;
   }
程序崩getmemory中的malloc 不能返回动态内存, free()str操作很危

5.char szstr[10];
  strcpy(szstr,"0123456789");
 
生什么果?什么?
 
度不一,会造成非法的OS
6.
几种程的同步机制,并比缺点。

  
原子操作
信号量机制

  
自旋
  
管程,会合,分布式系

7.程之通信的途径
共享存
消息传递
管道:以文件系统为
11.
程死的原因
争及程推进顺序非法
12.
4个必要条件
互斥、求保持、不可剥
13.

鸵鸟略、防策略、避免策略、检测与解除死
15.  
操作系度策略有哪几种?
FCFS(
先来先服)时间轮转,多
8.
的静和非静有何区
的静每个只有一个,非静每个象一个
9.
虚函数如何定?使用时应注意什么?
virtual void f()=0;
是接口,子实现
10.
表的区
:数据序存,固定大小
表:数据可以随机存,大小可动态

12.ISO的七模型是什么?tcp/udp是属于哪一tcp/udp有何点?

表示
话层
输层
络层
物理
物理
tcp /udp
属于运输层
TCP
提供了数据流传输、可靠性、有效流控制、全双工操作和多路复用技等。
TCP 不同, UDP 并不提供 IP 协议的可靠机制、流控制以及错误恢复功能等。由于 UDP 较简单 UDP 包含很少的字,比 TCP 负载消耗少。
tcp:
提供定的传输,有流量控制,缺点是包大,冗余性不好
udp:
不提供定的服,包小,开  


1
(void *)ptr (*(void**))ptr果是否相同?其中ptr同一个指
.(void *)ptr
(*(void**))ptr是相同的
2
int main()
   {
    int x=3;
    printf("%d",x);
    return 1;
  
   }
函数既然不会被其它函数用,什么要返回1

mian
中,c认为0表示成功,非0表示错误。具体的是某中具体出信息


1
,要对绝对地址0x100000赋值,我可以用
(unsigned int*)0x100000 = 1234;
那么要是想程序跳绝对地址是0x100000行,应该怎么做?
*((void (*)( ))0x100000 ) ( );
首先要将0x100000转换成函数指,:
(void (*)())0x100000
然后再用它
:
*((void (*)())0x100000)();
typedef可以看得更直
:
typedef void(*)() voidFuncPtr;
*((voidFuncPtr)0x100000)();
2
,已知一个数table,用一个宏定,求出数据的元素个数

#define NTBL
#define NTBL (sizeof(table)/sizeof(table[0]))

试题: 线程与程的区? 线程是否具有相同的堆? dll是否有独立的堆?
程是死的,只是一些源的集合,真正的程序行都是线程来完成的,程序启候操作系就帮你建了一个主线程。

每个线程有自己的堆
DLL
中有没有独立的堆问题不好回答,或者说这问题本身是否有问题。因DLL中的代是被某些线程所行,只有线有堆,如果DLL中的代EXE中的线程所用,那么候是不是说这DLL没有自己独立的堆?如果DLL中的代是由DLL自己建的线程所行,那么是不是DLL有独立的堆

以上的是堆,如果于堆来,每个DLL有自己的堆,所以如果是从DLL动态分配的内存,最好是从DLL除,如果你从DLL中分配内存,然后在EXE中,或者另外一个DLL除,很有可能致程序崩


unsigned short A = 10;
printf("~A = %u/n", ~A);

char c=128;
printf("c=%d/n",c);

出多少?并分析
第一,~A 0xfffffff5,int 11,但出的是uint。所以4294967285
第二c0x10,出的是int,最高位1,是数,所以它的就是0x00补码就是128,所以出-128

两道都是在考察二制向intuint转换时的最高位理。

分析下面的程序:
void GetMemory(char **p,int num)
{
    *p=(char *)malloc(num);
   
}       
int main()
{
    char *str=NULL;
   
    GetMemory(&str,100);
   
    strcpy(str,"hello");
   
    free(str);
   
    if(str!=NULL)
    {
        strcpy(str,"world");
    }   
       
    printf("/n str is %s",str);
    getchar();
}   
问输果是什么?希望大家能说说原因,先谢谢
str is world
free
只是放的str指向的内存空,它本身的值还是存在的.
所以free之后,有一个好的习惯就是将
str=NULL.
str指向空的内存已被回收,如果句之前存在分配空的操作的,段存是可能被重新分配其他量的
,
尽管段程序确是存在大大的问题(上面各位已经说得很清楚了),但是通常会打印出world来。

是因程中的内存管理一般不是由操作系完成的,而是由函数自己完成的。
当你malloc内存的候,管理向操作系(可能会比你申的大一些),然后在这块记录一些管理信息(一般是在你申的内存前面一点),并将可用内存的地址返回。但是放内存的候,管理通常都不会将内存还给操作系,因此你是可以继续访问这块地址的,只不。。。。。。。。楼上都说过了,最好别这么干。

char a[10],strlen(a)什么等于15?运行的

i nclude "stdio.h"
i nclude "string.h"

void main()
{

char aa[10];
printf("%d",strlen(aa));
}

sizeof()和初不初始化,没有关系;
strlen()
和初始化有关。


char (*str)[20];/*str
是一个数,即指向数的指*/
char *str[20];/*str
是一个指,其元素型数据.*/

long a=0x801010;
a+5=?
0x801010
用二制表示“1000 0000 0001 0000 0001 0000”,十制的值为8392720,再加上5就是8392725

1)struct A
{
       char t:4;
       char k:4;
       unsigned short i:8;
       unsigned long m;
};
sizeof(A) = ?
struct A
{
       char t:4; 4

       char k:4; 4

       unsigned short i:8; 8
     
       unsigned long m; //
偏移24节对齐

}; //
8
2)
下面的函数实现在一个数上加一个数,有什么错误改正。
int add_n ( int n )
{
    static int i = 100;
    i += n;
    return i;
}
当你第二次得不到正确的果,道你写个函数就是用一次?问题就出在 static上?


//
帮忙分析一下
i nclude<iostream.h>
i nclude <string.h>
i nclude <malloc.h>
i nclude <stdio.h>
i nclude <stdlib.h>
i nclude <memory.h>
typedef struct  AA
{
        int b1:5;
        int b2:2;
}AA;
void main()
{
        AA aa;
        char cc[100];
         strcpy(cc,"0123456789abcdefghijklmnopqrstuvwxyz");
       memcpy(&aa,cc,sizeof(AA));
        cout << aa.b1 <<endl;
        cout << aa.b2 <<endl;
}
答案是 -16和1

首先sizeof(AA)的大小4,b1b25bit2bit.
经过strcpymemcpy,aa4个字所存放的
:
0,1,2,3
ASC,即
00110000,00110001,00110010,00110011
所以,最后一步:示的是4个字的前5位,和之后的2位

别为10000,01
int是有正之分  所以:答案是-16和1

求函数返回x=9999;
int func
x

{
    int countx = 0;
    while ( x )
    {
        countx ++;
        x = x&(x-1);
    }
    return countx;
}
果呢?
知道了统计9999的二制数中有多少个1的函数,且有
9999
9×102451225615

9×1024中含有1的个数2
512
中含有1的个数1
256
中含有1的个数1
15
中含有1的个数4
故共有1的个数88
1000 - 1 = 0111
,正好是原数取反。就是原理。
种方法来求1的个数是很效率很高的。
不必去一个一个地移位。循次数最少。

int a,b,c 写函数实现C=a+b ,不可以改数据,如将clong int,是如何理溢出问题
bool add (int a, int b,int *c)
{
*c=a+b;
return (a>0 && b>0 &&(*c<a || *c<b) || (a<0 && b<0 &&(*c>a || *c>b)));
}


分析:
struct bit
{   int a:3;
    int  b:2;
    int c:3;
};
int main()
{
  bit s;
  char *c=(char*)&s;
   cout<<sizeof(bit)<<endl;
  *c=0x99;
   cout << s.a <<endl <<s.b<<endl<<s.c<<endl;
     int a=-1;
   printf("%x",a);
  return 0;
}
什么是
4
1
-1
-4
ffffffff
0x99在内存中表示 100 11 001 , a = 001, b = 11, c = 100
c有符合数, c = 100, 最高1表示c为负数,数在算机用补码表示,所以c = -4;同理

b = -1;
c有符合数, c = 100, c = 4,同理 b = 3


位域   
有些信息在存储时,并不需要占用一个完整的字 而只需占几个或一个二制位。例如在存放一个开关量,只有01 两种状 用一位二位即可。省存,并使便,C言又提供了一种数据构,称位域位段。所位域是把一个字中的二位划分几个不同的区域, 明每个区域的位数。每个域有一个域名,允在程序中按域名行操作。 这样就可以把几个不同的象用一个字的二制位域来表示。一、位域的定和位域量的明位域定构定相仿,其形式
    
struct
位域构名
    
{
位域列表
};   
其中位域列表的形式 明符 位域名:位域
    
例如:
    
struct bs   
{   
int a:8;   
int b:2;   
int c:6;   
};   
位域量的明与明的方式相同。 可采用先定明,同义说明或者直接三种方式。例如:
    
struct bs   
{   
int a:8;   
int b:2;   
int c:6;   
}data;   
databs量,共占两个字。其中位域a8位,位域b2位,位域c6位。于位域的定尚有以下几点明:   

1. 一个位域必在同一个字中,不能跨两个字。如一个字所剩空存放另一位域从下一元起存放位域。也可以有意使某位域从下一元开始。例如:    
struct bs   
{   
unsigned a:4   
unsigned :0 /*
空域
*/   
unsigned b:4 /*
从下一元开始存放
*/   
unsigned c:4   
}   
个位域定中,a占第一字4位,后4位填0表示不使用,b从第二字开始,占用4位,c占用4位。   

2. 由于位域不允跨两个字,因此位域的度不能大于一个字度,也就是不能超8位二   

3. 位域可以无位域名,这时它只用来作填充或整位置。无名的位域是不能使用的。例如:    
struct k   
{   
int a:1   
int :2 /*
2位不能使用
*/   
int b:3   
int c:2   
};   
从以上分析可以看出,位域在本上就是一种型, 其成是按二位分配的。   

二、位域的使用位域的使用和构成的使用相同,其一般形式 位域量名&#8226;位域名 位域允用各种格式出。   
main(){   
struct bs   
{   
unsigned a:1;   
unsigned b:3;   
unsigned c:4;   
} bit,*pbit;   
bit.a=1;   
bit.b=7;   
bit.c=15;   
pri


i nclude <stdio.h>

int main(void) {

    int **p;
    int arr[100];

    p = &arr;

    return 0;
}
解答:

,是指针类型不同,
int **p; //

&arr; //
得到的是指向第一维为100的数的指
i nclude <stdio.h>
int main(void) {
int **p, *q;
int arr[100];
q = arr;
p = &q;
return 0;
}


下面个程序行后会有什么错误或者效果:
 #define MAX 255
 int main()
{
   unsigned char A[MAX],i;//i
被定义为
unsigned char
   for (i=0;i<=MAX;i++)
      A[i]=i;
}
解答:死循加数越界访问C/C++行数越界检查

MAX=255
A的下围为:0..MAX-1,是其一..
其二.i255,
:
  A[255]=255;
句本身没有问题..但是返回for (i=0;i<=MAX;i++)
,
由于unsigned char的取(0..255),i++以后i0..无限循下去.

struct name1{
   char  str;
   short x;
   int   num;
}

struct name2{
   char str;
   int num;
   short x;
}

sizeof(struct name1)=8,sizeof(struct name2)=12
在第二个构中,num按四个字节对齐char后必留出3的空;同时为整个构的自然对齐里是4节对齐),在x补齐2个字这样就是12

intel
A.c
B.c两个c文件中使用了两个相同名字的static,编译候会不会有问题?两个static量会保存到哪里(栈还是堆或者其他的)?
static
的全局量,表明在本模中有意,不会影响其他模

都放在数据区,但是编译的命名是不同的。
如果要使量在其他模也有意,需要使用extern字。

struct s1
{
  int i: 8;
  int j: 4;
  int a: 3;
  double b;
};

struct s2
{
  int i: 8;
  int j: 4;
  double b;
  int a:3;
};

printf("sizeof(s1)= %d/n", sizeof(s1));
printf("sizeof(s2)= %d/n", sizeof(s2));
result: 16, 24
第一个
struct s1
{
  int i: 8;
  int j: 4;
  int a: 3;
  double b;
};
上是这样的,首先是i在相0的位置,占8位一个字,然后,j就在相一个字的位置,由于一个位置的字数是4位的倍数,因此不用对齐,就放在那里了,然后是a,要在3位的倍数关系的位置上,因此要移一位,在15位的位置上放下,目前共是18位,折算来是22位的子,由于double8的,因此要在相0要是8个字的位置上放下,因此从18位开始到8个字的位置被忽略,直接放在8的位置了,因此,共是16

第二个最后会照是不是构体内最大数据的倍数,不是的,会成是最大数据的倍数

上面是基本问题,接下来是问题


本人很弱,几个也搞不定,特来求救:
1
文件file1.txt的内容(例如):
12
34
56
出到file2.txt
56
34
12
(逆序)
2
出和一个定整数的所有
例如n=5
5=1+4
5=2+3(相加的数不能重复)

则输
1
423
望高手教!!

第一,注意可增.
i nclude <stdio.h>
i nclude <stdlib.h>

int main(void)
{
         int MAX = 10;
int *a = (int *)malloc(MAX * sizeof(int));
int *b;
   
FILE *fp1;
FILE *fp2;

fp1 = fopen("a.txt","r");
if(fp1 == NULL)
{printf("error1");
    exit(-1);
}

    fp2 = fopen("b.txt","w");
if(fp2 == NULL)
{printf("error2");
    exit(-1);
}

int i = 0;
    int j = 0;

while(fscanf(fp1,"%d",&a[i]) != EOF)
{
i++;
j++;
if(i >= MAX)
{
MAX = 2 * MAX;
b = (int*)realloc(a,MAX * sizeof(int));
if(b == NULL)
{
printf("error3");
exit(-1);
}
a = b;
}
}

for(;--j >= 0;)
   fprintf(fp2,"%d/n",a[j]);

fclose(fp1);
fclose(fp2);

return 0;
}

第二.
i nclude <stdio.h>

int main(void)
{
unsigned long int i,j,k;

printf("please input the number/n");
scanf("%d",&i);
    if( i % 2 == 0)
        j = i / 2;
else
j = i / 2 + 1;

printf("The result is /n");
    for(k = 0; k < j; k++)
     printf("%d = %d + %d/n",i,k,i - k);
return 0;
}

i nclude <stdio.h>
void main()
{
unsigned long int a,i=1;
scanf("%d",&a);
if(a%2==0)
{
     for(i=1;i<a/2;i++)
     printf("%d",a,a-i);
}
else
for(i=1;i<=a/2;i++)
        printf(" %d, %d",i,a-i);
}

兄弟,这样目若是做不出来在是有些不应该, 你一个递规反向出字符串的例子,是反序的典例程.

void inverse(char *p)
{
    if( *p = = '/0' )
return;
    inverse( p+1 );
    printf( "%c", *p );
}

int main(int argc, char *argv[])
{
    inverse("abc/0");

    return 0;
}

了楼上的递规反向
i nclude <stdio.h>
void test(FILE *fread, FILE *fwrite)
{
        char buf[1024] = {0};
        if (!fgets(buf, sizeof(buf), fread))
    &nb

 

原创粉丝点击