Welcome to Software Development on Codidact!
Will you help us build our independent community of developers helping developers? We're small and trying to grow. We welcome questions about all aspects of software development, from design to code to QA and more. Got questions? Got answers? Got code you'd like someone to review? Please join us.
Activity for Lundinâ€
Type | On... | Excerpt | Status | Date |
---|---|---|---|---|
Comment | Post #285974 |
As a side note regarding embedded systems and main(), there's an issue where C++ claims that if main() is defined, it must be declared as int main() and I don't even think they made an exception for freestanding systems. In that case `noreturn` might save the day. That doesn't apply to C however, wh... (more) |
— | over 3 years ago |
Comment | Post #285974 |
@#53937 I wouldn't dare say anything about ABI compatibility between all *nix systems that have implemented pthreads over the years. Just take x86_32 Linux vs x86_64 Linux as the most obvious example. (more) |
— | over 3 years ago |
Comment | Post #285974 |
@#53398 Again, you can't do that for the same reasons as in my previous comment - calling convention. If you specify a return type but don't return, you risk tricking the compiler into thinking it should push/pop items on the stack which are never pushed/popped there by the function. This is also the... (more) |
— | over 3 years ago |
Comment | Post #285974 |
@#53937 Never the less, it is bad practice not to clean up your own mess no matter what the OS does. Executing such clean-up code is also an excellent way of surfacing dormant bugs elsewhere in the application (`free()` crashing etc). (more) |
— | over 3 years ago |
Comment | Post #285974 |
@#53398 The whole practical rationale for this is cases like for example a "bare metal" system where your program starts up in a power-on reset interrupt. From there on it calls the C run-time start-up code _never to return_, so no need to waste stack on storing return address etc. Then the C run-tim... (more) |
— | over 3 years ago |
Comment | Post #285968 |
@#53078 The C standard is fuzzy and only says that the pointed-at data should be regarded as an array of objects with "a fundamental alignment requirement" (an alignment less than or equal to the greatest alignment supported by the implementation in all contexts). So the alloc functions may grab more... (more) |
— | over 3 years ago |
Edit | Post #285974 | Initial revision | — | over 3 years ago |
Answer | — |
A: noreturn function with non-void return type Syntax-wise it is a function specifier and may in theory appear everywhere where `inline` (or rather the syntax item function-specifier:) can appear, since the standard doesn't say otherwise. Though of course it would be nonsense to declare `Noreturn` together with a return type and a compiler failin... (more) |
— | over 3 years ago |
Comment | Post #285969 |
Discussion about resource requests specifically: [How does the community feel about resource requests?](https://software.codidact.com/posts/277530) (more) |
— | over 3 years ago |
Comment | Post #285911 |
Also related: [The size of the code format window is much too small.](https://software.codidact.com/posts/278868) (more) |
— | over 3 years ago |
Edit | Post #285971 | Initial revision | — | over 3 years ago |
Answer | — |
A: Software recommendations category At some extent, you can ask about (programming-related) software recommendations if you manage to narrow down the scope to something specific. A question like "which one of compiler x and compiler y currently got the best support for language standard z? I'm mainly interested in features a, b and c."... (more) |
— | over 3 years ago |
Edit | Post #285968 |
Post edited: |
— | over 3 years ago |
Edit | Post #285968 |
Post edited: |
— | over 3 years ago |
Edit | Post #285968 | Initial revision | — | over 3 years ago |
Answer | — |
A: Is it OK to use scanf with a void pointer? Void pointers are compatible with every other object pointer type and as mentioned in another answer, 7.21.6/10 speaks of the type of the pointed at object, not the type of the pointer. This is consistent with the rules of effective type/pointer aliasing (6.5/6), which have to be applied as well, sin... (more) |
— | over 3 years ago |
Comment | Post #285957 |
@#8196 All of these are artificial examples. The whole point of using forward declaration in the context of opaque types is to block the caller from knowing anything about that type - which as it happens means that they won't know the struct size either. As for dynamically allocating an array of func... (more) |
— | over 3 years ago |
Comment | Post #285956 |
@#8196 And how exactly is it less duplication to increase the references to the `p` identifier from 3 times to 6 times? Imagine if it isn't called `p` but `long_contrived_name_foo`, which happens to have a sibling `long_contrived_name_bar` and if we mix up these identifiers, everything will crash & b... (more) |
— | over 3 years ago |
Comment | Post #285956 |
@#53305 That's an excellent argument actually. The argument in favour of this `sizeof *p` style is that someone would aimlessly change the _type_ of a variable without checking the code using that variable. But what if they change the _identifier_ of that variable instead - again without checking the... (more) |
— | over 3 years ago |
Edit | Post #285957 | Initial revision | — | over 3 years ago |
Answer | — |
A: When does it not work to dereference the pointer for sizeof during malloc? In addition to all the examples I gave in my answer to the linked post, all scenarios where `p` is a pointer to incomplete type fails. Not just the `void` scenario, but also when `p` is a pointer to an array of incomplete type: int (p)[] = malloc(n sizeof p); // will not compile cleanly An... (more) |
— | over 3 years ago |
Comment | Post #285956 |
Actually, after giving this some thought... a compiler must yield a diagnostic message when de-referencing a void pointer _and passing it to `sizeof`_. Both gcc and clang do this in `-pedantic` mode. They are required to do so by constraints 6.5.4.3 regarding the sizeof operator. So yes something is ... (more) |
— | over 3 years ago |
Comment | Post #285956 |
De-referencing void pointers is not allowed as per 6.3.2.2 "The (nonexistent) value of a void expression (an expression that has type void) shall not be used in any way, and implicit or explicit conversions (except to void) shall not be applied to such an expression." Clang seems to fail in issuing a... (more) |
— | over 3 years ago |
Comment | Post #285956 |
`p[i][j]); // Add asterisk to p[i][j]` Shouldn't it be `*p[i][j]`? (more) |
— | over 3 years ago |
Comment | Post #285946 |
`_Nonnull` don't use this. First of all, convention gives that this ought to be the caller's responsibility. Second, if you insist on using such features, the standard already has support for this through `static`. And lately compilers also have added support for it. So if you wish to protect against... (more) |
— | over 3 years ago |
Edit | Post #285952 | Initial revision | — | over 3 years ago |
Answer | — |
A: stpecpy(): Design a better string copy function that truncates - Performance-wise, I'd benchmark this vs `if(memchr(src,'\0',n)==src+n) memcpy(dst, src, n);` because it isn't obvious at least to me if that's faster or slower than your custom function. - Regarding where `end` is pointing, I think that's the right call since it's convenient to have a pointer to t... (more) |
— | over 3 years ago |
Comment | Post #285910 |
@#8196 The equivalent `int (*p)[5]` would have been just as problematic. There's plenty of examples where the style simply doesn't work well. (more) |
— | over 3 years ago |
Comment | Post #285899 |
@#53937 Really? I haven't heard about that and the C committee hates fixing language flaws at the expense of backwards compatibility. Such a radical change would be nice but it also means that all C code out there won't be compatible with C2x. (more) |
— | over 3 years ago |
Comment | Post #285899 |
Expect casting to the expected type is a common way to dodge implicit promotions, so doing so might actually be considered good practice depending on context. For example MISRA-C wouldn't allow this code `unsigned short a,b; ... signed int c = a + b;` but require `c = (signed int)(a + b)`. Though thi... (more) |
— | over 3 years ago |
Comment | Post #285908 |
You could take the live production database and have it copied to a second instance on regular basis, for example at the same time when backups are running.
This identical, continuously updated copy of the real database becomes your test one, where you are free to play around. This also allows you... (more) |
— | over 3 years ago |
Edit | Post #285912 | Initial revision | — | over 3 years ago |
Answer | — |
A: Are static pointers implicitly initialized to NULL? Yes, it is guaranteed to evaluate to true. All variables with static storage duration are set to zero in case of arithmetic types or set to null in case they are pointers. The relevant part is C17 6.7.9/10: > If an object that has automatic storage duration is not initialized explicitly, its value... (more) |
— | over 3 years ago |
Comment | Post #285899 |
The forgetting stdlib.h argument was what once started the whole "don't cast the result" business, where otherwise people wouldn't care much about the cast. Bugs caused by C90 implicit int are _not_ fun to debug, they are subtle as sin. It was a very valid argument back in the 1990s. Today, not so mu... (more) |
— | over 3 years ago |
Comment | Post #285899 |
The difference between `(int*)malloc` and `(int)42` is that malloc does actually return a different type. In your integer examples, the type is already the expected `int`. Furthermore, the C language does actually not allow _any_ implicit pointer conversions except during pointer assignment. 6.5.4 _C... (more) |
— | over 3 years ago |
Edit | Post #285910 | Initial revision | — | over 3 years ago |
Answer | — |
A: How to properly use malloc? Should we cast the result of malloc? The cast to the intended type is not necessary in C, since during assignment, the `void` returned by `malloc` can be implicitly converted to any other object pointer and vice versa (as per C17 6.5.16.1). So the cast does add clutter. However, there's nothing wr... (more) |
— | over 3 years ago |
Comment | Post #285826 |
It's the very same thing as I mentioned here: https://software.codidact.com/posts/278910/278932#answer-278932. In fact I've stopped writing self-answered Q&A on SO and post all such content here instead. Because such posts tend to be of significantly higher quality than the average Q&A (and require a... (more) |
— | over 3 years ago |
Comment | Post #285875 |
So how about dropping the latter part of that sentence and go with something like "Best practices as long as a clear 'best' criteria is present. Examples could be: what code gives fastest execution, least memory use, widest tool support for a target, most beginner-friendly IDE for a certain language ... (more) |
— | over 3 years ago |
Comment | Post #285875 |
I think the rationale for the "best" criteria needs to be there to prevent really bad questions like "what compiler is best". Asking "what compiler is best _for a beginner using Windows_" is however quite some improvement of that question. Perhaps this should be rephrased focusing on the quality of t... (more) |
— | over 3 years ago |
Edit | Post #285870 | Initial revision | — | over 3 years ago |
Question | — |
A cleanup of "What type of questions can I ask here?" What type of questions can I ask here? has gotten rather cluttered since we have added/removed a lot of things along the way. In particular, I think it is hard to get an idea of what's on-topic by just taking a glance at it. Proposed changes: 1) Move the text directly below on-topic to a separa... (more) |
— | over 3 years ago |
Comment | Post #285836 |
Since cyclomatic complexity is the number of possible execution paths, it is expected behavior. What one can do is to keep switches simple - if they only check an integer enum which has a contiguous sequence, the switch will get optimized well. In case of floating point or strings etc, not so much. T... (more) |
— | over 3 years ago |
Comment | Post #285813 |
Similarly, how can you explain passing a function to a function, is this pass by value: `void func (void f(void));` Of course not. (more) |
— | over 3 years ago |
Comment | Post #285813 |
"if you want to pass a reference to an object you always have to be explicit about it" How do you explain this then? `void func (int arr[n]);` (more) |
— | over 3 years ago |
Comment | Post #285800 |
@#53177 Maybe give it a week at least to let more people vote and give feedback? (more) |
— | over 3 years ago |
Edit | Post #285800 | Initial revision | — | over 3 years ago |
Answer | — |
A: Should we allow UI/UX questions in our community? I think it should be on-topic with the following distinction: On-topic - Technical questions regarding to UI, including mark-up language syntax, how to set properties in RAD tools, how to use graphic libraries etc. - Algorithm questions for how to draw graphics, including at some extent the math... (more) |
— | over 3 years ago |
Edit | Post #285724 | Initial revision | — | over 3 years ago |
Answer | — |
A: Why object-oriented instead of class-oriented? As with anything computer science-related that dates back to the 1960s and 70s, things just happened at a whim. Everything was new and highly experimental back then. Nobody knew how to write or design programs the best way, how to organize them or what coding styles that were most readable. The whole... (more) |
— | over 3 years ago |