•
•
•
•
What is DaniWeb IT Discussion Community?
You're currently browsing the C section within the Software Development category of DaniWeb, a massive community of 422,830 software developers, web developers, Internet marketers, and tech gurus who are all enthusiastic about making contacts, networking, and learning from each other. In fact, there are 3,338 IT professionals currently interacting right now! Registration is free, only takes a minute and lets you enjoy all of the interactive features of the site.
Please support our C advertiser: Programming Forums
Views: 5633 | Replies: 19
![]() |
| |
•
•
Join Date: Jun 2005
Location: Novi Sad, Serbia
Posts: 273
Reputation:
Rep Power: 6
Solved Threads: 29
Try memcpy or strcpy.
•
•
•
•
Originally Posted by http://www.acm.uiuc.edu/webmonkeys/book/c_guide/2.14.html
2.14.4 memcpy
Declaration:
void *memcpy(void *str1, const void *str2, size_t n);
Copies n characters from str2 to str1. If str1 and str2 overlap the behavior is undefined.
Returns the argument str1.
2.14.13 strcpy
Declaration:
char *strcpy(char *str1, const char *str2);
Copies the string pointed to by str2 to str1. Copies up to and including the null character of str2. If str1 and str2 overlap the behavior is undefined.
Returns the argument str1.
Last edited by andor : Oct 24th, 2006 at 7:33 am.
If you want to win, you must not loose (Alan Ford)
•
•
Join Date: Oct 2006
Posts: 3
Reputation:
Rep Power: 0
Solved Threads: 0
i've tried strcpy() but when i compile and run it the prog hangs then crashes. i'm probably doing something basically wrong in the fubction maybe.
int main(int argc, char *argv[]){
char filename[30];
strcpy(filename, argv[1]);
}•
•
Join Date: Jun 2005
Location: Novi Sad, Serbia
Posts: 273
Reputation:
Rep Power: 6
Solved Threads: 29
•
•
•
•
i've tried strcpy() but when i compile and run it the prog hangs then crashes. i'm probably doing something basically wrong in the fubction maybe.
int main(int argc, char *argv[]){ char filename[30]; strcpy(filename, argv[1]); }
Yes probably U R doing something wrong. What R U passing as arg[1]? Probably nothing and thats why it crashes.
#include <stdio.h>
#include <string.h>
int main(int argc, char *argv[]){
char filename[30];
if (argc != 2)
{
printf("Dude are you passing something at all");
return 1;
}
strcpy(filename, argv[1]);
printf("filename: %s\n", filename);
return 0;
}PS: memcpy is safer
Last edited by andor : Oct 24th, 2006 at 7:59 am.
If you want to win, you must not loose (Alan Ford)
•
•
Join Date: Jun 2005
Location: Novi Sad, Serbia
Posts: 273
Reputation:
Rep Power: 6
Solved Threads: 29
•
•
Join Date: Oct 2007
Posts: 5
Reputation:
Rep Power: 0
Solved Threads: 0
I also want to read filename, but in addition I need to read some interger parameter. I used this, now want to change. How can I handle: ./progname infilename integer ?
C++ Syntax (Toggle Plain Text)
int main(){ ifstream input; input.open("filename"); if (!input) { cout<<"File not open"; exit(1); } getline(input, str); return 0; }
•
•
Join Date: Oct 2007
Location: Cherry Hill, NJ
Posts: 1,876
Reputation:
Rep Power: 11
Solved Threads: 193
> PS: memcpy is safer
No it's not. It will try to copy n characters whether it hits an architecture-dependent read boundary or not. Use strncpy(). It is fully standard and stops in the right place.
To convert a string to an integer
Also, this is the C forum. If you plan to use C++ please post in the C++ forum. While the same people frequent both, the advice you get will vary depending on the language. (C and C++ are significantly different languages.)
Hope this helps.
No it's not. It will try to copy n characters whether it hits an architecture-dependent read boundary or not. Use strncpy(). It is fully standard and stops in the right place.
To convert a string to an integer
#include <cstdlib> and use the atoi() function:int i = atoi( "42" );Also, this is the C forum. If you plan to use C++ please post in the C++ forum. While the same people frequent both, the advice you get will vary depending on the language. (C and C++ are significantly different languages.)
Hope this helps.
>i'm probably doing something basically wrong in the fubction maybe.
Are you passing any arguments to your program? If not, argv[1] isn't guaranteed to be there, and if it is, it's pretty much sure to be NULL. If you're passing something, make sure that it's less than 30 characters or you'll overflow the buffer. strncpy is the logical choice, but it's really poorly named and doesn't do quite what you're expecting. I'd say use strncat instead:
>It will try to copy n characters whether it hits an
>architecture-dependent read boundary or not.
An architecture-dependent read boundary? Can you describe what you mean by this?
>Use strncpy(). It is fully standard and stops in the right place.
memcpy is fully standard. Also, strncpy always copies n characters. If the string isn't shorter than the buffer, strncpy will pad the buffer all the way to the count with null characters. If the string is longer than the buffer, strncpy will fail to null terminate the buffer. Despite the name, strncpy shouldn't be used as a "count restricted strcpy".
>To convert a string to an integer #include <cstdlib> and use the atoi() function
I wouldn't recommend atoi unless you've completely validated the input string first. It's basically impossible to tell if atoi failed without prior validation, and if the string isn't representable as an integer then calling atoi produces undefined behavior. It's too risky, so you should use strtol instead:
Are you passing any arguments to your program? If not, argv[1] isn't guaranteed to be there, and if it is, it's pretty much sure to be NULL. If you're passing something, make sure that it's less than 30 characters or you'll overflow the buffer. strncpy is the logical choice, but it's really poorly named and doesn't do quite what you're expecting. I'd say use strncat instead:
c Syntax (Toggle Plain Text)
#include <string.h> int main ( int argc, char *argv[] ) { char buffer[30]; if ( argc > 1 ) { /* strncat won't work if buffer isn't already a string */ buffer[0] = '\0'; strncat ( buffer, argv[1], 29 ); } return 0; }
>architecture-dependent read boundary or not.
An architecture-dependent read boundary? Can you describe what you mean by this?
>Use strncpy(). It is fully standard and stops in the right place.
memcpy is fully standard. Also, strncpy always copies n characters. If the string isn't shorter than the buffer, strncpy will pad the buffer all the way to the count with null characters. If the string is longer than the buffer, strncpy will fail to null terminate the buffer. Despite the name, strncpy shouldn't be used as a "count restricted strcpy".
>To convert a string to an integer #include <cstdlib> and use the atoi() function
I wouldn't recommend atoi unless you've completely validated the input string first. It's basically impossible to tell if atoi failed without prior validation, and if the string isn't representable as an integer then calling atoi produces undefined behavior. It's too risky, so you should use strtol instead:
c Syntax (Toggle Plain Text)
char *end; long temp; int x; errno = 0; temp = strtol ( buffer, &end, 0 ); if ( end == buffer ) puts ( "No conversion made" ); else if ( *end != '\0' ) puts ( "Partially invalid string" ); else if ( temp < INT_MIN || temp > INT_MAX ) puts ( "Out of range value" ); else x = (int)temp;
![]() |
•
•
•
•
•
•
•
•
DaniWeb C Marketplace
•
•
•
•
Currently Active Users Viewing This Thread: 1 (0 members and 1 guests)
- Newbie Question - How to generate a link (PHP)
- copy string and convert to upper case (Assembly)
- String literial question (PHP)
Other Threads in the C Forum
- Previous Thread: returning three dimensional array
- Next Thread: Some issues with #define "string" and the write function (unix socket related).



Hybrid Mode