data:image/s3,"s3://crabby-images/54a9c/54a9cb3b273ec4e1d2b771a756827ecaa1f252e7" alt=""
data:image/s3,"s3://crabby-images/6001d/6001d951f262c96539a34492f04de7d790a04918" alt=""
The second question:
data:image/s3,"s3://crabby-images/2a907/2a9072b3d55f47bb445f808b8a9f67ff9c4e532d" alt=""
Books if a character array of deposit has a number of different length of string, you should make the longest length is greater than the length of the string array, why char [0] can also
data:image/s3,"s3://crabby-images/2d2e8/2d2e86f726f8c86b89f6fddd5ca0604b7d85ed70" alt=""
#include
#include
Int main ()
{
Char c []={" c program "};
Char [] d={} "Hello";
Char [] e={' C ', ', 'p', 'r', 'o', 'g', 'r', 'a', 'm'};
int i;
for(i=0; i<=4; I++)
C=d [I] [I];
Puts (c);
Puts (e);
return 0;
}
#include
Int main ()
{
Char [] e={' C ', ', 'p', 'r', 'o', 'g', 'r', 'a', 'm'};
//for (I=0; i<=8; I++)
Puts (e);
}
#include
Int main ()
{
Char a, [0].
//to save "abcd" in a
Strcpy (a, "abcde");
//output string in a
Puts (a);
//will be "1234" save in a
Strcpy (a, "1234");
//output string in a
Puts (a);
}
CodePudding user response:
#include
#include
Int main ()
{
Char c []={" c program "};
Char [] d={} "Hello";
Char [] e={' C ', ', 'p', 'r', 'o', 'g', 'r', 'a', 'm'};
int i;
for(i=0; i<=4; I++)
C=d [I] [I];
Puts (c);
Puts (e);
return 0;
}
#include
Int main ()
{
Char [] e={' C ', ', 'p', 'r', 'o', 'g', 'r', 'a', 'm'};
//for (I=0; i<=8; I++)
Puts (e);
}
#include
Int main ()
{
Char a, [0].
//to save "abcd" in a
Strcpy (a, "abcde");
//output string in a
Puts (a);
//will be "1234" save in a
Strcpy (a, "1234");
//output string in a
Puts (a);
}
CodePudding user response:
data:image/s3,"s3://crabby-images/37986/37986d1de90d47381a370aa44e8d49b20a749747" alt=""
Why is beyond 5 bytes or not warning?
#include
Int main ()
{
Char STR [5].
Gets (STR);
Puts (STR);
return 0;
}
CodePudding user response:
Occupy the static data partition, because there is no defined end, puts the actual cross-border access may occur, this show at randomCodePudding user response:
In addition, the usage gets here is not credible, can inject illegal string, produce coredump memoryCodePudding user response:
data:image/s3,"s3://crabby-images/26bd6/26bd6a526dcd43673858d7e5b31fa5ff1ce6d335" alt=""
Changed to printf is stil
#include
#include
Int main ()
{
Char c []={" c program "};
Char [] d={} "Hello";
Char [] e={' C ', ', 'p', 'r', 'o', 'g', 'r', 'a', 'm'};
int i;
for(i=0; i<=4; I++)
C=d [I] [I];
Printf (" % s \ n ", c);
Printf (" % s \ n ", e);
return 0;
}
CodePudding user response:
data:image/s3,"s3://crabby-images/c390c/c390c5f140879811e487e193780a2cb5ec4d55c2" alt=""
data:image/s3,"s3://crabby-images/35ee1/35ee1e0410b718928a98b375e02bca80862d3d6c" alt=""
Why is that? Why don't the second warning?
CodePudding user response: