• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EDT 23:52
CEST 05:52
KST 12:52
  • Home
  • Forum
  • Calendar
  • Streams
  • Liquipedia
  • Features
  • Store
  • EPT
  • TL+
  • StarCraft 2
  • Brood War
  • Smash
  • Heroes
  • Counter-Strike
  • Overwatch
  • Liquibet
  • Fantasy StarCraft
  • TLPD
  • StarCraft 2
  • Brood War
  • Blogs
Forum Sidebar
Events/Features
News
Featured News
ByuL, and the Limitations of Standard Play2Team Liquid Map Contest #22: Results and Winners7Code S Season 2 (2026): RO4 and Finals Preview12TL.net Map Contest #22 - Voting & Ladder Map Selection7Code S Season 2 (2026) - RO8 Preview8
Community News
MC vs IdrA, Boxer vs Nal_rA to be Legacy Matches @ BlizzCon85.0.16 Hotfix (June 30) - Balance + Bug Fixes17Weekly Cups (June 22-28): Zergs thrive in new patch2[TLMC] Summer 2026 Ladder Map Rotation05.0.16 patch for SC2 goes live (8 worker start)98
StarCraft 2
General
5.0.16 Hotfix (June 30) - Balance + Bug Fixes MC vs IdrA, Boxer vs Nal_rA to be Legacy Matches @ BlizzCon The Death of Cheese: From a Professional Cheeser 5.0.16 patch for SC2 goes live (8 worker start) ByuL, and the Limitations of Standard Play
Tourneys
RSL Revival: Season 6 - Qualifiers and Main Event Douyu Cup 2026: $20,000 Legends Event (June 26-28) Maestros of The Game 2 announcement and schedule ! INu's Battles#17 <BO.9> Sparkling Tuna Cup - Weekly Open Tournament
Strategy
[G] Having the right mentality to improve
Custom Maps
New Map Maker - Looking for Advice - Love or Hate Work In Progress Melee Maps [D]RTS in all its shapes and glory <3
External Content
The PondCast: SC2 News & Results Mutation # 532 Nuclear Family Mutation # 531 Experimental Artillery Mutation # 530 One For All
Brood War
General
ASL 22 Proposed Map Pool ProGamer Paychecks Story BW General Discussion Best thing happen to StarCraft since Remastered? Data needed
Tourneys
[Megathread] Daily Proleagues [ASL21] Grand Finals The Casual Games of the Week Thread [BSL22] GosuLeague Casts - Tue & Thu 22:00 CEST
Strategy
Simple Questions, Simple Answers Creating a full chart of Zerg builds Relatively freeroll strategies Why doesn't anyone use restoration?
Other Games
General Games
ZeroSpace at Steam NextFest - Last free demo Nintendo Switch Thread Path of Exile Stormgate/Frost Giant Megathread Beyond All Reason
Dota 2
Looking for a Dota Mentor Official 'what is Dota anymore' discussion
League of Legends
Heroes of the Storm
Simple Questions, Simple Answers Heroes of the Storm 2.0
Hearthstone
Deck construction bug
TL Mafia
[94721]Better Good-Health Signs Than 3-15 Bans/Yea TL Mafia Community Thread Vanilla Mini Mafia
Community
General
US Politics Mega-thread Russo-Ukrainian War Thread Canadian Politics Mega-thread The Games Industry And ATVI Things Aren’t Peaceful in Palestine
Fan Clubs
The HerO Fan Club! The herO Fan Club!
Media & Entertainment
Movie Discussion! Series you have seen recently... [Req][Books] Good Fantasy/SciFi books [TV/BOOK] *SPOILERS* Game of Thrones Discussion
Sports
2024 - 2026 Football Thread TeamLiquid Health and Fitness Initiative For 2023 Formula 1 Discussion McBoner: A hockey love story Cricket [SPORT]
World Cup 2022
Tech Support
Computer Build, Upgrade & Buying Resource Thread
TL Community
The Automated Ban List
Blogs
Listen To The Coaches!
TrAiDoS
An Exploration of th…
waywardstrategy
I'm an arrogant trash talke…
FlaShFTW
Gauntlet SC2: A Retrospectiv…
Ctone23
ramps on octagon
StaticNine
Funny Nicknames
LUCKY_NOOB
StarCraft improvement
iopq
Customize Sidebar...

Website Feedback

Closed Threads



Active: 4882 users

The Big Programming Thread - Page 841

Forum Index > General Forum
Post a Reply
Prev 1 839 840 841 842 843 1032 Next
Thread Rules
1. This is not a "do my homework for me" thread. If you have specific questions, ask, but don't post an assignment or homework problem and expect an exact solution.
2. No recruiting for your cockamamie projects (you won't replace facebook with 3 dudes you found on the internet and $20)
3. If you can't articulate why a language is bad, don't start slinging shit about it. Just remember that nothing is worse than making CSS IE6 compatible.
4. Use [code] tags to format code blocks.
Deleted User 101379
Profile Blog Joined August 2010
4849 Posts
February 10 2017 08:38 GMT
#16801
On February 10 2017 12:18 WarSame wrote:
What is an elegant way to set a bunch of div colours in SASS?

I would ideally like to do something like
$brown: #955436
$lightblue: #AAE0FA
$pink: #D93A96
$orange: #F7941D
$red: #ED1B24
$yellow: #FEF224
$green: #1FB25A
$darkblue: #0072BB

.block-(colorexample)
background-color:$colorexample


where I could have divs with classes like
block-brown
and have it automatically sub in the colour. Should I just not bother and make a block-colour for every single colour I have?


Please don't.

Name your CSS classes after what they represent, not after what they look like. Otherwise you'll either have to search and replace all the instances when your Boss tells you that all brown buttons should now be green, which negates all the advantages of CSS, or you have a class "brown" that is now green.
Artesimo
Profile Joined February 2015
Germany573 Posts
Last Edited: 2017-02-10 08:42:40
February 10 2017 08:38 GMT
#16802
Last questions:

About JOIN, if I got a ManyToMany Relationshipt between say, Students and lecturers:


ListL result em.createQuery("SELECT s, l FROM Studens s join s.lectures")
for(Iterator i = resultL.iterator(); i.hasNext();)
{
Object [] element = (Object[]) i.hasNext()//each Object[] containing a Student at [0] and a lecture at[1]
//using get-Methods to get Student/Lecture Name and printing it out


My Output would be equivalent to the joinedtable, where for every Student, all lectures get Listet:

_Student_ _Lecture_
Hans Lecture 1
Hans Lecture 2
Hans Lecture 3
Max Lecture 2
Max Lecture 3
Anna Lecture 3
. .
. .
. .
. .
Correct?

I could also acess the name of the Students directly, via using "SELECT s.name, l.name" instead.

An implicit join would also work like:

Select s, l,
FROM Student s, lesson l


Or to only get Name+all courses of one Students:

Select s, l,
FROM Student s, lesson l
WHERE s.name = "Hans"



Last question regarding general understanding:
All Querys in the end will be translated into SQL and send to the Database, this happens either after commiting an transaktion or calling flush() (which can be dangerous since it leaves the transaktionscope open, If the transaction fails afterwards, changes made before flush() are still in the database unless handled properly). However, how do you acess objekts then, that arent in the persitence context, but in the DB.

EntityManager em = emf.createEntityManager();//Session created
EntityTransaction tx = null;
try{
tx = em.getTransaction(); //transaction context created
tx.begin() //start transaciton();
// Customer001 previously not in persistence context/Cache
customer myCustomer = em.find(Customer.class, 001);//Now in persistence context
/*
Interaction with the object I pulled from the database - How can this work,
if the select-statement only get send after the commit?
Or get everything that you need for the tx get pulled from the DB before/em.find()
circumvents the commit? What about Entities pulled with JPQL-Querys?
*/
String name = myCustomer.getName()//
myCustomer.setName = "MC";

tx.commit();//End of transaction, transactions get send to DB
}catch (RuntimeException e){
if(tx != null) && tx.isActive()) tx.rollback();//Rollback transaction in case something went wrong, and tx got created
throw e;}
finally{em.close();} //closing the session
Manit0u
Profile Blog Joined August 2004
Poland17776 Posts
February 10 2017 09:49 GMT
#16803
Just fetch the objects you need before starting the transaction. You should really only use transactions for insert/update statements, not fetching.
Time is precious. Waste it wisely.
Artesimo
Profile Joined February 2015
Germany573 Posts
February 10 2017 09:59 GMT
#16804
On February 10 2017 18:49 Manit0u wrote:
Just fetch the objects you need before starting the transaction. You should really only use transactions for insert/update statements, not fetching.


So it doesn't work, or it is just really clunky? In case of it working, is my assumption correct, that fetching always happens immediately and only inserts/update/delete statements get hold back until .commit() is called?
Hanh
Profile Joined June 2016
146 Posts
February 10 2017 10:20 GMT
#16805
On February 10 2017 18:49 Manit0u wrote:
Just fetch the objects you need before starting the transaction. You should really only use transactions for insert/update statements, not fetching.


Not true if you care about isolation and atomicity. It can lead to serious issues specially in financial applications.
Manit0u
Profile Blog Joined August 2004
Poland17776 Posts
February 10 2017 10:57 GMT
#16806
On February 10 2017 19:20 Hanh wrote:
Show nested quote +
On February 10 2017 18:49 Manit0u wrote:
Just fetch the objects you need before starting the transaction. You should really only use transactions for insert/update statements, not fetching.


Not true if you care about isolation and atomicity. It can lead to serious issues specially in financial applications.


It really depends on what you need and what you're working with. Also, different SQL servers handle transactions differently (MS SQL for example will not allow for any other queries - even reads - until the transaction is commited and closed). Sure, if data integrity is critical, you want to wrap everything in transactions (and possibly add other mechanisms of ensuring that) but for the majority of use cases you won't need that level of paranoia.
Time is precious. Waste it wisely.
Hanh
Profile Joined June 2016
146 Posts
February 10 2017 11:09 GMT
#16807
This isn't paranoia. It is about a program behaving correctly or not. Saying that I don't need to do a transaction because I am only reading is the same as saying that I don't need to use a lock because I'm reading data (except that you won't crash because the database is always acquiring integrity locks). In some cases it is fine because there is an implicit transaction or auto commit in place. Yet if someone is learning about transactions, he should do the right thing.
Artesimo
Profile Joined February 2015
Germany573 Posts
Last Edited: 2017-02-10 11:34:36
February 10 2017 11:31 GMT
#16808
But I still struggle with the fact that the DB gets the data on commit, while I use fetches inside the transaction without having commited first. Does fetch always immediately get passed on to the DB and only write/delete/inserts/everything that manipulates data get send only on commit?
(In other words, persistence context stuff like adding/changing/removing data in/from it gets applied immediately, the Database only gets changed on commit. Fetching inside a transaction doesnt change anything on the DB but loads aditional entities in the persistence context? On commit, the persistence context will be synchronized with the DB)
Hanh
Profile Joined June 2016
146 Posts
February 10 2017 12:09 GMT
#16809
I don't know what the JPA (?) layer does but speaking from the database point of view, your transaction delimits a unit of execution that is Atomic and Isolated (A and I of ACID). Atomicity means that: Everything succeeds or everything fails. For instance, if you do 2 inserts and the 2nd one fails because of a constraint violation both inserts roll back. It doesn't mean that these inserts are sent at the end of the transaction. If you fetch something, then update it, and fetch again, your second fetch will return the updated value - even if the transaction isn't committed.
Isolation is more complicated but ideally, while your transaction is underway you don't see the actions of other transactions that are run concurrently. There are subtleties because isolation impacts performance and database implementations typically offer several options of isolation level.
WarSame
Profile Blog Joined February 2010
Canada1950 Posts
February 11 2017 03:36 GMT
#16810
On February 10 2017 17:38 Morfildur wrote:
Show nested quote +
On February 10 2017 12:18 WarSame wrote:
What is an elegant way to set a bunch of div colours in SASS?

I would ideally like to do something like
$brown: #955436
$lightblue: #AAE0FA
$pink: #D93A96
$orange: #F7941D
$red: #ED1B24
$yellow: #FEF224
$green: #1FB25A
$darkblue: #0072BB

.block-(colorexample)
background-color:$colorexample


where I could have divs with classes like
block-brown
and have it automatically sub in the colour. Should I just not bother and make a block-colour for every single colour I have?


Please don't.

Name your CSS classes after what they represent, not after what they look like. Otherwise you'll either have to search and replace all the instances when your Boss tells you that all brown buttons should now be green, which negates all the advantages of CSS, or you have a class "brown" that is now green.

In this case they are going to be blocks to build a monopoly board, though, so they need to be named by colour.
Can it be I stayed away too long? Did you miss these rhymes while I was gone?
berated-
Profile Blog Joined February 2007
United States1134 Posts
Last Edited: 2017-02-11 12:48:27
February 11 2017 12:46 GMT
#16811
On February 10 2017 20:31 Artesimo wrote:
But I still struggle with the fact that the DB gets the data on commit, while I use fetches inside the transaction without having commited first. Does fetch always immediately get passed on to the DB and only write/delete/inserts/everything that manipulates data get send only on commit?
(In other words, persistence context stuff like adding/changing/removing data in/from it gets applied immediately, the Database only gets changed on commit. Fetching inside a transaction doesnt change anything on the DB but loads aditional entities in the persistence context? On commit, the persistence context will be synchronized with the DB)


The DB definitely does not only get the data on commit. JPA is just built on top of JDBC, which gets a connection and starts a transaction if you are using your transaction manager. As others have tried to explain, and probably better than I will, you are actively participating in a database transaction at that time.

If you are trying to look at the database while your code has a transaction going on, you won't be able to see it -- that's the part of the isolation levels etc. It might feel like everything happens on commit, but, that's just when everything is actually committed, not when it is transferred.

If you are in the scope of a transaction, you can read the changes that you have made but others can't (most of the time).

Here is some reading on JDBC Transactions

Underneath the hood, when you start the transaction, it takes the connection that you have and turns off auto commit. Then every time you run something with JPA, it takes the jdbc connection and prepares a statement and then executes it -- all of that is done until you call commit.


Deleted User 3420
Profile Blog Joined May 2003
24492 Posts
February 11 2017 19:57 GMT
#16812
So, C question.

I want to create a program that takes in input of the total number of variables that will have to be put into an array

then create an array that has size based on that input

but im reading that arrays can't be created with a variable as the size
wtf is that about, that seems really annoying
Blitzkrieg0
Profile Blog Joined August 2010
United States13132 Posts
Last Edited: 2017-02-11 20:24:02
February 11 2017 20:20 GMT
#16813
On February 12 2017 04:57 travis wrote:
So, C question.

I want to create a program that takes in input of the total number of variables that will have to be put into an array

then create an array that has size based on that input

but im reading that arrays can't be created with a variable as the size
wtf is that about, that seems really annoying


Are you compiling C89 standard or C99 standard? The rules are different for each. The short answer is that the compiler wants to know exactly how much memory will be needed on the stack for your array.

The simple solution is to allocate on the heap using malloc, but that might not be what your class wants you to do.
I'll always be your shadow and veil your eyes from states of ain soph aur.
Deleted User 3420
Profile Blog Joined May 2003
24492 Posts
February 11 2017 20:29 GMT
#16814
I think they want me to just initialize each array to size 50, because they told us in specifications that they won't need to hold more than 50 elements

but I don't like the huge lack in knowledge that comes with that hehe

I am finding I am not a big fan of C.... too much stuff that takes too long to do
Nesserev
Profile Blog Joined January 2011
Belgium2760 Posts
Last Edited: 2017-02-11 21:41:13
February 11 2017 21:17 GMT
#16815
--- Nuked ---
Blitzkrieg0
Profile Blog Joined August 2010
United States13132 Posts
Last Edited: 2017-02-11 21:22:04
February 11 2017 21:18 GMT
#16816
On February 12 2017 05:29 travis wrote:
I think they want me to just initialize each array to size 50, because they told us in specifications that they won't need to hold more than 50 elements

but I don't like the huge lack in knowledge that comes with that hehe

I am finding I am not a big fan of C.... too much stuff that takes too long to do


If you know the max size will be 50 its as simple as:
const int MAX_SIZE = 50;


When you compile your code the compiler knows that the arrays size is 50. It knows exactly how much stack space to allocate and it is happy.

extern int MAX_SIZE;


Contrast with the above where you're getting the max size from somewhere else. The compiler doesn't know what the value will be and it won't let you compile.
I'll always be your shadow and veil your eyes from states of ain soph aur.
Biolunar
Profile Joined February 2012
Germany224 Posts
February 11 2017 21:41 GMT
#16817
If you do this:
const int MAX_SIZE = 50;
T arr[MAX_SIZE];

then arr is a VLA. Don't use VLAs.
What is best? To crush the Zerg, see them driven before you, and hear the lamentations of the Protoss.
Deleted User 3420
Profile Blog Joined May 2003
24492 Posts
February 11 2017 21:50 GMT
#16818
what about #define ARRAY_LENGTH 50 ?
Nesserev
Profile Blog Joined January 2011
Belgium2760 Posts
Last Edited: 2017-02-11 22:14:55
February 11 2017 22:03 GMT
#16819
--- Nuked ---
Blitzkrieg0
Profile Blog Joined August 2010
United States13132 Posts
February 11 2017 22:24 GMT
#16820
I was under the impression that a constant didn't change value, but when I wrote C89 was the worst months of my life so I'll just refrain from answering anymore about it since apparently I don't remember anything.
I'll always be your shadow and veil your eyes from states of ain soph aur.
Prev 1 839 840 841 842 843 1032 Next
Please log in or register to reply.
Live Events Refresh
PiGosaur Cup
00:00
#88
PiGStarcraft714
CranKy Ducklings116
Liquipedia
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
PiGStarcraft714
RuFF_SC2 149
Nina 91
ROOTCatZ 34
StarCraft: Brood War
GuemChi 3297
Rain 3170
Shuttle 605
sSak 90
Dewaltoss 38
Noble 25
Bale 23
Super Smash Bros
hungrybox537
Other Games
summit1g9318
C9.Mang0798
JimRising 540
Sick183
ViBE157
Maynarde86
minikerr7
Organizations
Other Games
gamesdonequick1018
Dota 2
PGL Dota 2 - Main Stream225
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
[ Show 15 non-featured ]
StarCraft 2
• mYiSmile117
• CranKy Ducklings SOOP5
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
League of Legends
• Lourlo972
• Rush748
• Stunt359
Upcoming Events
Kung Fu Cup
7h 8m
Replay Cast
20h 8m
CrankTV Team League
1d 7h
Bombastic Starleague
1d 16h
The PondCast
2 days
HomeStory Cup
2 days
Replay Cast
2 days
HomeStory Cup
3 days
Replay Cast
3 days
HomeStory Cup
4 days
[ Show More ]
OSC
4 days
Sparkling Tuna Cup
5 days
WardiTV Weekly
6 days
Liquipedia Results

Completed

YSL S3
Douyu Cup 2026
Murky Cup 2026

Ongoing

IPSL Spring 2026
Acropolis #4
CSL Season 21: Qualifier 2
SCTL 2026 Spring
XSE Pro League 2026
IEM Cologne Major 2026
Stake Ranked Episode 2
CS Asia Championships 2026
Asian Champions League 2026
IEM Atlanta 2026
PGL Astana 2026
BLAST Rivals Spring 2026
IEM Rio 2026

Upcoming

CSL 2026 Summer (S21)
ASL Season 22:Wild Card Qualifier
CSLAN 4
Blizzard Classic Cup 2026
Kung Fu Cup 2026 Grand Finals
RSL Revival: Season 6
CranK Gathers Season 4: BW vs SC2 Team League
HSC XXIX
Light Tournament 2026
Eternal Conflict S2 Finale
Heroes Pulsing #3
Eternal Conflict S2 E1
FISSURE Playground #5
BLAST Open Fall 2026
Esports World Cup 2026
BLAST Bounty Summer 2026
BLAST Bounty Summer Qual
Stake Ranked Episode 3
TLPD

1. ByuN
2. TY
3. Dark
4. Solar
5. Stats
6. Nerchio
7. sOs
8. soO
9. INnoVation
10. Elazer
1. Rain
2. Flash
3. EffOrt
4. Last
5. Bisu
6. Soulkey
7. Mini
8. Sharp
Sidebar Settings...

Advertising | Privacy Policy | Terms Of Use | Contact Us

Original banner artwork: Jim Warren
The contents of this webpage are copyright © 2026 TLnet. All Rights Reserved.