Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8697525
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 13, 20262026-06-13T01:32:53+00:00 2026-06-13T01:32:53+00:00

i have some problems to reverse LPSTR. Here is my function: LPSTR Reverse(LPSTR a_lpText)

  • 0

i have some problems to reverse LPSTR.
Here is my function:

LPSTR Reverse(LPSTR a_lpText)
{
   int nTextLength = strlen((char*)a_lpText);
   LPSTR lpReversed = (LPSTR) GlobalAlloc(GPTR, nTextLength + 1);
   for (int i = 0; i < nTextLength; ++i)
      *(lpReversed + i) = (CHAR) *(a_lpText + nTextLength - i);
   return lpReversed;
}

Function, return not initialized LPSTR or some strange characters.
Problem is probably in conversion? Thanks for answers!

Edit 1: strcat() don’t work. I just want copy char by char.

Edit 2:

*(lpReversed + i) = (CHAR) *(a_lpText + nTextLength - i - 1);

Freeze the whole program.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-13T01:32:54+00:00Added an answer on June 13, 2026 at 1:32 am

    This looks more like C code than C++, so I’ll stick to that style. I can’t understand why you would be using GlobalAlloc. You only need that for DDE which I cannot possibly imagine you are using here. Use malloc or new[] if this really is C++.

    If you really are using a DDE API that requires GlobalAlloc, then keep the GlobalAlloc part separate from the string reversing code. Mixing the two concerns makes for unmaintainable code.

    If this really is C++ then std::string is what you should be using wherever possible.

    I also think there’s great confusion with all the casting and all the non-standard Windows type macros. It makes the code pretty much unreadable.

    There is also an indexing error as pointed out by Maximus. For what it is worth, I’d write the function something like this:

    char* Reversed(const char* str)
    {
       int len = strlen(str);
       char* reversed = (char*) malloc(len+1);
       reversed[len] = 0;//ensure return string has null-terminator
       for (int i = 0; i < len; ++i)
          reversed[len-1-i] = str[i];
       return reversed;
    }
    

    The only cast you need is the return value of malloc. If you were to use new[] then you would not even need to do that. In which case the code would be like this:

    char* Reversed(const char* str)
    {
       int len = strlen(str);
       char* reversed = new char[len+1];
       reversed[len] = 0;//ensure return string has null-terminator
       for (int i = 0; i < len; ++i)
          reversed[len-1-i] = str[i];
       return reversed;
    }
    

    One should always strive to write code without casts.

    Don’t do pointer arithmetic yourself when the index operator [] can be used. It’s much easier to read this way.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have some problems with header() function. It works and doesn't work at the
i have some problems with a Query seem IN dosen't work with Group_concat, that
I have some problems with Javascript. In fact, I'm just newbie in that script
I have some problems with my first Open Graph custom action: I've created a
I have some problems sending mails through SMTP using Spring's MailSender interface and the
I have some problems with OpenCV s cvCanny(...) and the Image data types it
i have some problems with rowspan: var doc1 = new Document(); doc1.SetPageSize(PageSize.A4.Rotate()); string path
I have some problems sending an id though jquery. I have a form select
I have some problems with mod_rewrited at .httacess. We have created a website, the
I have some problems to start programming using cocos2D on linux + android. I

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.