ОО1/Пробни тестови 2020
- За питања са више одговора, тачни одговори су подебљани и уоквирени
- За питања за које се одговори уносе, тачни одговори су подвучени и сакривени, тако да се прикажу када изаберете тај текст (пример: овако)
- Притисните лево дугме испод за сакривање и откривање свих одговора, или десно дугме за укључивање и искључивање интерактивног режима:
Prvi test
Na svakom pitanju je bilo ili moguće izabrati jedno ili više rešenja ili uneti odgovor u polje.
1. zadatak
Prilikom reupotrebe objektno orijentisanog koda izvođenjem, u načelu se stari kod (postojeća klasa - osnova za izvođenje):
- ne mora menjati ni ponovo prevoditi i testirati.
- ne mora menjati, ali se mora ponovo prevoditi i testirati.
- ne mora menjati, mora ponovo prevoditi, ali se ne mora ponovo testirati.
- mora menjati i ponovo prevoditi i testirati.
- uopšte ne može iskoristiti.
2. zadatak
Koja naredba omogućava korišćenje imena X iz prostora imena Y prostim imenovanjem X, ukoliko ne postoji konflikt imena?
decltype Y;
using namespace Y;
using Y::X;
namespace Y.X;
using Y;
3. zadatak
Šta ispisuje sledeći program na jeziku C++?
#include <iostream>
struct S1{
int a;
int b;
};
struct S2{
S1 a;
int b[3][2];
};
int main() {
S2 s={1,2,{{3},{},{4,5}}};
std::cout<<s.b[2][0];
}
Odgovor: 4
Objašnjenje: 1 i 2 odgovaraju poljima a i b strukture S1. {{3},{},{4,5}}
predstavlja inicijalizaciju niza, prošireno predstavljenu kao {{3, 0}, {0, 0}, {4, 5}}
. Na kraju se iz trećeg niza iz polja b ({4, 5}
) ispisuje prvi element.
4. zadatak
Šta je dozvoljeno da stoji na mestu naredbe ###
?
#include <iostream>
struct A{
A(){}; //podrazumevani konstruktor strukture A
int x;
const int y=1;
mutable int z;
};
int main(){
A a1;
const A a2;
###
}
a2.z=1;
a1.y=1;
a2.y=1;
a1.x=1;
a1.z=1;
a2.x=1;
5. zadatak
Koje funkcije su ispravne, jer vraćaju referencu na "živ" objekat?
int& f(int &i){int r=i; return r; }
int& f(int i){return i; }
int& f(int &i){return *new int(i); }
int& f(int &i){int &r=*new int(i); return r; }
int& f(int &i){return i; }
int& f(int &i){int r=*new int(i); return r; }
Objašnjenje: Prva funkcija vraća referencu na lokalnu promenljivu u koju je kopirana vrednost. Druga funkcija isto, ali se kopiranje dešava pri prosleđivanju argumenata. Šesta funkcija alocira objekat na hipu, ali onda njegovu vrednost kopira u lokalnu promenljivu pa vraća referencu na tu promenljivu.
6. zadatak
Koji od sledećih iskaza su tačni na jeziku C++?
- Klasa može imati više privatnih sekcija.
- Iz metoda pozvanog za neki objekat se ne može pristupiti privatnom atributu drugog objekta iste klase.
- Javnoj sekciji klase mogu pristupati samo javni metodi klase, a privatnoj sekciji samo privatni metodi.
- Članovima u privatnoj sekciji klase može pristupati samo javni metod iste klase.
- Podrazumevana sekcija klase je javna.
7. zadatak
Za nepromenljiv i nepostojan (const volatile
) objekat klase mogu da se pozivaju metodi te klase sa navedenim sledećim modifikatorima (koji određuju prirodu tekućeg objekta):
inline
const
volatile
const volatile
- bez modifikatora
8. zadatak
Neka je data definicija klase Test
class Test{
Test(){}
};
Za koje od sledećih linija koda u funkciji main() će prevodilac prijaviti grešku?
Test test;
Test* test = new Test();
Test test();
Test* test;
Test test{};
Objašnjenje: Podrazumevani konstruktor se nalazi u privatnoj sekciji. Opcija pod c je deklaracija metode a opcija pod d ne pravi objekat uopšte.
9. zadatak
Šta ispisuje dati program na jeziku C++?
#include <iostream>
using namespace std;
class A {
public:
A() { cout << "A"; }
A(int a) { cout << "A" << a; }
};
class B {
A a;
public:
B() { cout << "B"; }
B(int b) { cout << "B" << b; }
};
class C {
B b;
A a;
public:
C() { cout << "C"; }
C(int c) : a(c) { cout << "C" << c; }
};
int main() {
C c(1);
return 0;
}
Odgovor: ABA1C1
Objašnjenje: Inicijalizuje se klasa C konstruktorom sa jednim argumentom. Odatle kreće inicijalizacija njenog atributa tipa B, kada se poziva podrazumevani konstruktor. B sadrži objekat klase A, pa se podrazumevanim konstruktorom inicijalizuje A i ispisuje A. Tada je gotova inicijalizacija atributa klase B i inicijalizacija B se završava ispisivanjem B. Zatim se prelazi na inicijalizaciju atributa tipa A klase C, ali konstruktorom sa jednim argumentom jer tako piše u inicijalizacionoj listi, pa se ispisuje A1. Na kraju se ispisuje C1.
10. zadatak
Koja tvrđenja su tačna za dati programski kod napisan na jeziku C++?
class A {
int i;
public:
A(int ii=2) { i = ii; }
};
- Klasa A ima konverzioni konstruktor.
- Klasa A ima jedan konstruktor.
- Objekat klase A se može stvoriti pozivanjem konstruktora koji nema nijedan parametar.
- Objekat klase A se može stvoriti pozivanjem konstruktora koji ima jedan argument.
- Klasa A nema podrazumevani konstruktor.
Drugi test
1. zadatak
- Isti zadatak se našao i na probnom kolokvijumu za IR.
Koji od sledećih operatora se moraju preklopiti kao nestatički metodi u jeziku C++?
operator()
operator[]
operator<<
operator=
operator+
2. zadatak
- Isti zadatak se našao i na probnom kolokvijumu za IR.
Povezati operatore sa odgovarajućom tipičnom primenom:
- Računanje vrednosti polinoma u tački operator()
- Pametni pokazivač operator->
- Asocijativni pristup elementu zbirke operator[]
3. zadatak
- Isti zadatak se našao i na probnom kolokvijumu za IR.
Šta ispisuje sledeći program na programskom jeziku C++? Ukoliko se program ne prevodi u polje za odgovor treba upisati vrednost 0.
#include <iostream>
class B;
class A {
public:
A(int i) {}
A(const B &b) { std::cout << "1"; }
A& operator=(const A& a) { std::cout << "2"; return *this; }
};
class B {
public:
operator A() { std::cout << "3"; return 1; }
};
int main() {
B b;
A a(1);
a = b;
}
Odgovor: 32
Objašnjenje: Operator = klase A prima argument tipa A, pa mora da se desi konverzija iz B u A. Ovde izgleda kao da je konverzija dvoznačna, jer može da se izvrši i preko konverzionong konstruktora klase A, i preko operatora konverzije klase B, ali nije. Naime, konverzioni konstruktor klase A prima argument koji ima const
kvalifikator, dok operator konverzije nema const
specifikator, pa konverzija ide preko operatora konverzije i ispisuje se 3. Nakon toga se izvrši operator dodele i ispiše 2.
4. zadatak
Koje tvrdnje su tačne?
- Operator
delete
može imati proizvoljan broj argumenata. - U preklopljenom operatoru
new
treba, kao poslednju naredbu, napisati eksplicitan poziv konstruktora klase za koju se operator preklapa. - Klasa može imati više preklopljenih
delete
operatora za pojedinačne objekte. - Operatori
new
idelete
se preklapaju kao statički metodi klase. - Klasa može imati više preklopljenih operatora
new
za nizove.
5. zadatak
Koja od sledećih tvrdnji u vezi izvođenja klasa su tačna u jeziku C++?
- Iz klase označene modifikatorom
final
nije moguće dalje izvođenje. - Dozvoljeno je sledeće izvođenje:
class A : B { }; class B : A { };
- Podrazumevan način izvođenja je zaštićen (
protected
). - Izvedena klasa ne nasleđuje konstruktore, destruktor i operatore
operator=
iz osnovne klase. - Izvođenje može biti javno (
public
), zaštićeno (protected
) ili privatno (private
).
6. zadatak
Koji iskazi su tačni? Izaberite jedan odgovor:
- Privatnim izvođenjem uspostavlja se relacija sadržanja između objekta izvedene klase i nasleđenog podobjekta osnovne klase.
- Objekat zaštićeno izvedene klase je jedna vrsta objekta osnovne klase u svakoj globalnoj funkciji.
- Objekat javno izvedene klase nasleđuje samo implementaciju osnovne klase, ne i ugovor.
- Kod privatnog izvođenja nasleđuje se ugovor osnovne klase.
- Javnim izvođenjem se samo uspostavlja relacija sadržanja između objekta izvedene klase i nasleđenog podobjekta osnovne klase.
7. zadatak
Šta ispisuje sledeći program na jeziku C++?
#include <iostream>
using namespace std;
class A {
public:
A() { cout << "A"; }
};
class C {
public:
C() { cout << "C"; }
};
class B: public A {
C c; A a;
public:
B():c(), A(), a() { cout << "B"; }
};
int main() {
B b[2];
}
- CAABCAAB
- ACBACB
- AACBAACB
- ACABACAB
Objašnjenje: Prvo se inicijalizuje podobjekat A, a zatim atributi tipa C a zatim A, i na kraju se poziva konstruktor B. Redosled u inicijalizatorskoj listi nije bitan. Pošto se prave dva objekta u nizu, ispisuje se dva puta.
8. zadatak
Šta ispisuje sledeći programski kod:
#include <iostream>
using namespace std;
class O {
public:
virtual void m() { cout << "1"; }
};
class I : public O {
public:
virtual void m() override { cout << "2"; }
};
int main() {
O * p = new I();
O o = *p;
p->m();
(*p).m();
o.m();
return 0;
}
Odgovor: 221
Objašnjenje: Poziv metode preko objekta je nepolimorfan (treći slučaj), dok je poziv preko reference ili pokazivača polimorfan (prvi i drugi slučaj). Dereferenciranje vraća referencu, u ovom slučaju ne mora da se desi kopija objekta.
9. zadatak
Šta treba da stoji umesto *** da bi dati program na jeziku C++ ispisao BA? Izaberite jedan ili više odgovora.
#include <iostream>
using namespace std;
class A {
public:
***
};
class B: public A {
public:
~B() { cout << "B"; }
};
int main() {
A *a = new B();
delete a;
}
- ~A() { cout << "A"; }
- ~A() { cout << "BA"; }
- virtual ~A() { cout << "BA"; }
- virtual ~A() { cout << "A"; }
Objašnjenje: Ukoliko je destruktor virtuelan, pozvaće se destruktor i osnovne klase. Validna alternativa jeste da nevirtuelni destruktor samo ispiše traženi tekst.
10. zadatak
Koje tvrdnje su tačne?
- Višestrukim izvođenjem se smatra izvođenje iz više klasa koje nisu u uzajamnom odnosu izvođenja (nasleđivanja).
- Višestrukim izvođenjem se smatra izvođenje u kojem je jedna klasa roditelj većeg broja klasa.
- Višestrukim izvođenjem se smatra izvođenje iz već izvedene klase.
- Višestrukim izvođenjem se smatra izvođenje iz klase iz koje su već izvedene neke druge klase.
- Višestrukim izvođenjem se nasleđuju ugovori i implementacije svih roditeljskih klasa.
IR kolokvijum
1. zadatak
Prostor na steku se dodeljuje:
- Lokalnim statičkim objektima
- Globalnim statičkim objektima
- Argumentima (parametrima) funkcija
- Dinamičkim objektima
- Lokalnim automatskim objektima
2. zadatak
Šta ispisuje sledeći program na programskom jeziku C++?
#include <iostream>
int& f(int &x) {
return ++x;
}
int main() {
int x = 1;
int z = 1;
auto y = f(z);
y++;
std::cout << x << y << z;
}
- 133
- 233
- Programski kod se ne prevodi.
- 132
- 232
Objašnjenje: auto
, za razliku od decltype
ne zadržava da li je tip bio referenca ili pokazivač, pa je tip y
samo int
i promena nad y
se ne oslikava nad z
.
3. zadatak
Koje tvrđenje je tačno?
- Mehanizam preklapanje[sic] imena funkcija je potpuno statički, koja funkcija će se pozvati određuje se u vreme prevođenja.
- Mehanizam preklapanje[sic] imena funkcija je potpuno dinamički, koja funkcija će se pozvati određuje se u vreme izvršavanja.
- Mehanizam preklapanje[sic] imena funkcija je potpuno statički, koja funkcija će se pozvati određuje se u vreme izvršavanja.
- Mehanizam preklapanje[sic] imena funkcija je potpuno dinamički, koja funkcija će se pozvati određuje se u vreme prevođenja.
4. zadatak
Koja tvrđenja su tačna na programskom jeziku C++?
- Metodi
int f() & { return 1; }
iint f() && { return 3; }
mogu postojati u istoj klasi. - Metodi
int f() & { return 1; }
iint f() const & { return 3; }
mogu postojati u istoj klasi. - Metodi
int f() & { return 1; }
ivoid f() & { }
mogu postojati u istoj klasi.
5. zadatak
Šta ispisuje sledeći program napisan na programskom jeziku C++? Ukoliko se program ne prevodi unesite X.
#include <iostream>
using namespace std;
class A
{
private:
int b = 2;
int c = 3;
public:
A() : c(b+1), b(7) { b--; a = 2; }
void pisi() { cout << a << b << c; }
private:
int a = 1;
};
int main()
{
A obj;
obj.pisi();
return 0;
}
Odgovor: 268
Objašnjenje: Pri inicijalizaciji objekta klase A polja b, c i a se prvo inicijalizuju na 7 (iz konstruktora), 8 (7+1) i 1, a zatim se u konstruktoru b smanji na 6 a a postavi na 2.
6. zadatak
Šta ispisuje dati program na jeziku C++?
#include <iostream>
using namespace std;
class A {
static int stID;
int ID = ++stID;
public:
A() {}
A(const A& a) {}
A(A&& a) {}
~A() { cout << ID; }
};
int A::stID = 0;
void f1(A& a) {}
void f2(A a) {}
int main() {
A x;
for(int i = 0; i < 3; i++){
A* y = new A;
if (i == 1) f2(*y);
if (i == 2) f1(*y);
}
return 0;
}
Odgovor: 41
Objašnjenje: Stvara se objekat x, sa ID od 1. U prvoj iteraciji petlje se samo stvara objekat y sa ID od 2. U drugoj iteraciji petlje se ponovo stvara objekat y sa ID od 3, ali se prosleđuje metodi u kojoj se kopira i dobija ID od 4. Na kraju te metode se uništava i ispisuje 4. U trećoj iteraciji petlje se ponovo stvara objekat y sa ID od 5, pa se prosleđuje metodi u kojoj se ne kopira. Na kraju programa se uništava objekat x i ispisuje 1. Dinamički alocirani objekti nisu eksplicitno oslobođeni, pa njihovi destruktori nisu pozvani i memoriju koju oni zauzimaju će osloboditi operativni sistem.
7. zadatak
Koja su tvrđenja tačna za prijateljske (friend
) funkcije i klase?
- Ako je klasa
A
prijatelj klaseB
i klasaB
prijatelj klaseC
, onda je i klasaA
prijatelj klaseC
. - Funkcija
m()
koja je prijatelj klasiA
može biti globalna funkcija. - Ako klasa
A
proglasi klasuB
za prijatelja, metodi klaseA
imaju pristup do privatnih polja klaseB
- Prijateljstvo između klasa je simetrična relacija.
- Funkcija
m()
koja je prijatelj klasiA
može biti metod klaseB
.
8. zadatak
Koji od sledećih operatora se moraju preklopiti kao nestatički metodi u jeziku C++?
operator[]
operator=
operator()
operator+
operator<<
9. zadatak
Povezati operatore sa odgovarajućom tipičnom primenom:
- Računanje vrednosti polinoma u tački operator()
- Pametni pokazivač operator->
- Asocijativni pristup elementu zbirke operator[]
10. zadatak
Šta ispisuje sledeći program na programskom jeziku C++? Ukoliko se program ne prevodi u polje za odgovor treba upisati vrednost 0.
#include <iostream>
class B;
class A {
public:
A(int i) {}
A(const B &b) { std::cout << "1"; }
A& operator=(const A& a) { std::cout << "2"; return *this; }
};
class B {
public:
operator A() { std::cout << "3"; return 1; }
};
int main() {
B b;
A a(1);
a = b;
}
Odgovor: 32
Objašnjenje: Operator = klase A prima argument tipa A, pa mora da se desi konverzija iz B u A. Ovde izgleda kao da je konverzija dvoznačna, jer može da se izvrši i preko konverzionong konstruktora klase A, i preko operatora konverzije klase B, ali nije. Naime, konverzioni konstruktor klase A prima argument koji ima const
kvalifikator, dok operator konverzije nema const
specifikator, pa konverzija ide preko operatora konverzije i ispisuje se 3. Nakon toga se izvrši operator dodele i ispiše 2.