473,395 Members | 2,006 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,395 software developers and data experts.

OOP Question

Given the following:

Public Class Foo
Private m_strBar as string

Public Property BarString as String
Get
BarString = m_strBar
End Get

Set(ByVal value as string)
m_strBar = value
End Set
End Property

Public Sub DoSomething

End Sub
End Class

I need to access information related to the BarString property, and access
it within the DoSomething sub.

My question is - is there any reason why I should, or should not, access the
local variable as opposed to getting the property value using Me.BarString?
In debugging it seems the compiler has to retrieve the value anyway, and
accessing the local variable is more "direct", so I assume does not have the
same performance implications that using Me.BarString does.

Thanks!
Feb 14 '06 #1
7 997
Accessing private fields within the class itself isn't too bad. Afterall,
that's the definition of a private field ;)

it does break the encapsulation provided by the property however. Say for
example that your property did a little more like:

get
if (m_strBar is nothig) then
return m_anotherFireld
end if
return m_strBar
end get
suddenly, by accessing m_strBar you are missing out on the functinality
provided by the property...sometimes this'll be what you want, sometimes it
won't.

Karl

--
http://www.openmymind.net/
http://www.fuelindustries.com/
"Elliot Rodriguez" <elliotrodriguezatgeemaildotcom> wrote in message
news:OG**************@TK2MSFTNGP10.phx.gbl...
Given the following:

Public Class Foo
Private m_strBar as string

Public Property BarString as String
Get
BarString = m_strBar
End Get

Set(ByVal value as string)
m_strBar = value
End Set
End Property

Public Sub DoSomething

End Sub
End Class

I need to access information related to the BarString property, and access
it within the DoSomething sub.

My question is - is there any reason why I should, or should not, access
the local variable as opposed to getting the property value using
Me.BarString? In debugging it seems the compiler has to retrieve the value
anyway, and accessing the local variable is more "direct", so I assume
does not have the same performance implications that using Me.BarString
does.

Thanks!

Feb 14 '06 #2
Thanks for giving me a good answer, and another angle to look at it, Karl.

"Karl Seguin [MVP]" <karl REMOVE @ REMOVE openmymind REMOVEMETOO . ANDME
net> wrote in message news:eg**************@TK2MSFTNGP11.phx.gbl...
Accessing private fields within the class itself isn't too bad. Afterall,
that's the definition of a private field ;)

it does break the encapsulation provided by the property however. Say for
example that your property did a little more like:

get
if (m_strBar is nothig) then
return m_anotherFireld
end if
return m_strBar
end get
suddenly, by accessing m_strBar you are missing out on the functinality
provided by the property...sometimes this'll be what you want, sometimes
it won't.

Karl

--
http://www.openmymind.net/
http://www.fuelindustries.com/
"Elliot Rodriguez" <elliotrodriguezatgeemaildotcom> wrote in message
news:OG**************@TK2MSFTNGP10.phx.gbl...
Given the following:

Public Class Foo
Private m_strBar as string

Public Property BarString as String
Get
BarString = m_strBar
End Get

Set(ByVal value as string)
m_strBar = value
End Set
End Property

Public Sub DoSomething

End Sub
End Class

I need to access information related to the BarString property, and
access it within the DoSomething sub.

My question is - is there any reason why I should, or should not, access
the local variable as opposed to getting the property value using
Me.BarString? In debugging it seems the compiler has to retrieve the
value anyway, and accessing the local variable is more "direct", so I
assume does not have the same performance implications that using
Me.BarString does.

Thanks!


Feb 14 '06 #3


I usually refer to it as the member variable.

public void DoSomething()
{
this.m_bar = "I am a Bar";
}

...

While I see alot of c#'ers use "this", not many vb'ers use Me. I happen to
use Me.

Like this

public sub DoSomething

Me.m_bar = "I am a VB Bar"

end Sub
You'll also notice there is no "str". That ~was VB6. go and google "Brad
Abrams" "Naming conventions" to find more.

My main reasoning is maintenance. When I use

this.m_bar;

I know EXACTLY what I'm talking about.

Sometimes... in the Property, it might be a derived property.
Public int Age
{ get { return DateTime.Now.Substract(m_dateOfBirth).ToYear(); }}

something like that (that won't compile, Im just showing an FYI. I take
todays date, substract the date of birth, and get the Year of the
difference.
I can't "prove" that using this.MyProperty is wrong... it just feels very
wrong to me.

"Elliot Rodriguez" <elliotrodriguezatgeemaildotcom> wrote in message
news:OG**************@TK2MSFTNGP10.phx.gbl...
Given the following:

Public Class Foo
Private m_strBar as string

Public Property BarString as String
Get
BarString = m_strBar
End Get

Set(ByVal value as string)
m_strBar = value
End Set
End Property

Public Sub DoSomething

End Sub
End Class

I need to access information related to the BarString property, and access
it within the DoSomething sub.

My question is - is there any reason why I should, or should not, access the local variable as opposed to getting the property value using Me.BarString? In debugging it seems the compiler has to retrieve the value anyway, and
accessing the local variable is more "direct", so I assume does not have the same performance implications that using Me.BarString does.

Thanks!

Feb 14 '06 #4
Hi Elliott,
My question is - is there any reason why I should, or should not, access
the local variable as opposed to getting the property value using
Me.BarString?
There are a number of reasons you would want to use a property. But it isn't
always necessary. One of the most obvious reasons is that the property
getter and setter are methods, which can do any additional processing you
want when getting or setting the value. Another is that a property getter
and setter do not always work with field values. Sometimes they work with
calculated values, or multiple other fields, properties, and/or methods.
Interacting with some technologies can require a property rather than a
field. Those are the most common ones I can think of off the top of my head.

--
HTH,

Kevin Spencer
Microsoft MVP
..Net Developer
We got a sick zebra a hat,
you ultimate tuna.
"Elliot Rodriguez" <elliotrodriguezatgeemaildotcom> wrote in message
news:OG**************@TK2MSFTNGP10.phx.gbl... Given the following:

Public Class Foo
Private m_strBar as string

Public Property BarString as String
Get
BarString = m_strBar
End Get

Set(ByVal value as string)
m_strBar = value
End Set
End Property

Public Sub DoSomething

End Sub
End Class

I need to access information related to the BarString property, and access
it within the DoSomething sub.

My question is - is there any reason why I should, or should not, access
the local variable as opposed to getting the property value using
Me.BarString? In debugging it seems the compiler has to retrieve the value
anyway, and accessing the local variable is more "direct", so I assume
does not have the same performance implications that using Me.BarString
does.

Thanks!

Feb 14 '06 #5
Sloan:

Thanks for your perspective. I know that the naming conventions I used in my
example are deprecated, but for me its a matter of preference, and its for a
personal project so I stick with it. Not to get too tangential here, but I
find that the changes in conventions have been mostly a matter of style and
in some cases improved readability, although I dont see how it helps or
hurts, personally.

Unless the compiler has issues with it that I simply dont know about...
"sloan" <sl***@ipass.net> wrote in message
news:%2***************@tk2msftngp13.phx.gbl...


I usually refer to it as the member variable.

public void DoSomething()
{
this.m_bar = "I am a Bar";
}

..

While I see alot of c#'ers use "this", not many vb'ers use Me. I happen
to
use Me.

Like this

public sub DoSomething

Me.m_bar = "I am a VB Bar"

end Sub
You'll also notice there is no "str". That ~was VB6. go and google "Brad
Abrams" "Naming conventions" to find more.

My main reasoning is maintenance. When I use

this.m_bar;

I know EXACTLY what I'm talking about.

Sometimes... in the Property, it might be a derived property.
Public int Age
{ get { return DateTime.Now.Substract(m_dateOfBirth).ToYear(); }}

something like that (that won't compile, Im just showing an FYI. I take
todays date, substract the date of birth, and get the Year of the
difference.
I can't "prove" that using this.MyProperty is wrong... it just feels very
wrong to me.

"Elliot Rodriguez" <elliotrodriguezatgeemaildotcom> wrote in message
news:OG**************@TK2MSFTNGP10.phx.gbl...
Given the following:

Public Class Foo
Private m_strBar as string

Public Property BarString as String
Get
BarString = m_strBar
End Get

Set(ByVal value as string)
m_strBar = value
End Set
End Property

Public Sub DoSomething

End Sub
End Class

I need to access information related to the BarString property, and
access
it within the DoSomething sub.

My question is - is there any reason why I should, or should not, access

the
local variable as opposed to getting the property value using

Me.BarString?
In debugging it seems the compiler has to retrieve the value anyway, and
accessing the local variable is more "direct", so I assume does not have

the
same performance implications that using Me.BarString does.

Thanks!


Feb 14 '06 #6
"Elliot Rodriguez" <elliotrodriguezatgeemaildotcom> wrote in message
news:OG**************@TK2MSFTNGP10.phx.gbl...
Given the following:

Public Class Foo
Private m_strBar as string

Public Property BarString as String
Get
BarString = m_strBar
End Get

Set(ByVal value as string)
m_strBar = value
End Set
End Property

Public Sub DoSomething

End Sub
End Class

I need to access information related to the BarString property, and access
it within the DoSomething sub.

My question is - is there any reason why I should, or should not, access
the local variable as opposed to getting the property value using
Me.BarString? In debugging it seems the compiler has to retrieve the value
anyway, and accessing the local variable is more "direct", so I assume
does not have the same performance implications that using Me.BarString
does.

Thanks!


I think Karl has the right of it, though he does spell his name incorrectly.

I always read from the property rather than the private field for the reason
he points out. Say I am writing a data object and my database does not
permit null values or I simply don't want null values written to the
database.

Private _firstName As String

Private Property FirstName As String
Get
If _firstName Is Nothing
_firstName = String.Empty
End If

Return _firstName
End Get
End Property

Obviously, I have omitted the Set block. Unlike value types (Integer,
Boolean, etc) most reference types are not initialized upon declaration.
They remain Nothing until assigned. For Example:

Dim value1 As Integer
Dim value2 As String

At this point in the code, Value1 is equal to 0 (zero) and value2 is
Nothing. So, by using our properties rather than the private field when we
send our data object to our data class, we avoid null values in our database
automatically, even if we did not populate the string fields.

carl
Feb 14 '06 #7
lol...blame my parents, no me :)

Karl
--
http://www.openmymind.net/
http://www.fuelindustries.com/
"Vagabond Software" <vagabondsw-X-@-X-gmail.com> wrote in message
news:eu*************@tk2msftngp13.phx.gbl...
"Elliot Rodriguez" <elliotrodriguezatgeemaildotcom> wrote in message
news:OG**************@TK2MSFTNGP10.phx.gbl...
Given the following:

Public Class Foo
Private m_strBar as string

Public Property BarString as String
Get
BarString = m_strBar
End Get

Set(ByVal value as string)
m_strBar = value
End Set
End Property

Public Sub DoSomething

End Sub
End Class

I need to access information related to the BarString property, and
access it within the DoSomething sub.

My question is - is there any reason why I should, or should not, access
the local variable as opposed to getting the property value using
Me.BarString? In debugging it seems the compiler has to retrieve the
value anyway, and accessing the local variable is more "direct", so I
assume does not have the same performance implications that using
Me.BarString does.

Thanks!


I think Karl has the right of it, though he does spell his name
incorrectly.

I always read from the property rather than the private field for the
reason he points out. Say I am writing a data object and my database does
not permit null values or I simply don't want null values written to the
database.

Private _firstName As String

Private Property FirstName As String
Get
If _firstName Is Nothing
_firstName = String.Empty
End If

Return _firstName
End Get
End Property

Obviously, I have omitted the Set block. Unlike value types (Integer,
Boolean, etc) most reference types are not initialized upon declaration.
They remain Nothing until assigned. For Example:

Dim value1 As Integer
Dim value2 As String

At this point in the code, Value1 is equal to 0 (zero) and value2 is
Nothing. So, by using our properties rather than the private field when
we send our data object to our data class, we avoid null values in our
database automatically, even if we did not populate the string fields.

carl

Feb 14 '06 #8

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

1
by: Mohammed Mazid | last post by:
Can anyone please help me on how to move to the next and previous question? Here is a snippet of my code: Private Sub cmdNext_Click() End Sub Private Sub cmdPrevious_Click() showrecord
3
by: Stevey | last post by:
I have the following XML file... <?xml version="1.0"?> <animals> <animal> <name>Tiger</name> <questions> <question index="0">true</question> <question index="1">true</question> </questions>
7
by: nospam | last post by:
Ok, 3rd or is it the 4th time I have asked this question on Partial Types, so, since it seems to me that Partial Types is still in the design or development stages at Microsoft, I am going to ask...
3
by: Ekqvist Marko | last post by:
Hi, I have one Access database table including questions and answers. Now I need to give answer id automatically to questionID column. But I don't know how it is best (fastest) to do? table...
10
by: glenn | last post by:
I am use to programming in php and the way session and post vars are past from fields on one page through to the post page automatically where I can get to their values easily to write to a...
10
by: Rider | last post by:
Hi, simple(?) question about asp.net configuration.. I've installed ASP.NET 2.0 QuickStart Sample successfully. But, When I'm first start application the follow message shown. ========= Server...
53
by: Jeff | last post by:
In the function below, can size ever be 0 (zero)? char *clc_strdup(const char * CLC_RESTRICT s) { size_t size; char *p; clc_assert_not_null(clc_strdup, s); size = strlen(s) + 1;
56
by: spibou | last post by:
In the statement "a *= expression" is expression assumed to be parenthesized ? For example if I write "a *= b+c" is this the same as "a = a * (b+c)" or "a = a * b+c" ?
2
by: Allan Ebdrup | last post by:
Hi, I'm trying to render a Matrix question in my ASP.Net 2.0 page, A matrix question is a question where you have several options that can all be rated according to several possible ratings (from...
3
by: Zhang Weiwu | last post by:
Hello! I wrote this: ..required-question p:after { content: "*"; } Corresponding HTML: <div class="required-question"><p>Question Text</p><input /></div> <div...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: ryjfgjl | last post by:
In our work, we often receive Excel tables with data in the same format. If we want to analyze these data, it can be difficult to analyze them because the data is spread across multiple Excel files...
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
by: Hystou | last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can...
0
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
0
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...
0
agi2029
by: agi2029 | last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.