Proper way to call and use C# variables?

Having a bad day today and need some expert advice.

Am I even doing this right?  It seems kinda reduntant.

What I intend on doing is using the object throughout the pages, so I put it in a session.

But each time I want to access the object I got to create another one and inject it with the session object?
protected void Page_Load(object sender, EventArgs e)
    {
        if (Session["AuditAnswer"] == null)
        {
            AnswerMainDTO AuditAnswer = new AnswerMainDTO();
            Session["AuditAnswer"] = AuditAnswer;
        }
 
    }
    protected void SelectProduct()
    {
        AnswerMainDTO AuditAnswer = new AnswerMainDTO();
        AuditAnswer = (AnswerMainDTO)Session["AuditAnswer"];
        AuditAnswer.Product = 1;
        Session["AuditAnswer"] = AuditAnswer;
    }

Open in new window

LVL 3
MepsAsked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

KelevraCommented:
Hi,

If there is a global variable you want to use in the entire site you could use the global.asax file!

Otherwise to answer your question you can store objects in session there are no problems in doing so!
protected void Page_Load(object sender, EventArgs e)
    {
        if (Session["AuditAnswer"] == null)
        {
            AnswerMainDTO AuditAnswer = new AnswerMainDTO();
 
 
            Session["AuditAnswer"] = AuditAnswer;
        }
 
    }
    protected void SelectProduct()
    {
        AnswerMainDTO AuditAnswer = (maybe do a cast here) Session["AuditAnswer"];
 
        AuditAnswer.Product = 1;
 
        Session["AuditAnswer"] = AuditAnswer;
    }

Open in new window

0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
MepsAuthor Commented:
Was just going to use this object for a few pages, so I didn't want to place in the gobal.

I know the starting page, and the ending page that will use this object so creating and destroying the object there.

Just seemed kinda odd to keep on creating the object just to use it.
0
KelevraCommented:
Well, you see the object you instanciate (by the new word) is visible only in your current page.

You can pass it through to other classes files or function by placing it into argument.

like:


MyObject obj = new MyObject();
 
obj.this = "that";
 
//call a function using the object without having to instanciate it again!
MyFunction (obj)
 
 
here if you have a function:
 
public void MyFunction (MyObject obj)
{
//do something!
}

Open in new window

0
MepsAuthor Commented:
Thank you for the assist.  good to know I don't have to instanciate the object every time.
0
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
C#

From novice to tech pro — start learning today.