Vous êtes sur la page 1sur 28

1. What will print out?

2. 3. 4. 5. 6. 7. 8. 9. 10. } main() { char *p1="name"; char *p2; p2=(char*)malloc(20); memset (p2, 0, 20); while(*p2++ = *p1++); printf("%s\n",p2);

Answer:empty string. 11. What will be printed as the result of the operation below:
12. 13. 14. 15. 16. 17. 18. } main() { int x=20,y=35; x=y++ + x++; y= ++y + ++x; printf("%d%d\n",x,y);

Answer : 5794 19. What will be printed as the result of the operation below:
20. 21. 22. 23. 24. } { int x=5; printf("%d,%d,%d\n",x,x< <2,x>>2); main()

Answer: 5,20,1

25. What will be printed as the result of the operation below:


26. 27. 28. 29. 30. 31. 32. 33. 34. 35. 36. } int swap2(int a, int b) { #define swap(a,b) a=a+b;b=a-b;a=a-b; void main() { int x=5, y=10; swap (x,y); printf("%d %d\n",x,y); swap2(x,y); printf("%d %d\n",x,y);

int temp;

temp=a;

b=a;

a=temp;

return 0;

Answer: 10, 5 10, 5 37. What will be printed as the result of the operation below:
38. 39. 40. main() { char *ptr = " Cisco Systems";

41. 42. 43. 44. 45. }

*ptr++; printf("%s\n",ptr); ptr++; printf("%s\n",ptr);

Answer:Cisco Systems isco systems

46. What will be printed as the result of the operation below:


47. 48. 49. 50. 51. 52. } main() { char s1[]="Cisco"; char s2[]= "systems"; printf("%s",s1);

Answer: Cisco 53. What will be printed as the result of the operation below:
54. 55. 56. 57. 58. 59. 60. 61. 62. 63. 64. } main() { char *p1; char *p2; p1=(char *)malloc(25); p2=(char *)malloc(25); strcpy(p1,"Cisco"); strcpy(p2,"systems"); strcat(p1,p2); printf("%s",p1);

Answer: Ciscosystems 65. The following variable is available in file1.c, who can access it?:
66. static int average;

Answer: all the functions in the file1.c can access the variable. 67. WHat will be the result of the following code?
68. 69. 70. 71. 72. 73. } #define TRUE 0 // somecode.

while(TRUE) { // somecode

Answer: This will not go into the loop as TRUE is defined as 0. 74. What will be printed as the result of the operation below:
75. int x;

int modifyvalue()

return(x+=10);

int changevalue(int x)

return(x+=1);

void main()

int x=10;

x++;

changevalue(x);

x++;

modifyvalue();

printf("First output:%d\n",x);

x++;

changevalue(x);

printf("Second output:%d\n",x);

modifyvalue();

printf("Third output:%d\n",x);

Answer: 12 , 13 , 13 76. What will be printed as the result of the operation below:
77. main()

78. 79. 80. 81. 82. 83.

{ int x=10, y=15; x = x++; y = ++y; printf("%d %d\n",x,y); }

Answer: 11, 16 84. What will be printed as the result of the operation below:
85. 86. 87. 88. 89. 90. } main() { int a=0; if(a==0) printf("Cisco Systems\n"); printf("Cisco Systems\n");

Answer: Two lines with Cisco Systems will be printed. The questions were asked by Lucent Technologies for Software Tester (in some companies SQA - Software Quality Assurance) position. 1. What programming language are you using? 2. What C++ libraries are you proficient with? 3. Which argorithm do you like the most? Why? 4. How do you debug SSH? 5. What is the QA process? 6. How do you train another QA engineer? 7. What bug tracking tools you have used? Have you used any free tools? 8. How do you start your QA if there are no system requirements? 9. Have you used MSVC? What do you think of it? 10. There are 3 lights (in one room) and 3 swtiches (in another room), one for each, if you only enter into the light room once. How can you find out which switch corresponds to which light? 11. What is your weakness? 12. Why do you think you are suited for this job? 13. If there is a day, when you find yourself not fitting in our team, what will you do? 14. What makes you think you are qualified for this job? 15. Do you like music? Which composers are your favourite?

16. What kind of PC games you like most? Why? 17. Are you familiar with collboration tools? Which communication method do you prefer for talk, email and chat? 18. When will you be available to start work? 19. What security tools have you used? 20. Tell me about yourself. 21. Tell me about your experience with this type of work 22. What do you like and dislike about our company? 23. Why do you want to work for us? 24. What should we hire you? What can you do for us? What can you do that others can not? 25. What is the jobs most attractive and least attractive factor? 26. What do you look for in a job? 27. Please give me your definition of software test engineer. 28. How long whould it take you to make a meaningful contribution to our firm? 29. How long would you stay with us? 30. Are you thinking of going back to school or college? 31. What kind of programs/machines or equipment have you worked with? 32. You may be overqualified for this position we have to offer. 33. Give me an example of a project you handled from start to finish. 34. What was your last employers opinion of you? 35. Can you work under pressure, deadline etc? 36. Do you have any questions? 37. What is it you liked and disliked about your last job? A frequent reader of this site sent this in. No answers, but a nice set of questions. Consider getting Kernighan and Ritchie title if you find many things puzzling here. 1. What does static variable mean? 2. What is a pointer? 3. What is a structure? 4. What are the differences between structures and arrays? 5. In header files whether functions are declared or defined? 6. What are the differences between malloc() and calloc()? 7. What are macros? What are the advantages and disadvantages? 8. Difference between pass by reference and pass by value? 9. What is static identifier? 10. Where are the auto variables stored? 11. Where does global, static, local, register variables, free memory and C Program instructions get stored? 12. Difference between arrays and linked list? 13. What are enumerations? 14. Describe about storage allocation and scope of global, extern, static, local and register variables? 15. What are register variables? What are the advantage of using register variables? 16. What is the use of typedef?

17. Can we specify variable field width in a scanf() format string? If possible how? 18. Out of fgets() and gets() which function is safe to use and why? 19. Difference between strdup and strcpy? 20. What is recursion? 21. Differentiate between a for loop and a while loop? What are it uses? 22. What are the different storage classes in C? 23. Write down the equivalent pointer expression for referring the same element a[i][j][k][l]? 24. What is difference between Structure and Unions? 25. What the advantages of using Unions? 26. What are the advantages of using pointers in a program? 27. What is the difference between Strings and Arrays? 28. In a header file whether functions are declared or defined? 29. What is a far pointer? where we use it? 30. How will you declare an array of three function pointers where each function receives two ints and returns a float? 31. What is a NULL Pointer? Whether it is same as an uninitialized pointer? 32. What is a NULL Macro? What is the difference between a NULL Pointer and a NULL Macro? 33. What does the error Null Pointer Assignment mean and what causes this error? 34. What is near, far and huge pointers? How many bytes are occupied by them? 35. How would you obtain segment and offset addresses from a far address of a memory location? 36. Are the expressions arr and *arr same for an array of integers? 37. Does mentioning the array name gives the base address in all the contexts? 38. Explain one method to process an entire string as one unit? 39. What is the similarity between a Structure, Union and enumeration? 40. Can a Structure contain a Pointer to itself? 41. How can we check whether the contents of two structure variables are same or not? 42. How are Structure passing and returning implemented by the complier? 43. How can we read/write Structures from/to data files? 44. What is the difference between an enumeration and a set of pre-processor # defines? 45. What do the c and v in argc and argv stand for? 46. Are the variables argc and argv are local to main? 47. What is the maximum combined length of command line arguments including the space between adjacent arguments? 48. If we want that any wildcard characters in the command line arguments should be appropriately expanded, are we required to make any special provision? If yes, which? 49. Does there exist any way to make the command line arguments available to other functions without passing them as arguments to the function? 50. What are bit fields? What is the use of bit fields in a Structure declaration? 51. To which numbering system can the binary number 1101100100111100 be easily converted to?

52. Which bit wise operator is suitable for checking whether a particular bit is on or off? 53. Which bit wise operator is suitable for turning off a particular bit in a number? 54. Which bit wise operator is suitable for putting on a particular bit in a number? 55. Which bit wise operator is suitable for checking whether a particular bit is on or off? 56. Which one is equivalent to multiplying by 2? o Left shifting a number by 1 o Left shifting an unsigned int or char by 1? 57. Write a program to compare two strings without using the strcmp() function. 58. Write a program to concatenate two strings. 59. Write a program to interchange 2 variables without using the third one. 60. Write programs for String Reversal. The same for Palindrome check. 61. Write a program to find the Factorial of a number. 62. Write a program to generate the Fibonacci Series? 63. Write a program which employs Recursion? 64. Write a program which uses command line arguments. 65. Write a program which uses functions like strcmp(), strcpy(), etc. 66. What are the advantages of using typedef in a program? 67. How would you dynamically allocate a one-dimensional and two-dimensional array of integers? 68. How can you increase the size of a dynamically allocated array? 69. How can you increase the size of a statically allocated array? 70. When reallocating memory if any other pointers point into the same piece of memory do you have to readjust these other pointers or do they get readjusted automatically? 71. Which function should be used to free the memory allocated by calloc()? 72. How much maximum can you allocate in a single call to malloc()? 73. Can you dynamically allocate arrays in expanded memory? 74. What is object file? How can you access object file? 75. Which header file should you include if you are to develop a function which can accept variable number of arguments? 76. Can you write a function similar to printf()? 77. How can a called function determine the number of arguments that have been passed to it? 78. Can there be at least some solution to determine the number of arguments passed to a variable argument list function? 79. How do you declare the following: o An array of three pointers to chars o An array of three char pointers o A pointer to array of three chars o A pointer to function which receives an int pointer and returns a float pointer o A pointer to a function which receives nothing and returns nothing 80. What do the functions atoi(), itoa() and gcvt() do?

81. Does there exist any other function which can be used to convert an integer or a float to a string? 82. How would you use qsort() function to sort an array of structures? 83. How would you use qsort() function to sort the name stored in an array of pointers to string? 84. How would you use bsearch() function to search a name stored in array of pointers to string? 85. How would you use the functions sin(), pow(), sqrt()? 86. How would you use the functions memcpy(), memset(), memmove()? 87. How would you use the functions fseek(), freed(), fwrite() and ftell()? 88. How would you obtain the current time and difference between two times? 89. How would you use the functions randomize() and random()? 90. How would you implement a substr() function that extracts a sub string from a given string? 91. What is the difference between the functions rand(), random(), srand() and randomize()? 92. What is the difference between the functions memmove() and memcpy()? 93. How do you print a string on the printer? 94. Can you use the function fprintf() to display the output on the screen? This set of questions came from a prominent gaming company. As you can see, the answers are not given (the interviews are typically conducted by senior developers), but theres a set of notes with common mistakes to avoid. 1. Explain which of the following declarations will compile and what will be constant - a pointer or the value pointed at: o const char * o char const * o char * const Note: Ask the candidate whether the first declaration is pointing to a string or a single character. Both explanations are correct, but if he says that its a single character pointer, ask why a whole string is initialized as char* in C++. If he says this is a string declaration, ask him to declare a pointer to a single character. Competent candidates should not have problems pointing out why const char* can be both a character and a string declaration, incompetent ones will come up with invalid reasons. 2. Youre given a simple code for the class BankCustomer. Write the following functions: o Copy constructor o = operator overload o == operator overload o + operator overload (customers balances should be added up, as an example of joint account between husband and wife)

Note:Anyone confusing assignment and equality operators should be dismissed from the interview. The applicant might make a mistake of passing by value, not by reference. The candidate might also want to return a pointer, not a new object, from the addition operator. Slightly hint that youd like the value to be changed outside the function, too, in the first case. Ask him whether the statement customer3 = customer1 + customer2 would work in the second case. 3. What problems might the following macro bring to the application? #define sq(x) x*x 4. Consider the following struct declarations:
5. 6. 7. 8. 9. struct A { A(){ cout << "A"; } }; struct B { B(){ cout << "B"; } }; struct C { C(){ cout << "C"; } }; struct D { D(){ cout << "D"; } }; struct E : D { E(){ cout << "E"; } };

10. struct F : A, B 11. { 12. 13. 14. 15. }; C c; D d; E e; F() : B(), A(),d(),c(),e() { cout << "F"; }

What constructors will be called when an instance of F is initialized? Produce the program output when this happens. 16. Anything wrong with this code?
17. T *p = new T[10]; 18. delete p;

Note: Incorrect replies: No, everything is correct, Only the first element of the array will be deleted, The entire array will be deleted, but only the first element destructor will be called. 19. Anything wrong with this code?
20. T *p = 0;

21. delete p;

Note: Typical wrong answer: Yes, the program will crash in an attempt to delete a null pointer. The candidate does not understand pointers. A very smart candidate will ask whether delete is overloaded for the class T. 22. Explain virtual inheritance. Draw the diagram explaining the initialization of the base class when virtual inheritance is used. Note: Typical mistake for applicant is to draw an inheritance diagram, where a single base class is inherited with virtual methods. Explain to the candidate that this is not virtual inheritance. Ask them for the classic definition of virtual inheritance. Such question might be too complex for a beginning or even intermediate developer, but any applicant with advanced C++ experience should be somewhat familiar with the concept, even though hell probably say hed avoid using it in a real project. Moreover, even the experienced developers, who know about virtual inheritance, cannot coherently explain the initialization process. If you find a candidate that knows both the concept and the initialization process well, hes hired. 23. Whats potentially wrong with the following code?
24. long value; 25. //some stuff 26. value &= 0xFFFF;

Note: Hint to the candidate about the base platform theyre developing for. If the person still doesnt find anything wrong with the code, they are not experienced with C++. 27. What does the following code do and why would anyone write something like that?
28. void send (int *to, int * from, int count) 29. { 30. 31. 32. 33. 34. 35. 36. 37. int n = (count + 7) / 8; switch ( count { case 0: do { *to++ = *from++; case 7: *to++ = *from++; case 6: *to++ = *from++; case 5: *to++ = *from++; case 4: *to++ = *from++; % 8)

38. 39. 40. 41. 42. 43. } }

case 3: *to++ = *from++; case 2: *to++ = *from++; case 1: *to++ = *from++; } while ( --n > 0 );

44. In the H file you see the following declaration:


45. class Foo { 46. void Bar( void ) const ; 47. };

Tell me all you know about the Bar() function. Some good C++ questions to ask a job applicant. 1. How do you decide which integer type to use? 2. What should the 64-bit integer type on new, 64-bit machines be? Whats the best way to declare and define global variables? What does extern mean in a function declaration? Whats the auto keyword good for? I cant seem to define a linked list node which contains a pointer to itself. How do I declare an array of N pointers to functions returning pointers to functions returning pointers to characters? 8. How can I declare a function that returns a pointer to a function of its own type? 9. My compiler is complaining about an invalid redeclaration of a function, but I only define it once and call it once. Whats happening? 10. What can I safely assume about the initial values of variables which are not explicitly initialized? 11. Why cant I initialize a local array with a string? 12. What is the difference between char a[] = string; and char *p = string; ? 13. How do I initialize a pointer to a function? 3. 4. 5. 6. 7. Q: Write a short code using C++ to print out all odd number from 1 to 100 using a for loop(Asked by Intacct.com people)
for( unsigned int i = 1; i < = 100; i++ ) if( i & 0x00000001 ) cout << i<<",";

ISO layers and what layer is the IP operated from?( Asked by Cisco system people)

cation, Presentation, Session, Transport, Network, Data link and Physical. The IP is operated in the Network layer. 3.Q: Write a program that ask for user input from 5 to 9 then calculate the average( Asked by Cisco system people) A.int main() { int MAX=4; int total =0; int average=0; int numb; cout<<"Please enter your input from 5 to 9"; cin>>numb; if((numb <5)&&(numb>9)) cout<<"please re type your input"; else for(i=0;i<=MAX; i++) { total = total + numb; average= total /MAX; } cout<<"The average number is"<<average<<endl; return 0; } 4.Q: Can you be bale to identify between Straight- through and Cross- over cable wiring? and in what case do you use Straight- through and Cross-over? (Asked by Cisco system people) A. Straight-through is type of wiring that is one to to one connection Cross- over is type of wiring which those wires are got switched We use Straight-through cable when we connect between NIC Adapter and Hub. Using Cross-over cable when connect between two NIC Adapters or sometime between two hubs. 5.Q: If you hear the CPU fan is running and the monitor power is still on, but you did not see any thing show up in the monitor screen. What would you do to find out what is going wrong? (Asked by WNI people) A. I would use the ping command to check whether the machine is still alive(connect to the network) or it is dead.

1. In C++, what is the difference between method overloading and method overwriting? Overloading a method (or function) in C++ is the ability for functions of the same name to be defined as long as these methods have different signatures (different set of parameters). Method overwriting is the ability of the inherited class rewriting the virtual method of the base class. 2. What methods can be overwritten in Java? In C++ terminology, all public methods in Java are virtual. Therefore, all Java methods can be overwritten in subclasses except those that are declared final, static, and private. 3. In C, What is the difference between a static variable and global variable? A static variable declared outside of any function is accessible only to all the functions defined in the same file (as the static variable). However, a global variable can be accessed by any function (including the ones from different files). 4. In C, why is the void pointer useful? The void pointer is useful becuase it is a generic pointer that any pointer can be cast into and back again without loss of information. 5. What are the defining traits of an object-oriented language? The defining traits of an object-oriented langauge are:

encapsulation inheritance polymorphism

What is pure virtual function? A class is made abstract by declaring one or more of its virtual functions to be pure. A pure virtual function is one with an initializer of = 0 in its declaration Q. Write a Struct Time where integer m, h, s are its members struct Time { int m; int h; int s; }; ow do you traverse a Btree in Backward in-order? Process the node in the right subtree

Process the root Process the node in the left subtree Q. What is the two main roles of Operating System? As a resource manager As a virtual machine Q. In the derived class, which data member of the base class are visible? In the public and protected sections (From Microsoft) Assume I have a linked list contains all of the alphabets from A to Z. I want to find the letter Q in the list, how does you perform the search to find the Q?Answer: In a linked list, we only know about the header and other elements are invisible unless we go through the node one by one. Since we have go through every single node to find Q, the search time for a linked list is linear which is O (N). From IBM) How do you think about your school? : I enjoy studying in our school because we have many professors and instructors are from local companies. Their professions lead us more close to local industries. (From IBM) What classes you have enjoyed the most during your school years? Answer: I like the class I am taking this semester, which involves a group project that needs great amount of team efforts. I really enjoy work with a group of people because we can learn new materials mutually. > m IBM) According to your group project you just mentioned, whats the responsibility for each member in your group? Answer: We have five people in our group. So far we have two web servers set up; one will be the back up system and the other will be the main system. Our leader coordinates the schedule. Two members are working on the database and do the coding for the connection between database and Java serverlets. One member is working on the user browser interface. All members will assign some classes to work on and perform the final test at the end. We have group meeting every Saturday to ensure our schedule is on track. Can you work under pressure? Answer: I worked for Sega of America in the hardware development group three years ago. They were working on the next generation of gaming machine (which is the Dreamcast we seen today in the market). My duty was to ensure the quality of prototypes that just built from manufacture were ready for engineers to test. I managed to balance the schedules and pressures from school and work 1. How do you write a function that can reverse a linked-list? (Cisco System) void reverselist(void)

{ if(head==0) return; if(head->next==0) return; if(head->next==tail) { head->next = 0; tail->next = head; } else { node* pre = head; node* cur = head->next; node* curnext = cur->next; head->next = 0; cur->next = head; for(; curnext!=0; ) { cur->next = pre; pre = cur; cur = curnext; curnext = curnext->next;

} curnext->next = cur; } } 2. What is polymorphism? Polymorphism is the idea that a base class can be inherited by several classes. A base class pointer can point to its child class and a base class array can store different child class objects. 3. How do you find out if a linked-list has an end? (i.e. the list is not a cycle) You can find out by using 2 pointers. One of them goes 2 nodes each time. The second one goes at 1 nodes each time. If there is a cycle, the one that goes 2 nodes each time will eventually meet the one that goes slower. If that is the case, then you will know the linked-list is a cycle. 4. How can you tell what shell you are running on UNIX system? You can do the Echo $RANDOM. It will return a undefined variable if you are from the C-Shell, just a return prompt if you are from the Bourne shell, and a 5 digit random numbers if you are from the Korn shell. You could also do a ps -l and look for the shell with the highest PID. 5. What is Boyce Codd Normal form? A relation schema R is in BCNF with respect to a set F of functional dependencies if for all functional dependencies in F+ of the form a->b, where a and b is a subset of R, at least one of the following holds:

a->b is a trivial functional dependency (b is a subset of a) a is a superkey for schema R

Q: What is the difference between Stack and Queue? A: Stack is a Last In First Out (LIFO) data structure. Queue is a First In First Out (FIFO) data structure Q: Write a fucntion that will reverse a string. (Microsoft) A: char *strrev(char *s)

{ int i = 0, len = strlen(s); char *str; if ((str = (char *)malloc(len+1)) == NULL) /*cannot allocate memory */ err_num = 2; return (str); } while(len) str[i++]=s[len]; str[i] = NULL; return (str); } Q: What is the software Life-Cycle? A: The software Life-Cycle are 1) Analysis and specification of the task 2) Design of the algorithms and data structures 3) Implementation (coding) 4) Testing 5) Maintenance and evolution of the system 6) Obsolescence Q: What is the difference between a Java application and a Java applet? A: The difference between a Java application and a Java applet is that a Java application is a program that can be executed using the Java

interpeter, and a JAVA applet can be transfered to different networks and executed by using a web browser (transferable to the WWW). Q: Name 7 layers of the OSI Reference Model? (from Cisco) A: -Application layer -Presentation layer -Session layer -Transport layer -Network layer -Data Link layer -Physical layer Q1 What are the advantages and disadvantages of B-star trees over Binary trees? (Asked by Motorola people) A1 B-star trees have better data structure and are faster in search than Binary trees, but its harder to write codes for B-start trees. Q2 Write the psuedo code for the Depth first Search.(Asked by Microsoft) A2 dfs(G, v) //OUTLINE Mark v as "discovered" For each vertex w such that edge vw is in G: If w is undiscovered: dfs(G, w); that is, explore vw, visit w, explore from there as much as possible, and backtrack from w to v. Otherwise: "Check" vw without visiting w. Mark v as "finished". Q3 Describe one simple rehashing policy.(Asked by Motorola people) A3 The simplest rehashing policy is linear probing. Suppose a key K hashes to location i. Suppose other key occupies H[i]. The following function is used to generate alternative locations:

rehash(j) = (j + 1) mod h where j is the location most recently probed. Initially j = i, the hash code for K. Notice that this version of rehash does not depend on K. Q4 Describe Stacks and name a couple of places where stacks are useful. (Asked by Microsoft) A4 A Stack is a linear structure in which insertions and deletions are always made at one end, called the top. This updating policy is called last in, first out (LIFO). It is useful when we need to check some syntex errors, such as missing parentheses. Q5 Suppose a 3-bit sequence number is used in the selective-reject ARQ, what is the maximum number of frames that could be transmitted at a time? (Asked by Cisco) A5 If a 3-bit sequence number is used, then it could distinguish 8 different frames. Since the number of frames that could be transmitted at a time is no greater half the numner of frames that could be distinguished by the sequence number, so at most 4 frames can be transmitted at a time. 1.Question: Suppose that data is an array of 1000 integers. Write a single function call that will sort the 100 elements data [222] through data [321]. Answer: quicksort ((data + 222), 100); 2.Question: Which recursive sorting technique always makes recursive calls to sort subarrays that are about half size of the original array? Answer: Mergesort always makes recursive calls to sort subarrays that are about half size of the original array, resulting in O(n log n) time. 3.Question: What is the difference between an external iterator and an internal iterator? Describe an advantage of an external iterator. Answer: .An internal iterator is implemented with member functions of the class that has items to step through. .An external iterator is implemented as a separate class that can be "attach" to the object that has items to step through. .An external iterator has the advantage that many difference iterators can be active simultaneously on the same object. 4.Question: Why are arrays usually processed with for loop? Answer: The real power of arrays comes from their facility of using an index variable to traverse the array, accessing each element with the same expression a[i]. All the is needed to make this work is a iterated statement in which the variable i serves as a counter, incrementing from 0 to a.length -1. That is exactly what a loop does. 5.Question: What is an HTML tag? Answer: An HTML tag is a syntactical construct in the HTML language that abbreviates specific instructions to be executed when the HTML script is loaded into a Web browser.

It is like a method in Java, a function in C++, a procedure in Pascal, or a subroutine in FORTRAN 1. Design and implement a String class that satisfies the following:

Supports embedded nulls Provide the following methods (at least) o Constructor o Destructor o Copy constructor o Assignment operator o Addition operator (concatenation) o Return character at location o Return substring at location o Find substring Provide versions of methods for String and for char* arguments

2. Given the following classes class Fruit { // } class Apple : public Fruit { // } class Peach : public Fruit { // } // Container of fruit class BasketOfFruit { BasketOfFruit() ; void insert( Fruit & f ) ; // } // Container of apples class BasketOfApples /* ??? */ { // } Should BasketOfApples derive from BasketOfFruit? Why or why not? What is the general principle that determines the answer?

3. Describe briefly what the following function does. What standard function is it most like ? int f( char *p ) { int n = 0 ; while ( *p != 0 ) n = 10*n + *p++ - 0 ; return n ; } 4. Describe briefly what function a does in the following code fragment. struct s { struct s *next ; } a( struct s *p, struct s *x ) { while ( p->next != 0 ) p = p->next ; p->next = x ; x->next = 0 ; } 5. What default methods are declared implicitly by the C++ compiler for the class below: class Empty { }; 6. Given a system with a hard realtime priority, multithreaded architecture, with priorities from 1 (least) to 5 (most), explain the major flaw in the design below: The following objects are shared between the threads: Disk : This class is a singleton. The read() and write() methods both block on a simple atomic lock()/unlock() shared between the two. (ie, only one thread can access the disk, thru either read or write, at any given time). It also has a waitForData() method, which blocks (without claiming the lock) until either a timeout elapses, or data is ready. It returns true upon returning due to new data, false upon returning due to the timeout. Network : This class is a singleton. The read() and write() methods both block on a simple atomic lock()/unlock() shared between the two. (ie, only one thread can access the disk, thru either read or write, at any given time). Sensor: The Sensor class accesses a number of physical sensors. The first method, waitForData(), blocks until data has been collected from the sensors. The second method, processData(), does a series of long and cpu-intensive calculations on the data. These calculations often take several minutes. It then returns the processed data.

Each of the following threads is running concurrently. Assume that the psuedocode in each thread is looped infinitely (ie, encased in a while(true) { }. It is extremely important that information buffered to the disk be sent to the network as quickly as possible, this is why Thread 1 runs at priority 5. The system conditions checked in thread 3 are not particularly important events (not as important as the calculations done in thread 2). If the events arent transmitted over the network for several minutes, its not a problem at all. They do, however, contain a large amount of system information. Thread 4 watches for serious system alarms, indicating serious problems. These are a serious concern and if not quickly buffered to the disk and sent to the network, can cause serious revenue loss. Thread 1: (priority: 5) while(!Disk.waitForData()) { yield(); } /* Wait until someone has written data to the disk */ Network.write(Disk.read()); /* Write the data buffered on the disk to the network */ Thread 2: (priority: 2) while(!Sensor.waitForData()) { yield(); } /* Wait until the sensors have picked up data */ Disk.write(Sensor.processData()); /* process the data and write it to the disk. */ Thread 3: (priority: 1) if (checkSystemCondition1()) /* true.. */ Disk.write(SystemCond1Data); /* condition and buffer it to disk if (checkSystemCondition2()) /* Disk.write(SystemCond2Data); if (checkSystemCondition3()) /* Disk.write(SystemCond3Data); yield(); If system condition 1 is Grab the data on the system */ see above*/ see above */

Thread 4: (priority: 4) if (checkAlarms()) /* If any serious alarms exist */ Disk.write(AlarmData); /* Buffer that data to disk for immediate network transmit */ yield(); Q: How do you link a C++ program to C functions?

A: By using the extern "C" linkage specification around the C function declarations. Q: Explain the scope resolution operator. A: It permits a program to reference an identifier in the global scope that has been hidden by another identifier with the same name in the local scope. Q: What are the differences between a C++ struct and C++ class? A: The default member and base-class access specifiers are different. Q: How many ways are there to initialize an int with a constant? A: Two. There are two formats for initializers in C++ as shown in the example that follows. The first format uses the traditional C notation. The second format uses constructor notation. int foo = 123; int bar (123); Q: How does throwing and catching exceptions differ from using setjmp and longjmp? A: The throw operation calls the destructors for automatic objects instantiated since entry to the try block. Q: What is your reaction to this line of code? delete this; A: Its not a good practice. Q: What is a default constructor? A: A constructor that has no arguments. Q: What is a conversion constructor? A: A constructor that accepts one argument of a different type. Q: What is the difference between a copy constructor and an overloaded assignment operator?

A: A copy constructor constructs a new object by using the content of the argument object. An overloaded assignment operator assigns the contents of an existing object to another existing object of the same class. Q: When should you use multiple inheritance? A: There are three acceptable answers: "Never," "Rarely," and "When the problem domain cannot be accurately modeled any other way." Q: What is a virtual destructor? A: The simple answer is that a virtual destructor is one that is declared with the virtual attribute. Q: Explain the ISA and HASA class relationships. How would you implement each in a class design? A: A specialized class "is" a specialization of another class and, therefore, has the ISA relationship with the other class. An Employee ISA Person. This relationship is best implemented with inheritance. Employee is derived from Person. A class may have an instance of another class. For example, an employee "has" a salary, therefore the Employee class has the HASA relationship with the Salary class. This relationship is best implemented by embedding an object of the Salary class in the Employee class. Q: When is a template a better solution than a base class? A: When you are designing a generic class to contain or otherwise manage objects of other types, when the format and behavior of those other types are unimportant to their containment or management, and particularly when those other types are unknown (thus, the genericity) to the designer of the container or manager class. Q: What is a mutable member? A: One that can be modified by the class even when the object of the class or the member function doing the modification is const. Q: What is an explicit constructor? A: A conversion constructor declared with the explicit keyword. The compiler does not use an explicit constructor to implement an implied conversion of types. Its purpose is reserved explicitly for construction. Q: What is the Standard Template Library? A: A library of container templates approved by the ANSI committee for inclusion in the standard C++ specification.

A programmer who then launches into a discussion of the generic programming model, iterators, allocators, algorithms, and such, has a higher than average understanding of the new technology that STL brings to C++ programming. Q: Describe run-time type identification. A: The ability to determine at run time the type of an object by using the typeid operator or the dynamic_cast operator. Q: What problem does the namespace feature solve? A: Multiple providers of libraries might use common global identifiers causing a name collision when an application tries to link with two or more such libraries. The namespace feature surrounds a librarys external declarations with a unique namespace that eliminates the potential for those collisions. This solution assumes that two library vendors dont use the same namespace identifier, of course. Q: Are there any new intrinsic (built-in) data types? A: Yes. The ANSI committee added the bool intrinsic type and its true and false value keywords What is a Make file?(Fujitsu) Ans: Make file is a utility in Unix to help compile large programs. It helps by only compiling the portion of the program that has been changed. 2. What is deadlock?(Novell) Deadlock is a situation when two or more processes prevent each other from running.Example: if T1 is holding x and waiting for y to be free and T2 holding y and waiting for x to be free deadlock happens. emaphore?(Novell) Semaphore is a special variable, it has two methods: up and down. Semaphore performs atomic operations, which means ones a semaphore is called it can not be inturrupted. 4. Is C an Object Oriented language?(Microsoft) C is not an Object Oriented language, but limited Object Oriented programming can be done in C. 5. What is difference between C++ and Java? C++ has pointers Java does not. Java is platform independent C++ is not.

Java has garbage collection C++ does not. Q1: Could you tell something about the Unix System Kernel? (from ITCO ) A1: The kernel is the heart of the UNIX openrating system, its reponsible for controlling the computers resouces and scheduling user jobs so that each one gets its fair share of resources. Q2: What are each of the standard files and what are they normally associated with? (from ITCO ) A2: They are the standard input file, the standard output file and the standard error file. The first is usually associated with the keyboard, the second and third are usually associated with the terminal screen. Q3: Detemine the code below, tell me exectly how many times is the operation sum++ performed ? (from ITCO ) for ( i = 0; i < 100; i++ ) for ( j = 100; j > 100 - i; j) sum++; A3: (99 * 100)/2 = 4950 The sum++ is performed 4950 times. Q4: Give 4 examples which belongs application layer in TCP/IP architecture? (from CISCO ) A4: FTP, TELNET, HTTP and TFTP Q5: Whats the meaning of ARP in TCP/IP? (from CISCO ) A5: The "ARP" stands for Address Resolution Protocol. The ARP standard defines two basic message types: a request and a response. a request message contains an IP address and requests the corresponding hardware address; a replay contains both the IP address, sent in the request, and the hardware address

Vous aimerez peut-être aussi