copy char* to char*

2019-04-28 02:53发布

Here is part of my code:

extern "C" REGISTRATION_API int extreme(char* lKey)
{
string s1; 
char *p=NULL;
try
{
    ifstream myfile ("extreme.txt");
    int i=0;
    if (myfile.is_open())
    {
    while (getline(myfile,s1))
       {
        switch (i)
         {
        case 1:
         strcpy(p,s1.c_str());
         lKey=p;
        break;
             //continue here
         }
      }
   }
}

Now when I call this function from external application, I get this error:

AccessViolationException:
Attempted to read or write protected memory. This is often an indication that other memory is corrupt.

The problem is due to this:

lKey=p;

How can I assign the lKey to p?

标签: c++ char
4条回答
Viruses.
2楼-- · 2019-04-28 03:36

You need to pre-allocate the memory which you pass to strcpy. I.e. a p = new char[s1.length()+1]; will do it (+1 for the terminating 0 character). However, it's not a good idea to mix up std::string and C string routines for no good reason. Better stick with std::string, it will save you a LOTS of trouble.

Also lKey=p won't work either -- it just copies the local address of p into the local variable lKey. The caller won't even see a difference.

查看更多
兄弟一词,经得起流年.
3楼-- · 2019-04-28 03:42

Remember that a char* is just an address of a memory location. You need to have memory allocated at the address.

In your code you don't have memory allocated to use and you didn't set p to point to that memory address.

strcpy does not allocate a buffer, it just takes a memory address to copy the data to.

If you are passing a buffer into the function then you probably want simply this (and remove p)

strcpy(lKey, s1.c_str());
查看更多
Deceive 欺骗
4楼-- · 2019-04-28 03:45
  1. Eliminate p (it is doing nothing here), and copy the data from s1 directly to lkey
  2. Not to beat on you, but the indentation scheme is a travesty, please cop a good style from somewhere ( google 1tbs )
查看更多
ら.Afraid
5楼-- · 2019-04-28 03:46

Actually the problem is strcpy(p,s1.c_str()); since p is never set to anything but NULL.

查看更多
登录 后发表回答