ArrayList public constructor - “Constructs an empty list with an initial capacity of ten” - where?...
up vote
7
down vote
favorite
This question already has an answer here:
In Java 8, why is the default capacity of ArrayList now zero?
6 answers
Be aware, it is not a duplicate of Why start an ArrayList with an initial capacity?
Looking into the source code of the java.util.ArrayList
class, starting from at least java 1.8 I see the following code:
/**
* Constructs an empty list with an initial capacity of ten.
*/
public ArrayList() {
this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
}
Where
private static final Object DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
Though the javadoc officially states:
Constructs an empty list with an initial capacity of ten.
I outline: ...an initial capacity of ten. Where is this ten?
Am I completely mad and missing something, or there is simply a javadoc bug here?
UPD: How it looked like prior java 1.8:
public ArrayList(int initialCapacity) {
super();
if (initialCapacity < 0)
throw new IllegalArgumentException("Illegal Capacity: "+
initialCapacity);
this.elementData = new Object[initialCapacity];
}
/**
* Constructs an empty list with an initial capacity of ten.
*/
public ArrayList() {
this(10);
}
java arraylist javadoc
marked as duplicate by Aomine
StackExchange.ready(function() {
if (StackExchange.options.isMobile) return;
$('.dupe-hammer-message-hover:not(.hover-bound)').each(function() {
var $hover = $(this).addClass('hover-bound'),
$msg = $hover.siblings('.dupe-hammer-message');
$hover.hover(
function() {
$hover.showInfoMessage('', {
messageElement: $msg.clone().show(),
transient: false,
position: { my: 'bottom left', at: 'top center', offsetTop: -7 },
dismissable: false,
relativeToBody: true
});
},
function() {
StackExchange.helpers.removeMessages();
}
);
});
});
Dec 13 at 13:58
This question has been asked before and already has an answer. If those answers do not fully address your question, please ask a new question.
add a comment |
up vote
7
down vote
favorite
This question already has an answer here:
In Java 8, why is the default capacity of ArrayList now zero?
6 answers
Be aware, it is not a duplicate of Why start an ArrayList with an initial capacity?
Looking into the source code of the java.util.ArrayList
class, starting from at least java 1.8 I see the following code:
/**
* Constructs an empty list with an initial capacity of ten.
*/
public ArrayList() {
this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
}
Where
private static final Object DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
Though the javadoc officially states:
Constructs an empty list with an initial capacity of ten.
I outline: ...an initial capacity of ten. Where is this ten?
Am I completely mad and missing something, or there is simply a javadoc bug here?
UPD: How it looked like prior java 1.8:
public ArrayList(int initialCapacity) {
super();
if (initialCapacity < 0)
throw new IllegalArgumentException("Illegal Capacity: "+
initialCapacity);
this.elementData = new Object[initialCapacity];
}
/**
* Constructs an empty list with an initial capacity of ten.
*/
public ArrayList() {
this(10);
}
java arraylist javadoc
marked as duplicate by Aomine
StackExchange.ready(function() {
if (StackExchange.options.isMobile) return;
$('.dupe-hammer-message-hover:not(.hover-bound)').each(function() {
var $hover = $(this).addClass('hover-bound'),
$msg = $hover.siblings('.dupe-hammer-message');
$hover.hover(
function() {
$hover.showInfoMessage('', {
messageElement: $msg.clone().show(),
transient: false,
position: { my: 'bottom left', at: 'top center', offsetTop: -7 },
dismissable: false,
relativeToBody: true
});
},
function() {
StackExchange.helpers.removeMessages();
}
);
});
});
Dec 13 at 13:58
This question has been asked before and already has an answer. If those answers do not fully address your question, please ask a new question.
add a comment |
up vote
7
down vote
favorite
up vote
7
down vote
favorite
This question already has an answer here:
In Java 8, why is the default capacity of ArrayList now zero?
6 answers
Be aware, it is not a duplicate of Why start an ArrayList with an initial capacity?
Looking into the source code of the java.util.ArrayList
class, starting from at least java 1.8 I see the following code:
/**
* Constructs an empty list with an initial capacity of ten.
*/
public ArrayList() {
this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
}
Where
private static final Object DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
Though the javadoc officially states:
Constructs an empty list with an initial capacity of ten.
I outline: ...an initial capacity of ten. Where is this ten?
Am I completely mad and missing something, or there is simply a javadoc bug here?
UPD: How it looked like prior java 1.8:
public ArrayList(int initialCapacity) {
super();
if (initialCapacity < 0)
throw new IllegalArgumentException("Illegal Capacity: "+
initialCapacity);
this.elementData = new Object[initialCapacity];
}
/**
* Constructs an empty list with an initial capacity of ten.
*/
public ArrayList() {
this(10);
}
java arraylist javadoc
This question already has an answer here:
In Java 8, why is the default capacity of ArrayList now zero?
6 answers
Be aware, it is not a duplicate of Why start an ArrayList with an initial capacity?
Looking into the source code of the java.util.ArrayList
class, starting from at least java 1.8 I see the following code:
/**
* Constructs an empty list with an initial capacity of ten.
*/
public ArrayList() {
this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
}
Where
private static final Object DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
Though the javadoc officially states:
Constructs an empty list with an initial capacity of ten.
I outline: ...an initial capacity of ten. Where is this ten?
Am I completely mad and missing something, or there is simply a javadoc bug here?
UPD: How it looked like prior java 1.8:
public ArrayList(int initialCapacity) {
super();
if (initialCapacity < 0)
throw new IllegalArgumentException("Illegal Capacity: "+
initialCapacity);
this.elementData = new Object[initialCapacity];
}
/**
* Constructs an empty list with an initial capacity of ten.
*/
public ArrayList() {
this(10);
}
This question already has an answer here:
In Java 8, why is the default capacity of ArrayList now zero?
6 answers
java arraylist javadoc
java arraylist javadoc
edited Dec 13 at 13:51
asked Dec 13 at 13:47
Andremoniy
21.7k673155
21.7k673155
marked as duplicate by Aomine
StackExchange.ready(function() {
if (StackExchange.options.isMobile) return;
$('.dupe-hammer-message-hover:not(.hover-bound)').each(function() {
var $hover = $(this).addClass('hover-bound'),
$msg = $hover.siblings('.dupe-hammer-message');
$hover.hover(
function() {
$hover.showInfoMessage('', {
messageElement: $msg.clone().show(),
transient: false,
position: { my: 'bottom left', at: 'top center', offsetTop: -7 },
dismissable: false,
relativeToBody: true
});
},
function() {
StackExchange.helpers.removeMessages();
}
);
});
});
Dec 13 at 13:58
This question has been asked before and already has an answer. If those answers do not fully address your question, please ask a new question.
marked as duplicate by Aomine
StackExchange.ready(function() {
if (StackExchange.options.isMobile) return;
$('.dupe-hammer-message-hover:not(.hover-bound)').each(function() {
var $hover = $(this).addClass('hover-bound'),
$msg = $hover.siblings('.dupe-hammer-message');
$hover.hover(
function() {
$hover.showInfoMessage('', {
messageElement: $msg.clone().show(),
transient: false,
position: { my: 'bottom left', at: 'top center', offsetTop: -7 },
dismissable: false,
relativeToBody: true
});
},
function() {
StackExchange.helpers.removeMessages();
}
);
});
});
Dec 13 at 13:58
This question has been asked before and already has an answer. If those answers do not fully address your question, please ask a new question.
add a comment |
add a comment |
2 Answers
2
active
oldest
votes
up vote
7
down vote
accepted
This is an optimization. The developers decided to initialize the ArrayList
with an empty backing array, and lazily create a non-empty backing array only when you start adding elements to the List
.
When you add the first element (by calling add
), it calls
ensureCapacityInternal(size + 1);
which checks if elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA
, and if so, sets the capacity to
minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);
DEFAULT_CAPACITY
is 10
.
But I still don't get, it is explicitly said: an initial capacity of ten. Where is this ten? :p
– Andremoniy
Dec 13 at 13:51
@Andremoniy see edit
– Eran
Dec 13 at 13:52
I see. It's a good catch. No doubts. HOWEVER. There is a big difference for those who only reads the javadoc: before java 1.8 it would make sense to createArrayList(0)
to make it a slightly more efficient, isn't it? So I would insist that this is a kind of bug in javadoc...
– Andremoniy
Dec 13 at 13:54
@Andremoniy I'm not sure it's a bug in javadoc. I'd call it an implementation detail.
– Eran
Dec 13 at 13:56
1
@Andremoniyadd
callsensureCapacityInternal(1)
(when the list is empty), which callsensureExplicitCapacity(10)
, which callsgrow(10)
, which callselementData = Arrays.copyOf(elementData, newCapacity);
– Eran
Dec 13 at 14:00
|
show 4 more comments
up vote
3
down vote
The capacity will be set as 10 when you add element to the list first time.
See this:
/**
* Default initial capacity.
*/
private static final int DEFAULT_CAPACITY = 10;
Complete procedure
Step 1:
public boolean add(E e) {
modCount++;
add(e, elementData, size);
return true;
}
Step 2:
private void add(E e, Object elementData, int s) {
if (s == elementData.length)
elementData = grow();
elementData[s] = e;
size = s + 1;
}
Step 3, the list grows
:
private Object grow() {
return grow(size + 1); // size is 0 here
}
private Object grow(int minCapacity) {
return elementData = Arrays.copyOf(elementData,
newCapacity(minCapacity)); // newCapacity(1) will return 10, see step 4, the elementData will have capacity 10.
}
Step 4, call newCapacity(1)
:
private int newCapacity(int minCapacity) {
// overflow-conscious code
int oldCapacity = elementData.length;
int newCapacity = oldCapacity + (oldCapacity >> 1);
if (newCapacity - minCapacity <= 0) {
if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA)
return Math.max(DEFAULT_CAPACITY, minCapacity); // will return 10 here !!!!
if (minCapacity < 0) // overflow
throw new OutOfMemoryError();
return minCapacity;
}
return (newCapacity - MAX_ARRAY_SIZE <= 0)
? newCapacity
: hugeCapacity(minCapacity);
}
Appreciate your detailed answer. Though it appears that my question is a duplicate.
– Andremoniy
Dec 13 at 14:07
add a comment |
2 Answers
2
active
oldest
votes
2 Answers
2
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
7
down vote
accepted
This is an optimization. The developers decided to initialize the ArrayList
with an empty backing array, and lazily create a non-empty backing array only when you start adding elements to the List
.
When you add the first element (by calling add
), it calls
ensureCapacityInternal(size + 1);
which checks if elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA
, and if so, sets the capacity to
minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);
DEFAULT_CAPACITY
is 10
.
But I still don't get, it is explicitly said: an initial capacity of ten. Where is this ten? :p
– Andremoniy
Dec 13 at 13:51
@Andremoniy see edit
– Eran
Dec 13 at 13:52
I see. It's a good catch. No doubts. HOWEVER. There is a big difference for those who only reads the javadoc: before java 1.8 it would make sense to createArrayList(0)
to make it a slightly more efficient, isn't it? So I would insist that this is a kind of bug in javadoc...
– Andremoniy
Dec 13 at 13:54
@Andremoniy I'm not sure it's a bug in javadoc. I'd call it an implementation detail.
– Eran
Dec 13 at 13:56
1
@Andremoniyadd
callsensureCapacityInternal(1)
(when the list is empty), which callsensureExplicitCapacity(10)
, which callsgrow(10)
, which callselementData = Arrays.copyOf(elementData, newCapacity);
– Eran
Dec 13 at 14:00
|
show 4 more comments
up vote
7
down vote
accepted
This is an optimization. The developers decided to initialize the ArrayList
with an empty backing array, and lazily create a non-empty backing array only when you start adding elements to the List
.
When you add the first element (by calling add
), it calls
ensureCapacityInternal(size + 1);
which checks if elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA
, and if so, sets the capacity to
minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);
DEFAULT_CAPACITY
is 10
.
But I still don't get, it is explicitly said: an initial capacity of ten. Where is this ten? :p
– Andremoniy
Dec 13 at 13:51
@Andremoniy see edit
– Eran
Dec 13 at 13:52
I see. It's a good catch. No doubts. HOWEVER. There is a big difference for those who only reads the javadoc: before java 1.8 it would make sense to createArrayList(0)
to make it a slightly more efficient, isn't it? So I would insist that this is a kind of bug in javadoc...
– Andremoniy
Dec 13 at 13:54
@Andremoniy I'm not sure it's a bug in javadoc. I'd call it an implementation detail.
– Eran
Dec 13 at 13:56
1
@Andremoniyadd
callsensureCapacityInternal(1)
(when the list is empty), which callsensureExplicitCapacity(10)
, which callsgrow(10)
, which callselementData = Arrays.copyOf(elementData, newCapacity);
– Eran
Dec 13 at 14:00
|
show 4 more comments
up vote
7
down vote
accepted
up vote
7
down vote
accepted
This is an optimization. The developers decided to initialize the ArrayList
with an empty backing array, and lazily create a non-empty backing array only when you start adding elements to the List
.
When you add the first element (by calling add
), it calls
ensureCapacityInternal(size + 1);
which checks if elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA
, and if so, sets the capacity to
minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);
DEFAULT_CAPACITY
is 10
.
This is an optimization. The developers decided to initialize the ArrayList
with an empty backing array, and lazily create a non-empty backing array only when you start adding elements to the List
.
When you add the first element (by calling add
), it calls
ensureCapacityInternal(size + 1);
which checks if elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA
, and if so, sets the capacity to
minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);
DEFAULT_CAPACITY
is 10
.
edited Dec 13 at 14:05
answered Dec 13 at 13:49
Eran
277k37446531
277k37446531
But I still don't get, it is explicitly said: an initial capacity of ten. Where is this ten? :p
– Andremoniy
Dec 13 at 13:51
@Andremoniy see edit
– Eran
Dec 13 at 13:52
I see. It's a good catch. No doubts. HOWEVER. There is a big difference for those who only reads the javadoc: before java 1.8 it would make sense to createArrayList(0)
to make it a slightly more efficient, isn't it? So I would insist that this is a kind of bug in javadoc...
– Andremoniy
Dec 13 at 13:54
@Andremoniy I'm not sure it's a bug in javadoc. I'd call it an implementation detail.
– Eran
Dec 13 at 13:56
1
@Andremoniyadd
callsensureCapacityInternal(1)
(when the list is empty), which callsensureExplicitCapacity(10)
, which callsgrow(10)
, which callselementData = Arrays.copyOf(elementData, newCapacity);
– Eran
Dec 13 at 14:00
|
show 4 more comments
But I still don't get, it is explicitly said: an initial capacity of ten. Where is this ten? :p
– Andremoniy
Dec 13 at 13:51
@Andremoniy see edit
– Eran
Dec 13 at 13:52
I see. It's a good catch. No doubts. HOWEVER. There is a big difference for those who only reads the javadoc: before java 1.8 it would make sense to createArrayList(0)
to make it a slightly more efficient, isn't it? So I would insist that this is a kind of bug in javadoc...
– Andremoniy
Dec 13 at 13:54
@Andremoniy I'm not sure it's a bug in javadoc. I'd call it an implementation detail.
– Eran
Dec 13 at 13:56
1
@Andremoniyadd
callsensureCapacityInternal(1)
(when the list is empty), which callsensureExplicitCapacity(10)
, which callsgrow(10)
, which callselementData = Arrays.copyOf(elementData, newCapacity);
– Eran
Dec 13 at 14:00
But I still don't get, it is explicitly said: an initial capacity of ten. Where is this ten? :p
– Andremoniy
Dec 13 at 13:51
But I still don't get, it is explicitly said: an initial capacity of ten. Where is this ten? :p
– Andremoniy
Dec 13 at 13:51
@Andremoniy see edit
– Eran
Dec 13 at 13:52
@Andremoniy see edit
– Eran
Dec 13 at 13:52
I see. It's a good catch. No doubts. HOWEVER. There is a big difference for those who only reads the javadoc: before java 1.8 it would make sense to create
ArrayList(0)
to make it a slightly more efficient, isn't it? So I would insist that this is a kind of bug in javadoc...– Andremoniy
Dec 13 at 13:54
I see. It's a good catch. No doubts. HOWEVER. There is a big difference for those who only reads the javadoc: before java 1.8 it would make sense to create
ArrayList(0)
to make it a slightly more efficient, isn't it? So I would insist that this is a kind of bug in javadoc...– Andremoniy
Dec 13 at 13:54
@Andremoniy I'm not sure it's a bug in javadoc. I'd call it an implementation detail.
– Eran
Dec 13 at 13:56
@Andremoniy I'm not sure it's a bug in javadoc. I'd call it an implementation detail.
– Eran
Dec 13 at 13:56
1
1
@Andremoniy
add
calls ensureCapacityInternal(1)
(when the list is empty), which calls ensureExplicitCapacity(10)
, which calls grow(10)
, which calls elementData = Arrays.copyOf(elementData, newCapacity);
– Eran
Dec 13 at 14:00
@Andremoniy
add
calls ensureCapacityInternal(1)
(when the list is empty), which calls ensureExplicitCapacity(10)
, which calls grow(10)
, which calls elementData = Arrays.copyOf(elementData, newCapacity);
– Eran
Dec 13 at 14:00
|
show 4 more comments
up vote
3
down vote
The capacity will be set as 10 when you add element to the list first time.
See this:
/**
* Default initial capacity.
*/
private static final int DEFAULT_CAPACITY = 10;
Complete procedure
Step 1:
public boolean add(E e) {
modCount++;
add(e, elementData, size);
return true;
}
Step 2:
private void add(E e, Object elementData, int s) {
if (s == elementData.length)
elementData = grow();
elementData[s] = e;
size = s + 1;
}
Step 3, the list grows
:
private Object grow() {
return grow(size + 1); // size is 0 here
}
private Object grow(int minCapacity) {
return elementData = Arrays.copyOf(elementData,
newCapacity(minCapacity)); // newCapacity(1) will return 10, see step 4, the elementData will have capacity 10.
}
Step 4, call newCapacity(1)
:
private int newCapacity(int minCapacity) {
// overflow-conscious code
int oldCapacity = elementData.length;
int newCapacity = oldCapacity + (oldCapacity >> 1);
if (newCapacity - minCapacity <= 0) {
if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA)
return Math.max(DEFAULT_CAPACITY, minCapacity); // will return 10 here !!!!
if (minCapacity < 0) // overflow
throw new OutOfMemoryError();
return minCapacity;
}
return (newCapacity - MAX_ARRAY_SIZE <= 0)
? newCapacity
: hugeCapacity(minCapacity);
}
Appreciate your detailed answer. Though it appears that my question is a duplicate.
– Andremoniy
Dec 13 at 14:07
add a comment |
up vote
3
down vote
The capacity will be set as 10 when you add element to the list first time.
See this:
/**
* Default initial capacity.
*/
private static final int DEFAULT_CAPACITY = 10;
Complete procedure
Step 1:
public boolean add(E e) {
modCount++;
add(e, elementData, size);
return true;
}
Step 2:
private void add(E e, Object elementData, int s) {
if (s == elementData.length)
elementData = grow();
elementData[s] = e;
size = s + 1;
}
Step 3, the list grows
:
private Object grow() {
return grow(size + 1); // size is 0 here
}
private Object grow(int minCapacity) {
return elementData = Arrays.copyOf(elementData,
newCapacity(minCapacity)); // newCapacity(1) will return 10, see step 4, the elementData will have capacity 10.
}
Step 4, call newCapacity(1)
:
private int newCapacity(int minCapacity) {
// overflow-conscious code
int oldCapacity = elementData.length;
int newCapacity = oldCapacity + (oldCapacity >> 1);
if (newCapacity - minCapacity <= 0) {
if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA)
return Math.max(DEFAULT_CAPACITY, minCapacity); // will return 10 here !!!!
if (minCapacity < 0) // overflow
throw new OutOfMemoryError();
return minCapacity;
}
return (newCapacity - MAX_ARRAY_SIZE <= 0)
? newCapacity
: hugeCapacity(minCapacity);
}
Appreciate your detailed answer. Though it appears that my question is a duplicate.
– Andremoniy
Dec 13 at 14:07
add a comment |
up vote
3
down vote
up vote
3
down vote
The capacity will be set as 10 when you add element to the list first time.
See this:
/**
* Default initial capacity.
*/
private static final int DEFAULT_CAPACITY = 10;
Complete procedure
Step 1:
public boolean add(E e) {
modCount++;
add(e, elementData, size);
return true;
}
Step 2:
private void add(E e, Object elementData, int s) {
if (s == elementData.length)
elementData = grow();
elementData[s] = e;
size = s + 1;
}
Step 3, the list grows
:
private Object grow() {
return grow(size + 1); // size is 0 here
}
private Object grow(int minCapacity) {
return elementData = Arrays.copyOf(elementData,
newCapacity(minCapacity)); // newCapacity(1) will return 10, see step 4, the elementData will have capacity 10.
}
Step 4, call newCapacity(1)
:
private int newCapacity(int minCapacity) {
// overflow-conscious code
int oldCapacity = elementData.length;
int newCapacity = oldCapacity + (oldCapacity >> 1);
if (newCapacity - minCapacity <= 0) {
if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA)
return Math.max(DEFAULT_CAPACITY, minCapacity); // will return 10 here !!!!
if (minCapacity < 0) // overflow
throw new OutOfMemoryError();
return minCapacity;
}
return (newCapacity - MAX_ARRAY_SIZE <= 0)
? newCapacity
: hugeCapacity(minCapacity);
}
The capacity will be set as 10 when you add element to the list first time.
See this:
/**
* Default initial capacity.
*/
private static final int DEFAULT_CAPACITY = 10;
Complete procedure
Step 1:
public boolean add(E e) {
modCount++;
add(e, elementData, size);
return true;
}
Step 2:
private void add(E e, Object elementData, int s) {
if (s == elementData.length)
elementData = grow();
elementData[s] = e;
size = s + 1;
}
Step 3, the list grows
:
private Object grow() {
return grow(size + 1); // size is 0 here
}
private Object grow(int minCapacity) {
return elementData = Arrays.copyOf(elementData,
newCapacity(minCapacity)); // newCapacity(1) will return 10, see step 4, the elementData will have capacity 10.
}
Step 4, call newCapacity(1)
:
private int newCapacity(int minCapacity) {
// overflow-conscious code
int oldCapacity = elementData.length;
int newCapacity = oldCapacity + (oldCapacity >> 1);
if (newCapacity - minCapacity <= 0) {
if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA)
return Math.max(DEFAULT_CAPACITY, minCapacity); // will return 10 here !!!!
if (minCapacity < 0) // overflow
throw new OutOfMemoryError();
return minCapacity;
}
return (newCapacity - MAX_ARRAY_SIZE <= 0)
? newCapacity
: hugeCapacity(minCapacity);
}
edited Dec 13 at 14:08
answered Dec 13 at 13:53
孙兴斌
15.9k41644
15.9k41644
Appreciate your detailed answer. Though it appears that my question is a duplicate.
– Andremoniy
Dec 13 at 14:07
add a comment |
Appreciate your detailed answer. Though it appears that my question is a duplicate.
– Andremoniy
Dec 13 at 14:07
Appreciate your detailed answer. Though it appears that my question is a duplicate.
– Andremoniy
Dec 13 at 14:07
Appreciate your detailed answer. Though it appears that my question is a duplicate.
– Andremoniy
Dec 13 at 14:07
add a comment |